From f326bd639d60371be34f2d4f4cf5fd6081503477 Mon Sep 17 00:00:00 2001 From: Abdi Tolessa <41271840+AbdiTolesa@users.noreply.github.com> Date: Mon, 16 Mar 2026 22:21:53 +0300 Subject: [PATCH 1/5] Extend Style slider component's usability --- css/admin/frm-settings-components.css | 627 +- css/admin/welcome-tour.css | 153 +- css/font_icons.css | 89 +- css/frm_admin.css | 11946 +++++++++++++- css/frm_testing_mode.css | 2860 +++- js/addons-page.js | 4846 +++++- js/form-templates.js | 6800 +++++++- js/formidable-settings-components.js | 2932 +++- js/formidable-web-components.js | 5836 ++++++- js/formidable_admin.js | 13301 +++++++++++++++- js/formidable_blocks.js | 2716 +++- js/formidable_dashboard.js | 960 +- js/formidable_overlay.js | 794 +- js/formidable_styles.js | 3161 +++- js/frm_testing_mode.js | 3487 +++- js/onboarding-wizard.js | 1901 ++- .../components/slider-component.js | 6 + .../frm-border-radius-component.css | 230 +- .../frm-colorpicker-component.css | 155 +- .../frm-dropdown-component.css | 133 +- .../frm-range-slider-component.css | 291 +- .../frm-tab-navigator-component.css | 244 +- .../frm-typography-component.css | 167 +- js/welcome-tour.js | 4438 +++++- 24 files changed, 68044 insertions(+), 29 deletions(-) diff --git a/css/admin/frm-settings-components.css b/css/admin/frm-settings-components.css index 460b746c3a..c2a027558e 100644 --- a/css/admin/frm-settings-components.css +++ b/css/admin/frm-settings-components.css @@ -1 +1,626 @@ -.formidable_page_formidable-styles.js .control-section .accordion-section-title:focus{background:none}.formidable_page_formidable-styles .frm-right-panel h3.accordion-section-title:hover>svg:last-child,.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title>svg:first-child,.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title>svg:last-child{color:var(--grey-900)}.formidable_page_formidable-styles .frm-right-panel .frm-style-component{align-self:center}.frm_settings_form .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button,.formidable_page_formidable-styles .frm-right-panel .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button{background-color:#fff !important}.frm_settings_form .frm-style-component .wp-picker-container button,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container button{position:relative;height:36px !important;background-image:none !important;overflow:hidden;background-color:#fff !important}.frm_settings_form .frm-style-component .wp-picker-container::after,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container::after{content:"";width:20px;height:20px;display:block;position:absolute;top:0;right:8px;bottom:0;margin:auto;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center;z-index:10}.frm_settings_form .frm-style-component .wp-color-result-text,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-color-result-text{line-height:36px !important;padding:0 12px;border:0}.frm_settings_form .frm-style-component .color-alpha,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .color-alpha{width:20px !important;height:20px !important;border-radius:50% !important;border:1px solid #d0d5dd;top:0;left:0;bottom:0;margin:auto;margin-left:12px}.frm_settings_form .frm-style-component .wp-picker-input-wrap input,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-input-wrap input{width:calc(100% - 10px) !important;margin:1px 5px;height:32px;line-height:32px}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component>div{max-width:216px}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .wp-picker-container{max-width:calc(100% - 44px);position:relative}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component button.frm_choose_image_box{width:36px;height:36px;padding:0;background:#fff;overflow:hidden;text-indent:-999px;flex-wrap:wrap;border:none}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_styling_frame{margin-left:0}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper{position:relative;width:36px;height:36px;margin:0;border:1px solid var(--grey-300);border-radius:var(--small-radius);overflow:hidden;box-sizing:border-box}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame{max-width:120%;height:120%;margin:-10%;position:relative}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_data{position:absolute;left:0;top:0;width:100%;height:100%;overflow:hidden;margin:0;border-radius:var(--small-radius)}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option{width:100%;height:100%;border:1px solid var(--red-500);text-indent:-9999px;position:absolute;top:0;left:0}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::before{opacity:0;content:"";display:block;position:absolute;width:100%;height:100%;z-index:1;top:0;left:0;background:rgba(255,255,255,.8)}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::after{opacity:0;content:"";display:block;position:absolute;width:100%;height:100%;z-index:1;top:0;left:0;background:url("../../images/style/close.svg") no-repeat;background-position:center}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::before,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::after{opacity:1}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame img{width:100%;height:100%}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper+*,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_title,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_bg_image_additional_settings,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option *{display:none}.frm-style-component .frm-radio-container{max-width:216px;height:36px;background:#f2f4f7;gap:var(--small-gap);padding:var(--gap-2xs);box-sizing:border-box;border-radius:var(--small-radius);position:relative}.frm-style-component.frm-field-shape .frm-radio-container{max-width:unset}.frm-style-component.frm-direction-component .frm-radio-container{gap:var(--gap-xs)}.frm-style-component .frm-radio-container svg{width:16px}.frm-style-component .frm-radio-container .frm-radio-active-tracker{display:block;width:28%;height:calc(100% - 8px);background:#fff;border-radius:var(--small-radius);box-shadow:var(--button-shadow);position:absolute;top:var(--gap-2xs);bottom:0;left:var(--gap-2xs);z-index:1;transition:.35s transform cubic-bezier(0.075, 0.82, 0.165, 1)}.frm-style-component.frm-field-shape .frm-radio-container .frm-radio-active-tracker{width:23%}.frm-style-component.frm-align-component.frm-2-options .frm-radio-container .frm-radio-active-tracker,.frm-style-component.frm-direction-component .frm-radio-container .frm-radio-active-tracker,.frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker{width:calc(50% - var(--gap-xs))}.frm-style-component .frm-radio-container>label{width:30%;height:100%;margin:0;cursor:pointer;position:relative;display:flex;z-index:2}.frm-style-component.frm-field-shape .frm-radio-container>label{width:23%}.frm-style-component.frm-align-component.frm-2-options .frm-radio-container>label,.frm-style-component.frm-direction-component .frm-radio-container>label,.frm-style-component.frm-text-toggle-component .frm-radio-container>label{width:50%}.frm-style-component.frm-text-toggle-component .frm-radio-container{height:44px;max-width:unset;gap:var(--gap-xs);padding:var(--gap-xs)}.frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker{height:calc(100% - var(--gap-sm));top:var(--gap-xs)}.frm-style-tabs-wrapper .frm-tabs-navs ul>li:not(.frm-active):hover,.frm-style-component .frm-radio-container input:not(:checked)+label:hover{background:#eaecf0;border-radius:var(--small-radius);box-shadow:var(--button-shadow)}.frm-style-component .frm-radio-container input{display:none}.frm-style-component .frm-slider-container{width:calc(100% - 91px);display:flex;align-items:center;color:#1d2939}.frm-style-component .frm-slider-container svg.frmsvg{color:currentColor;margin-right:8px;margin-left:-5px;position:relative;z-index:15}.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover{color:#4199fd;cursor:pointer}.frm-style-component .frm-slider-container .frm-slider-active-track{display:block;height:100%;width:0;position:relative;border-radius:200px}.frm-style-component .frm-slider-container .frm-slider-active-track,.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{background:#4199fd;box-shadow:0 1.88px 4px -1px rgba(16,24,40,.03),0 6px 8px -2px rgba(16,24,40,.08)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{position:absolute;display:block;width:16px;height:16px;border-radius:50%;transform:translateX(15px);cursor:grab;right:0;top:0;bottom:0;margin:auto}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label{position:absolute;display:block;width:48px;height:36px;background:#101828;color:#fff;font-weight:400;font-size:var(--text-sm);line-height:36px;border-radius:var(--small-radius);transform:translate(-18px, -42px) scale3d(0.7, 1, 1);opacity:0;z-index:-2;pointer-events:none;text-align:center;user-select:none}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label{z-index:12;transform:translate(-18px, -42px) scale3d(1, 1, 1);opacity:1;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before{content:"";display:block;position:absolute;width:18px;height:18px;border-radius:50%;left:0;top:0;transform:translate(-5px, -5px) scale3d(0.7, 0.7, 1);border:4px solid #4199fd;opacity:0;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before{opacity:.5;transform:translate(-5px, -5px) scale3d(1, 1, 1);transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after{content:"";position:absolute;display:block;width:180%;height:200%;border-radius:50%;left:0;top:0;transform:translate(-24%, -24%)}.frm-style-component .frm-slider-value{width:86px;height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300)}.frm-style-component .frm-slider-value>*{border:none}.frm-style-component .frm-slider-value input{width:40px;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-style-component .frm-slider-value select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px;padding-right:24px !important}.frm-style-component .frm-slider-value select.frm-single-unit{pointer-events:none;background-image:none;padding-right:12px !important}.frm-style-component .frm-slider{display:block;width:calc(100% - 5px);height:4px;background:#eaecf0;border-radius:200px;cursor:pointer}.frm-slider-component .frm-independent-slider-field{margin-top:10px}.frm-slider-component.frm-disabled .frm-slider-container{pointer-events:none;opacity:.5}.frm-slider-component.frm-disabled .frm-slider-value input[type=text]{width:28px}.frm-slider-component.frm-disabled .frm-slider-value select{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text]{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select{width:28px}.frm-style-component .frm-slider-component.frm-has-multiple-values{margin-bottom:10px}.frm-tabs-wrapper{position:relative;overflow:hidden}.frm-tabs-wrapper .frm-tabs-navigator{margin:0;padding:0;display:flex;gap:var(--gap-xs);justify-content:space-between;align-items:center;background:#f2f4f7;border-radius:var(--small-radius);box-sizing:border-box;height:44px;position:relative;z-index:2}.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item{flex:1;text-align:center;cursor:pointer}.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background{display:block;height:100%;background:#fff;position:absolute;top:0;left:0;z-index:1}.frm-style-tabs-wrapper{position:relative}.frm-style-tabs-wrapper .frm-tabs-navs{padding:0;min-height:44px}.frm-style-tabs-wrapper .frm-tabs-navs ul{margin:0;height:var(--h-md);position:relative;justify-content:space-between}.frm-style-tabs-wrapper .frm-tabs-navs ul li,.frm-style-tabs-wrapper .frm-tabs-navs ul li a{color:var(--grey-500);font-weight:500;font-size:var(--text-sm);line-height:28px}.frm-style-tabs-wrapper .frm-tabs-navs ul li{flex:1;height:28px;text-align:center;margin-top:var(--gap-xs);margin-bottom:0;cursor:pointer}.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active,.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a{color:var(--grey-900)}.frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child{margin-left:var(--gap-xs)}.frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child{margin-right:var(--gap-xs)}.frm-style-tabs-wrapper .frm-tabs-delimiter{position:absolute;top:0;left:0;width:100%;background:#f2f4f7;height:44px;margin:0;border-radius:var(--small-radius)}.frm-style-tabs-wrapper .frm-tabs-delimiter .frm-tabs-active-underline{height:28px;background:#fff;position:absolute;left:0;bottom:8px;transition:.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);border-radius:var(--small-radius);box-shadow:var(--button-shadow);display:none}.frm-tabs-container{position:relative;overflow:hidden;margin-top:var(--gap-md);height:100%}.frm-style-tabs-wrapper .frm-tabs-container .frm-tabs-slide-track{transition:.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-tabs-wrapper .frm-tabs-slide-track>div{flex:0 0 100%;opacity:0;transition:.25s opacity linear;position:relative;height:auto;max-height:unset;overflow:hidden;box-sizing:border-box}.frm-style-tabs-wrapper .frm-tabs-slide-track>div>div{overflow:auto;position:relative;width:100%;padding:0;box-sizing:border-box}.frm-tabs-slide-track>div>div:first-child{height:100%}.frm-tabs-slide-track>div.frm-active{opacity:1;transition:.35s opacity linear}.frm-style-component .frm_toggle_slider{background:#f2f4f7}.frm-style-component label.frm-copy-text{line-height:32px;cursor:pointer;white-space:nowrap}.frm-style-component .wp-picker-holder{right:0}.frm-style-component .CodeMirror{min-height:unset !important;height:350px !important}.frm-style-component .CodeMirror .CodeMirror-placeholder{color:var(--grey-400)}.formidable_page_formidable-styles .accordion-section-content .frm-style-item-heading{font-weight:500;font-size:var(--text-md);color:var(--grey-900)}.frm-unit-input{position:relative;display:flex;align-items:center}.frm-unit-input input[type=number]::-webkit-outer-spin-button,.frm-unit-input input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none}.frm-unit-input .frm-input-group-suffix{position:absolute;top:1px;right:1px;display:flex;align-items:center;height:calc(100% - 2px);padding-right:var(--gap-xs)}.frm-unit-input .frm-input-group-suffix select{width:fit-content;height:100%;min-height:unset;font-size:var(--text-sm);text-align:right;color:var(--grey-500) !important;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%23667085' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 0 top 50%;padding-left:var(--gap-2xs);padding-right:21px !important;border:rgba(0,0,0,0)}.frm-unit-input .frm-input-group-suffix select:focus-visible{outline:1px solid var(--primary-500);outline-offset:-2px} +/*!***********************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/admin/frm-settings-components.scss ***! + \***********************************************************************************************************************************************************************************************************************************************/ +/** + * Formidable Forms settings components styles + */ +/** + * Accordion settings component styles + */ +.formidable_page_formidable-styles.js .control-section .accordion-section-title:focus { + background: none; +} +.formidable_page_formidable-styles .frm-right-panel h3.accordion-section-title:hover > svg:last-child, +.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title > svg:first-child, +.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title > svg:last-child { + color: var(--grey-900); +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component { + align-self: center; +} + +/** + * Color picker component styles + */ +.frm_settings_form .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button, +.formidable_page_formidable-styles .frm-right-panel .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button { + background-color: #fff !important; +} +.frm_settings_form .frm-style-component .wp-picker-container button, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container button { + position: relative; + height: 36px !important; + background-image: none !important; + overflow: hidden; + background-color: #fff !important; +} +.frm_settings_form .frm-style-component .wp-picker-container::after, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container::after { + content: ""; + width: 20px; + height: 20px; + display: block; + position: absolute; + top: 0; + right: 8px; + bottom: 0; + margin: auto; + background: url("../../images/style/small-arrow.svg") no-repeat; + background-position: center; + z-index: 10; +} +.frm_settings_form .frm-style-component .wp-color-result-text, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-color-result-text { + line-height: 36px !important; + padding: 0 12px; + border: 0; +} +.frm_settings_form .frm-style-component .color-alpha, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component .color-alpha { + width: 20px !important; + height: 20px !important; + border-radius: 50% !important; + border: 1px solid rgb(208, 213, 221); + top: 0; + left: 0; + bottom: 0; + margin: auto; + margin-left: 12px; +} +.frm_settings_form .frm-style-component .wp-picker-input-wrap input, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-input-wrap input { + width: calc(100% - 10px) !important; + margin: 1px 5px; + height: 32px; + line-height: 32px; +} + +/** + * Background image component styles + */ +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component > div { + max-width: 216px; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .wp-picker-container { + max-width: calc(100% - 44px); + position: relative; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component button.frm_choose_image_box { + width: 36px; + height: 36px; + padding: 0; + background: white; + overflow: hidden; + text-indent: -999px; + flex-wrap: wrap; + border: none; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_styling_frame { + margin-left: 0; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper { + position: relative; + width: 36px; + height: 36px; + margin: 0; + border: 1px solid var(--grey-300); + border-radius: var(--small-radius); + overflow: hidden; + box-sizing: border-box; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame { + max-width: 120%; + height: 120%; + margin: -10%; + position: relative; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_data { + position: absolute; + left: 0; + top: 0; + width: 100%; + height: 100%; + overflow: hidden; + margin: 0; + border-radius: var(--small-radius); +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option { + width: 100%; + height: 100%; + border: 1px solid var(--red-500); + text-indent: -9999px; + position: absolute; + top: 0; + left: 0; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::before { + opacity: 0; + content: ""; + display: block; + position: absolute; + width: 100%; + height: 100%; + z-index: 1; + top: 0; + left: 0; + background: rgba(255, 255, 255, 0.8); +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::after { + opacity: 0; + content: ""; + display: block; + position: absolute; + width: 100%; + height: 100%; + z-index: 1; + top: 0; + left: 0; + background: url("../../images/style/close.svg") no-repeat; + background-position: center; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::before, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::after { + opacity: 1; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame img { + width: 100%; + height: 100%; +} +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper + *, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_title, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_bg_image_additional_settings, +.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option * { + display: none; +} + +/** + * Radio buttons component styles + */ +.frm-style-component .frm-radio-container { + max-width: 216px; + height: 36px; + background: rgb(242, 244, 247); + gap: var(--small-gap); + padding: var(--gap-2xs); + box-sizing: border-box; + border-radius: var(--small-radius); + position: relative; +} +.frm-style-component.frm-field-shape .frm-radio-container { + max-width: unset; +} +.frm-style-component.frm-direction-component .frm-radio-container { + gap: var(--gap-xs); +} +.frm-style-component .frm-radio-container svg { + width: 16px; +} +.frm-style-component .frm-radio-container .frm-radio-active-tracker { + display: block; + width: 28%; + height: calc(100% - 8px); + background: white; + border-radius: var(--small-radius); + box-shadow: var(--button-shadow); + position: absolute; + top: var(--gap-2xs); + bottom: 0; + left: var(--gap-2xs); + z-index: 1; + transition: 0.35s transform cubic-bezier(0.075, 0.82, 0.165, 1); +} +.frm-style-component.frm-field-shape .frm-radio-container .frm-radio-active-tracker { + width: 23%; +} +.frm-style-component.frm-align-component.frm-2-options .frm-radio-container .frm-radio-active-tracker, .frm-style-component.frm-direction-component .frm-radio-container .frm-radio-active-tracker, .frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker { + width: calc(50% - var(--gap-xs)); +} +.frm-style-component .frm-radio-container > label { + width: 30%; + height: 100%; + margin: 0; + cursor: pointer; + position: relative; + display: flex; + z-index: 2; +} +.frm-style-component.frm-field-shape .frm-radio-container > label { + width: 23%; +} +.frm-style-component.frm-align-component.frm-2-options .frm-radio-container > label, .frm-style-component.frm-direction-component .frm-radio-container > label, .frm-style-component.frm-text-toggle-component .frm-radio-container > label { + width: 50%; +} +.frm-style-component.frm-text-toggle-component .frm-radio-container { + height: 44px; + max-width: unset; + gap: var(--gap-xs); + padding: var(--gap-xs); +} +.frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker { + height: calc(100% - var(--gap-sm)); + top: var(--gap-xs); +} + +.frm-style-tabs-wrapper .frm-tabs-navs ul > li:not(.frm-active):hover, +.frm-style-component .frm-radio-container input:not(:checked) + label:hover { + background: rgb(234, 236, 240); + border-radius: var(--small-radius); + box-shadow: var(--button-shadow); +} + +.frm-style-component .frm-radio-container input { + display: none; +} + +/** + * Sliders component styles + */ +.frm-style-component .frm-slider-container { + width: calc(100% - 91px); + display: flex; + align-items: center; + color: rgb(29, 41, 57); +} +.frm-style-component .frm-slider-container svg.frmsvg { + color: currentColor; + margin-right: 8px; + margin-left: -5px; + position: relative; + z-index: 15; +} + +.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover { + color: rgb(65, 153, 253); + cursor: pointer; +} + +.frm-style-component .frm-slider-container .frm-slider-active-track { + display: block; + height: 100%; + width: 0; + position: relative; + border-radius: 200px; +} +.frm-style-component .frm-slider-container .frm-slider-active-track, +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { + background: rgb(65, 153, 253); + box-shadow: 0 1.88px 4px -1px rgba(16, 24, 40, 0.03), 0 6px 8px -2px rgba(16, 24, 40, 0.08); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { + position: absolute; + display: block; + width: 16px; + height: 16px; + border-radius: 50%; + transform: translateX(15px); + cursor: grab; + right: 0; + top: 0; + bottom: 0; + margin: auto; +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label { + position: absolute; + display: block; + width: 48px; + height: 36px; + background: rgb(16, 24, 40); + color: white; + font-weight: 400; + font-size: var(--text-sm); + line-height: 36px; + border-radius: var(--small-radius); + transform: translate(-18px, -42px) scale3d(0.7, 1, 1); + opacity: 0; + z-index: -2; + pointer-events: none; + text-align: center; + user-select: none; +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label { + z-index: 12; + transform: translate(-18px, -42px) scale3d(1, 1, 1); + opacity: 1; + transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before { + content: ""; + display: block; + position: absolute; + width: 18px; + height: 18px; + border-radius: 50%; + left: 0; + top: 0; + transform: translate(-5px, -5px) scale3d(0.7, 0.7, 1); + border: 4px solid rgb(65, 153, 253); + opacity: 0; + transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before { + opacity: 0.5; + transform: translate(-5px, -5px) scale3d(1, 1, 1); + transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after { + content: ""; + position: absolute; + display: block; + width: 180%; + height: 200%; + border-radius: 50%; + left: 0; + top: 0; + transform: translate(-24%, -24%); +} + +.frm-style-component .frm-slider-value { + width: 86px; + height: 36px; + display: flex; + justify-content: center; + box-sizing: border-box; + background: white; + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); +} +.frm-style-component .frm-slider-value > * { + border: none; +} +.frm-style-component .frm-slider-value input { + width: 40px; + height: 100%; + padding: 0; + font-size: var(--text-sm); + color: rgb(16, 24, 40); + padding-left: 12px; + box-sizing: border-box; +} +.frm-style-component .frm-slider-value select { + text-align: right; + padding: 0; + font-size: var(--text-sm); + color: rgb(102, 112, 133); + width: 44px; + background: url("../../images/style/small-arrow.svg") no-repeat; + background-position: center right 12px; + padding-right: 24px !important; +} +.frm-style-component .frm-slider-value select.frm-single-unit { + pointer-events: none; + background-image: none; + padding-right: 12px !important; +} +.frm-style-component .frm-slider { + display: block; + width: calc(100% - 5px); + height: 4px; + background: rgb(234, 236, 240); + border-radius: 200px; + cursor: pointer; +} + +.frm-slider-component .frm-independent-slider-field { + margin-top: 10px; +} +.frm-slider-component.frm-disabled .frm-slider-container { + pointer-events: none; + opacity: 0.5; +} +.frm-slider-component.frm-disabled .frm-slider-value input[type=text] { + width: 28px; +} +.frm-slider-component.frm-disabled .frm-slider-value select { + width: 56px; +} +.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text] { + width: 56px; +} +.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select { + width: 28px; +} + +.frm-style-component .frm-slider-component.frm-has-multiple-values { + margin-bottom: 10px; +} + +/** + * Tabs component styles + */ +.frm-tabs-wrapper { + position: relative; + overflow: hidden; +} +.frm-tabs-wrapper .frm-tabs-navigator { + margin: 0; + padding: 0; + display: flex; + gap: var(--gap-xs); + justify-content: space-between; + align-items: center; + background: rgb(242, 244, 247); + border-radius: var(--small-radius); + box-sizing: border-box; + height: 44px; + position: relative; + z-index: 2; +} +.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item { + flex: 1; + text-align: center; + cursor: pointer; +} +.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background { + display: block; + height: 100%; + background: white; + position: absolute; + top: 0; + left: 0; + z-index: 1; +} + +.frm-style-tabs-wrapper { + position: relative; +} +.frm-style-tabs-wrapper .frm-tabs-navs { + padding: 0; + min-height: 44px; +} +.frm-style-tabs-wrapper .frm-tabs-navs ul { + margin: 0; + height: var(--h-md); + position: relative; + justify-content: space-between; +} +.frm-style-tabs-wrapper .frm-tabs-navs ul li, +.frm-style-tabs-wrapper .frm-tabs-navs ul li a { + color: var(--grey-500); + font-weight: 500; + font-size: var(--text-sm); + line-height: 28px; +} +.frm-style-tabs-wrapper .frm-tabs-navs ul li { + flex: 1; + height: 28px; + text-align: center; + margin-top: var(--gap-xs); + margin-bottom: 0; + cursor: pointer; +} +.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active, .frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a { + color: var(--grey-900); +} +.frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child { + margin-left: var(--gap-xs); +} +.frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child { + margin-right: var(--gap-xs); +} +.frm-style-tabs-wrapper .frm-tabs-delimiter { + position: absolute; + top: 0; + left: 0; + width: 100%; + background: rgb(242, 244, 247); + height: 44px; + margin: 0; + border-radius: var(--small-radius); +} +.frm-style-tabs-wrapper .frm-tabs-delimiter .frm-tabs-active-underline { + height: 28px; + background: white; + position: absolute; + left: 0; + bottom: 8px; + transition: 0.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); + border-radius: var(--small-radius); + box-shadow: var(--button-shadow); + display: none; +} + +.frm-tabs-container { + position: relative; + overflow: hidden; + margin-top: var(--gap-md); + height: 100%; +} + +.frm-style-tabs-wrapper .frm-tabs-container .frm-tabs-slide-track { + transition: 0.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-tabs-wrapper .frm-tabs-slide-track > div { + flex: 0 0 100%; + opacity: 0; + transition: 0.25s opacity linear; + position: relative; + height: auto; + max-height: unset; + overflow: hidden; + box-sizing: border-box; +} +.frm-style-tabs-wrapper .frm-tabs-slide-track > div > div { + overflow: auto; + position: relative; + width: 100%; + padding: 0; + box-sizing: border-box; +} + +.frm-tabs-slide-track > div > div:first-child { + height: 100%; +} +.frm-tabs-slide-track > div.frm-active { + opacity: 1; + transition: 0.35s opacity linear; +} + +/** + * Miscellaneous settings component styles + */ +.frm-style-component .frm_toggle_slider { + background: rgb(242, 244, 247); +} + +.frm-style-component label.frm-copy-text { + line-height: 32px; + cursor: pointer; + white-space: nowrap; +} + +.frm-style-component .wp-picker-holder { + right: 0; +} + +.frm-style-component .CodeMirror { + min-height: unset !important; + height: 350px !important; +} +.frm-style-component .CodeMirror .CodeMirror-placeholder { + color: var(--grey-400); +} + +.formidable_page_formidable-styles .accordion-section-content .frm-style-item-heading { + font-weight: 500; + font-size: var(--text-md); + color: var(--grey-900); +} + +.frm-unit-input { + position: relative; + display: flex; + align-items: center; +} +.frm-unit-input input[type=number]::-webkit-outer-spin-button, +.frm-unit-input input[type=number]::-webkit-inner-spin-button { + -webkit-appearance: none; + appearance: none; +} +.frm-unit-input .frm-input-group-suffix { + position: absolute; + top: 1px; + right: 1px; + display: flex; + align-items: center; + height: calc(100% - 2px); + padding-right: var(--gap-xs); +} +.frm-unit-input .frm-input-group-suffix select { + width: fit-content; + height: 100%; + min-height: unset; + font-size: var(--text-sm); + text-align: right; + color: var(--grey-500) !important; + background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%23667085' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 0 top 50%; + padding-left: var(--gap-2xs); + padding-right: 21px !important; + border: transparent; +} +.frm-unit-input .frm-input-group-suffix select:focus-visible { + outline: 1px solid var(--primary-500); + outline-offset: -2px; +} + +/*# sourceMappingURL=frm-settings-components.css.map*/ \ No newline at end of file diff --git a/css/admin/welcome-tour.css b/css/admin/welcome-tour.css index 6b3f3cf0fc..306d2df092 100644 --- a/css/admin/welcome-tour.css +++ b/css/admin/welcome-tour.css @@ -1 +1,152 @@ -.frm-checklist{width:316px;height:400px;overflow:hidden}.frm-checklist,.frm-checklist *,.frm-checklist *::before,.frm-checklist *::after{box-sizing:border-box}.frm-checklist p,.frm-checklist span{font-size:var(--text-xs)}.frm-checklist__header .frmsvg{transition:transform 200ms ease-out 50ms}.frm-checklist__progress-bar{height:8px}.frm-checklist__progress-fill{width:0}.frm-checklist__dismiss{height:50px;border-top:1px solid var(--grey-100) !important;cursor:pointer;transition:height 150ms cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-checklist__dismiss>span{transition:color 150ms ease-out}.frm-checklist__dismiss:hover>span{color:var(--grey-600) !important}.frm-checklist__completed{height:100%}.frm-checklist__completed p{color:var(--grey-800);margin:0}.frm-checklist__step-status{height:16px;width:16px;border-radius:50%;border:1.5px dashed var(--grey-400)}.frm-checklist__step-description{background-color:var(--grey-50);border-radius:var(--small-radius);line-height:var(--leading);display:none}.frm-checklist__step--active .frm-checklist__step-title,.frm-checklist__step--active .frm-checklist__step-title a{font-weight:600;color:var(--grey-800)}.frm-checklist__step--active .frm-checklist__step-description{display:block}.frm-checklist__step--completed .frm-checklist__step-status{background-color:var(--success-500);border-style:solid;border-color:var(--success-500)}.frm-checklist--collapsed{height:auto}.frm-checklist--collapsed .frm-checklist__steps{display:none}.frm-checklist--collapsed .frm-checklist__dismiss{height:0;overflow:hidden}.frm-checklist--collapsed .frm-checklist__header .frmsvg{transform:rotate(-180deg)}.frm-spotlight{--fadeout-time: 25ms;position:fixed;cursor:default}.frm-spotlight[data-placement=right]{transform:translateY(-50%)}.frm-spotlight[data-placement=bottom]{transform:translateX(-50%)}.frm-spotlight>*{flex:0 0 auto}.frm-spotlight__content{position:relative;box-sizing:border-box;flex-shrink:0;width:242px;border:1px solid var(--grey-200);overflow:visible}.frm-spotlight__content::after{content:"";position:absolute;width:11px;height:11px;background-color:inherit;transform:translateY(-50%) rotate(45deg);border-left:1px solid var(--grey-200);border-radius:2px}.frm-spotlight[data-placement=right] .frm-spotlight__content::after{top:50%;left:-6px;transform:translateY(-50%) rotate(45deg);border-bottom:1px solid var(--grey-200)}.frm-spotlight[data-placement=bottom] .frm-spotlight__content::after{top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);border-top:1px solid var(--grey-200)}.frm-spotlight__pointer{box-sizing:border-box;width:14px;height:14px;background-color:var(--grey-600);padding:3px;border-radius:50%}.frm-spotlight[data-placement=right] .frm-spotlight__pointer{margin-right:var(--gap-2xs)}.frm-spotlight[data-placement=bottom] .frm-spotlight__pointer{margin-bottom:var(--gap-2xs)}.frm-welcome-tour .frm-checklist{position:fixed;right:var(--gap-md);bottom:var(--gap-sm);z-index:9999} +/*!************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/admin/welcome-tour.scss ***! + \************************************************************************************************************************************************************************************************************************************/ +.frm-checklist { + width: 316px; + height: 400px; + overflow: hidden; +} +.frm-checklist, +.frm-checklist *, +.frm-checklist *::before, +.frm-checklist *::after { + box-sizing: border-box; +} +.frm-checklist p, +.frm-checklist span { + font-size: var(--text-xs); +} +.frm-checklist__header .frmsvg { + transition: transform 200ms ease-out 50ms; +} +.frm-checklist__progress-bar { + height: 8px; +} +.frm-checklist__progress-fill { + width: 0; +} +.frm-checklist__dismiss { + height: 50px; + border-top: 1px solid var(--grey-100) !important; + cursor: pointer; + transition: height 150ms cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-checklist__dismiss > span { + transition: color 150ms ease-out; +} +.frm-checklist__dismiss:hover > span { + color: var(--grey-600) !important; +} +.frm-checklist__completed { + height: 100%; +} +.frm-checklist__completed p { + color: var(--grey-800); + margin: 0; +} +.frm-checklist__step-status { + height: 16px; + width: 16px; + border-radius: 50%; + border: 1.5px dashed var(--grey-400); +} +.frm-checklist__step-description { + background-color: var(--grey-50); + border-radius: var(--small-radius); + line-height: var(--leading); + display: none; +} +.frm-checklist__step--active .frm-checklist__step-title, +.frm-checklist__step--active .frm-checklist__step-title a { + font-weight: 600; + color: var(--grey-800); +} +.frm-checklist__step--active .frm-checklist__step-description { + display: block; +} +.frm-checklist__step--completed .frm-checklist__step-status { + background-color: var(--success-500); + border-style: solid; + border-color: var(--success-500); +} +.frm-checklist--collapsed { + height: auto; +} +.frm-checklist--collapsed .frm-checklist__steps { + display: none; +} +.frm-checklist--collapsed .frm-checklist__dismiss { + height: 0; + overflow: hidden; +} +.frm-checklist--collapsed .frm-checklist__header .frmsvg { + transform: rotate(-180deg); +} + +.frm-spotlight { + --fadeout-time: 25ms; + position: fixed; + cursor: default; +} +.frm-spotlight[data-placement=right] { + transform: translateY(-50%); +} +.frm-spotlight[data-placement=bottom] { + transform: translateX(-50%); +} +.frm-spotlight > * { + flex: 0 0 auto; +} +.frm-spotlight__content { + position: relative; + box-sizing: border-box; + flex-shrink: 0; + width: 242px; + border: 1px solid var(--grey-200); + overflow: visible; +} +.frm-spotlight__content::after { + content: ""; + position: absolute; + width: 11px; + height: 11px; + background-color: inherit; + transform: translateY(-50%) rotate(45deg); + border-left: 1px solid var(--grey-200); + border-radius: 2px; +} +.frm-spotlight[data-placement=right] .frm-spotlight__content::after { + top: 50%; + left: -6px; + transform: translateY(-50%) rotate(45deg); + border-bottom: 1px solid var(--grey-200); +} +.frm-spotlight[data-placement=bottom] .frm-spotlight__content::after { + top: -6px; + left: 50%; + transform: translateX(-50%) rotate(45deg); + border-top: 1px solid var(--grey-200); +} +.frm-spotlight__pointer { + box-sizing: border-box; + width: 14px; + height: 14px; + background-color: var(--grey-600); + padding: 3px; + border-radius: 50%; +} +.frm-spotlight[data-placement=right] .frm-spotlight__pointer { + margin-right: var(--gap-2xs); +} +.frm-spotlight[data-placement=bottom] .frm-spotlight__pointer { + margin-bottom: var(--gap-2xs); +} + +.frm-welcome-tour .frm-checklist { + position: fixed; + right: var(--gap-md); + bottom: var(--gap-sm); + z-index: 9999; +} + +/*# sourceMappingURL=welcome-tour.css.map*/ \ No newline at end of file diff --git a/css/font_icons.css b/css/font_icons.css index 0a2a2f899a..b567c55fa0 100644 --- a/css/font_icons.css +++ b/css/font_icons.css @@ -1 +1,88 @@ -@font-face{font-family:"s11-fp";src:url("../fonts/s11-fp.woff?v=7") format("woff");font-weight:400;font-style:normal}.frm-submenu-highlight{background:#1da867}.frm-submenu-highlight a span{color:#fff;font-weight:600}.frmfont,.frm_icon_font{text-decoration:none;text-shadow:none;font-weight:400;display:inline-block;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:auto;line-height:1.5;transition:color .1s ease-in-out,opacity .1s ease-in-out;font-size:18px}i.frmfont,i.frm_icon_font{font-style:normal;font-variant:normal;speak:none}.frmfont::before,select.frmfont,.frm_icon_font::before,select.frm_icon_font{font-family:"s11-fp" !important;text-align:center}.frmfont,a.frmfont,.frmfont:hover,a.frmfont:hover .frm_icon_font,a.frm_icon_font,.frm_icon_font:hover,a.frm_icon_font:hover{text-decoration:none !important;box-shadow:none}.frmfont:focus,.frm_icon_font:focus{box-shadow:none}.frmfont:active,.frm_icon_font:active{outline:none}.frm_trigger .frm_icon_font{padding:0 5px}.frm_tooltip_icon::before{content:"\e611"}.frm_delete_icon::before{content:"\e610" !important}.frm_arrowdown6_icon::before{content:"\e62a"} +/*!****************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/font_icons.scss ***! + \****************************************************************************************************************************************************************************************************************************/ +/** + * Font Icons + */ +@font-face { + font-family: "s11-fp"; + src: url("../fonts/s11-fp.woff?v=7") format("woff"); + font-weight: 400; + font-style: normal; +} +.frm-submenu-highlight { + background: #1da867; +} + +.frm-submenu-highlight a span { + color: #fff; + font-weight: 600; +} + +.frmfont, +.frm_icon_font { + text-decoration: none; + text-shadow: none; + font-weight: 400; + display: inline-block; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + text-rendering: auto; + line-height: 1.5; + transition: color 0.1s ease-in-out, opacity 0.1s ease-in-out; + font-size: 18px; +} + +i.frmfont, +i.frm_icon_font { + font-style: normal; + font-variant: normal; + speak: none; +} + +.frmfont::before, +select.frmfont, +.frm_icon_font::before, +select.frm_icon_font { + font-family: "s11-fp" !important; + text-align: center; +} + +.frmfont, +a.frmfont, +.frmfont:hover, +a.frmfont:hover .frm_icon_font, +a.frm_icon_font, +.frm_icon_font:hover, +a.frm_icon_font:hover { + text-decoration: none !important; + box-shadow: none; +} + +.frmfont:focus, +.frm_icon_font:focus { + box-shadow: none; +} + +.frmfont:active, +.frm_icon_font:active { + outline: none; +} + +.frm_trigger .frm_icon_font { + padding: 0 5px; +} + +.frm_tooltip_icon::before { + content: "\e611"; +} + +.frm_delete_icon::before { + content: "\e610" !important; +} + +.frm_arrowdown6_icon::before { + content: "\e62a"; +} + +/*# sourceMappingURL=font_icons.css.map*/ \ No newline at end of file diff --git a/css/frm_admin.css b/css/frm_admin.css index 5e6551eaf3..b62f9367d2 100644 --- a/css/frm_admin.css +++ b/css/frm_admin.css @@ -1,3 +1,11945 @@ -@font-face{font-family:"s11-fp";src:url("../fonts/s11-fp.woff?v=7") format("woff");font-weight:400;font-style:normal}.frm-submenu-highlight{background:#1da867}.frm-submenu-highlight a span{color:#fff;font-weight:600}.frmfont,.frm_icon_font{text-decoration:none;text-shadow:none;font-weight:400;display:inline-block;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:auto;line-height:1.5;transition:color .1s ease-in-out,opacity .1s ease-in-out;font-size:18px}i.frmfont,i.frm_icon_font{font-style:normal;font-variant:normal;speak:none}.frmfont::before,select.frmfont,.frm_icon_font::before,select.frm_icon_font{font-family:"s11-fp" !important;text-align:center}.frmfont,a.frmfont,.frmfont:hover,a.frmfont:hover .frm_icon_font,a.frm_icon_font,.frm_icon_font:hover,a.frm_icon_font:hover{text-decoration:none !important;box-shadow:none}.frmfont:focus,.frm_icon_font:focus{box-shadow:none}.frmfont:active,.frm_icon_font:active{outline:none}.frm_trigger .frm_icon_font{padding:0 5px}.frm_tooltip_icon::before{content:"\e611"}.frm_delete_icon::before{content:"\e610" !important}.frm_arrowdown6_icon::before{content:"\e62a"}:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}@font-face{font-family:"Inter";src:url("../fonts/Inter-VariableFont_slnt,wght.ttf?v=1") format("truetype")}.with_frm_style,.frm-white-body .wpbody-content,.frm_wrap{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif}@media not all and (min-resolution: 0.001dpcm){@supports(-webkit-appearance: none) and (stroke-color: transparent){.with_frm_style,.frm-white-body .wpbody-content,.frm_wrap{-webkit-font-smoothing:antialiased}}}.frm-sm-z-index{z-index:1}.frm-md-z-index{z-index:5}.frm-white-body,.frm-white-body p,.frm_wrap,.frm_wrap p,.frm-modal,.frm-white-body .postbox .inside{font-size:var(--text-sm);color:var(--grey-500);line-height:var(--leading)}.frm-white-body p,.frm_wrap p{margin:var(--gap-sm) 0}body:not(.frm-admin-page-styles):not(.frm-admin-page-style) .with_frm_style .frm_form_fields>fieldset{--fieldset-padding: 15px 0}a,.widget .widget-top,.stuffbox h3,.frm-collapsed{cursor:pointer;text-decoration:none}.post-type-frm_display .wrap>#posts-filter,.wrap.frm-with-margin,.frm_wrap>.wrap{margin:var(--gap-sm) var(--gap-md) var(--gap-md)}#frm_top_bar+.wrap{margin:var(--gap-xl)}.frm-full-screen #wpbody-content>.wrap{margin:0}.post-type-frm_display .wrap{margin:0}.toplevel_page_formidable #post-body-content{overflow-x:visible}.frm-full-screen{height:100%;overflow:hidden}.frm-full-screen.frm-admin-page-reports,.frm-full-screen.frm-admin-page-entries,.frm-full-screen.post-type-frm_display{overflow:auto}.frm-full-screen #wpadminbar,.frm-full-screen #adminmenumain,.frm-full-screen .wp-header-end{display:none}body.frm-white-body:not(.frm-full-screen) .mce-fullscreen{top:32px;left:160px}.frm-full-screen #wpbody-content,.frm-full-screen #wpbody,.frm-full-screen #wpcontent{padding:0;overflow:hidden;margin:0 !important}.frm-white-body #wpbody-content{position:relative;padding-bottom:0}.post-new-php.post-type-frm_display #screen-meta-links,.post-php.post-type-frm_display #screen-meta-links{display:none}.frm-white-body #screen-meta-links{position:fixed;bottom:0;right:20px}.frm-full-screen #screen-meta-links .screen-meta-toggle{right:55px}.frm-white-body #screen-meta-links .show-settings{border-radius:var(--small-radius) var(--small-radius) 0 0;border:1px solid var(--grey-300);border-bottom:none}.frm-white-body.frm-lite #screen-meta-links .screen-meta-toggle{right:125px}.frm-white-body #screen-meta{margin:0}.frm-white-body #screen-meta-links .show-settings::after{color:var(--grey)}.frm-white-body .columns-2{border-bottom:1px solid var(--grey-300)}.frm-full-screen .columns-2{border:none}body.post-type-frm_display.edit-php,body.frm-white-body{background:#fff}body.frm-white-body ul#adminmenu a.wp-has-current-submenu::after,body.frm-white-body ul#adminmenu>li.current>a.current::after{border-right-color:#fff}.frm-white-body #wpcontent{padding-left:0;padding-right:0}.frm-white-body .wrap #post-body{padding:0 20px}.frm-grey-body #wpbody{background:var(--grey-100)}.frm-grey-body #frm_top_bar{background:#fff}.post-type-frm_display .tablenav,.frm_wrap .tablenav{margin-bottom:10px}.frm-white-body .tablenav .actions select,.wp-admin .frm_wrap .tablenav select{margin-right:var(--gap-xs)}.tablenav .actions .button{margin-top:1px}.frm-white-body table.widefat{background:var(--lightest-grey);border-width:0;box-shadow:none;margin:20px 0}.frm-white-body table.widefat tfoot,.frm-white-body table.widefat thead{background:#fff}.frm-white-body table.widefat th{font-size:var(--text-md)}.frm-white-body table.widefat th a{color:var(--grey-700)}.frm-white-body table.widefat strong a{color:var(--primary-700)}.frm-scroll-box{clear:both;overflow:auto;max-height:405px;border:1px solid var(--grey-300);border-radius:var(--small-radius)}.frm_form_field.frm_scroll_box .frm_opt_container{height:100px;overflow:auto;border:1px solid var(--grey-300)}.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden)+p,.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden)+div,.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden)+span{grid-column:span 6/span 6;align-content:center}.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden)+p,.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden)+div,.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden)+span{grid-column:span 12/span 12 !important;align-content:center}.frm_form_field.frm-phone-type~[id*=frm-field-format-custom-]>label,.frm_form_field.frm-format-dropdown~[id*=frm-field-format-custom-]>label{opacity:0}.frm_form_field.frm-format-dropdown~[id*=frm-field-format-custom-]{grid-column:span 6/span 6}.frm-single-settings.frm-type-textarea>.frm_grid_container [id*=frm-field-format-custom-]+p{grid-column:span 12/span 12}.frm-single-settings .frm_grid_container{column-gap:var(--gap-sm)}.frm-content-center{align-content:center}.frm-self-end{align-self:end}.frm-short-list{overflow:auto;max-height:190px}.frm-white-body table.frm-border td{font-size:var(--text-sm)}.frm-white-body .striped>tbody>:nth-child(odd){background-color:#fff}.frm_wrap td.column-title strong{display:inline}#frm_top_bar{display:flex;gap:var(--gap-sm);width:100%;height:72px;margin:0;box-sizing:border-box;text-align:center;padding:0 var(--gap-md)}#frm_top_bar>.frm-full-close:last-child,#frm_top_bar>#frm-publishing:last-child{margin-left:auto}#frm_top_bar{border-bottom:1px solid var(--grey-300);padding:0 var(--gap-md);overflow:visible}.frm-white-body h1,.frm-white-body h2,.frm-white-body h3,.frm-white-body h4{color:var(--grey-900);font-weight:400;line-height:var(--leading) !important}.frm-white-body .wrap h1,.frm-white-body h1{font-size:var(--text-xl)}.frm-white-body .wrap h2,.frm-white-body h2{font-size:var(--text-lg);font-weight:500}.frm-white-body .wrap h3,.frm-white-body h3{font-size:var(--text-md)}.frm-white-body .wrap h4,.frm-white-body h4{font-size:var(--text-sm);font-weight:500}#frm_error_modal .frm_lock_simple{padding:20px;border-radius:50%;background-color:var(--primary-25);display:inline-block}#frm_error_modal #frm_lock_simple{color:var(--primary-500)}#frm_error_modal .frm-modal-title{display:block}#frm_error_modal .frm-modal-title h2{font-weight:600;font-size:var(--text-xl);margin:0}#frm_error_modal .frm_modal_content{padding:var(--gap-md);color:var(--grey-900)}.frm-views-editor-body .frm_page_container #frm_top_bar h1{padding:0 !important;color:var(--grey-900);font-size:var(--text-xl) !important}.post-type-frm_display .frm_top_left{padding-bottom:0 !important}.frm-new-table-view-option.frm-selected-table-view-option{border-radius:var(--small-radius);background:var(--primary-25)}.frm-views-editor-body #frm_adv_info .tabs-panel{padding-left:4px;padding-right:4px}#frm_edit_box_content_modal .frm_modal_footer{padding-top:var(--gap-sm);border-top:1px solid var(--grey-300)}#frm_edit_box_content_modal .frm_modal_footer>div{display:flex;justify-content:space-between}#frm_edit_box_content_modal #frm_modal_box_select_area,#frm_edit_box_content_modal #frm_box_content_wysiwyg_wrapper,#frm_edit_box_content_modal .frm_modal_content{max-height:calc(100vh - 176px) !important}#frm_edit_box_content_modal #frm_modal_box_select_area{height:calc(100vh - 176px) !important}#frm_edit_box_content_modal #wp-content-editor-tools{padding-top:0}#frm_edit_box_content_modal.frm-modal .postbox .frm-modal-title+div:last-child{right:var(--gap-md)}.frm_code_list.frm-full-hover .frm-dropdown-view a{flex-direction:row-reverse}#frm_view_editor_left.frm-right-panel .accordion-section-title::before{content:"" !important;margin:0}.frm-gradient,.frm-upgrade-bar{background:linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important;color:#fff !important;border:0 !important}.frm-gradient.frm-button-primary:not([disabled]),.frm-gradient.frm-button-primary:not([disabled]):hover,.frm-gradient.frm-button-primary:not([disabled]):focus{background:linear-gradient(90deg, #1961d5, #816cfa) !important}.frm-upgrade-bar,.frm-gradient{position:relative}.frm-upgrade-bar::before,.frm-gradient::before{content:"";display:none;position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgba(255,255,255,.1);z-index:0}.frm-upgrade-bar:hover::before,.frm-gradient:hover::before,.frm-gradient:focus::before{display:block}.frm-upgrade-bar-inner,.frm-gradient>*{position:relative;z-index:1}.frm-upgrade-bar{border-bottom:1px solid var(--sidebar-hover);padding:9px 0;font-size:12px;text-align:center}.frm-upgrade-bar a{color:currentColor !important;text-decoration:underline}.frm-upgrade-bar a:focus{outline:1px dotted var(--sidebar-hover)}.frm-upgrade-bar span{opacity:.9}a h1 .frmsvg{color:var(--grey-400);vertical-align:middle;min-width:var(--text-sm)}a .frmsvg{color:currentColor}.frm_wrap .view-switch a.current::before,.frm-white-body a,.frm_wrap a,.frm_wrap a i{color:var(--primary-color)}.frm_wrap a:active,.frm_wrap a:hover{color:var(--primary-700);box-shadow:none}.post-type-frm_display a:focus,.frm_wrap a:focus{box-shadow:none}.frm_top_left{text-align:left;float:left;white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis;align-self:center}.post-type-frm_display .frm_top_left,.frm_top_left.frm_top_wide{max-width:100%}.post-type-frm_display .frm_nav_bar .frm-header-logo,.frm_nav_bar .frm-header-logo{margin:18px 0 10px}#frm_top_bar .frm_form_nav{flex:1}ul.frm_form_nav{margin:0 auto;padding-top:18px;display:block;min-width:240px}.nav-tab-wrapper.frm_form_nav{padding:0 25px}ul.frm_form_nav>li{margin:0 min(3.5%,32px) 0 0;display:inline-block}.post-type-frm_display #advanced-sortables h2.hndle,.post-type-frm_display #side-sortables h2.hndle,.post-type-frm_display #normal-sortables h2.hndle,.post-type-frm_display .frm_form_nav .nav-tab-active,.frm_form_nav>li>a{font-size:1.3em;text-decoration:none;display:block;padding:6px 2px 4px;font-weight:500;color:var(--grey-700);border-bottom:2px solid rgba(0,0,0,0)}.post-type-frm_display.js .postbox .handlediv .toggle-indicator::before{margin-top:10px}.frm-nav-tabs a:focus,.frm-nav-tabs a:active,.frm_form_nav a:active,.frm_form_nav a:focus{outline:none;box-shadow:none}.frm_form_nav>li>a{font-size:var(--text-md);font-weight:400;color:var(--grey-500)}.frm_form_nav>li>a:hover{border-color:var(--primary-700)}.frm_form_nav .frm-dropdown-menu a:hover{background-color:#eaf2fa}.post-type-frm_display .frm_form_nav .nav-tab-active,.post-type-frm_display .frm_form_nav .nav-tab-active:hover,.frm_form_nav>li a.current_page{color:var(--primary-500);border-color:var(--primary-500);background:rgba(0,0,0,0);opacity:1;font-weight:600}.frm-full-close{display:none;padding-left:var(--gap-md);border:0 solid var(--grey-300);border-left-width:1px;height:100%;box-sizing:border-box}.frm-full-screen .frm-full-close{display:flex;align-items:center}.frm-full-close a{display:block}.frm-full-close .frmsvg{font-size:20px;width:20px;height:20px;color:var(--grey-500)}#frm_top_bar h1{font-weight:400;padding:0;margin:0;color:var(--grey-900);display:inline-flex;gap:var(--gap-sm);align-items:center;text-align:left;min-width:200px}#frm_top_bar h1 span{max-width:175px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:inline-block;vertical-align:bottom}#frm_top_bar ul.frm_form_nav,#frm_top_bar .frm-header-logo,#frm_top_bar #frm_bs_dropdown{align-self:center;margin-top:0;margin-bottom:0;padding-top:0}#frm_top_bar .frm-header-logo{display:flex}#frm_top_bar h2{float:left;margin:0 0 0 var(--gap-sm);padding:2px 0 2px var(--gap-sm);font-weight:400;border-left:2px solid var(--grey)}.frm_wrap>#frm_top_bar #frm-publishing{margin-top:0}#frm-publishing{min-width:225px;align-self:center;align-items:center;display:flex;flex-direction:row-reverse;gap:0 var(--gap-sm);flex-wrap:wrap}.frm_wrap .postbox{border-color:var(--grey-300);border-radius:6px;box-shadow:none}.frm_wrap .postbox h3.hndle{cursor:default;padding:10px 20px;margin:0;line-height:1.4em;border-color:var(--grey-300)}.frm-pre-hndle{font-size:15px;padding:5px;margin:9px 15px}.frm-empty-row{display:none}.frm-child-row{box-shadow:5px 0 0 0 inset var(--sidebar-hover)}.frm_animate_bg{transition:background 200ms linear,color 200ms linear}.wrap>.subsubsub{clear:both;margin:0}.frm_wrap .subsubsub a{line-height:var(--leading);font-size:var(--text-sm)}.frm-admin-page-styles .frm_page_container,.frm_wrap .frm_page_container{height:calc(100vh - 32px);display:flex;flex-direction:column;overflow:hidden;padding-top:0;position:fixed;top:32px;bottom:0;left:0;right:0}.frm-admin-page-translate .frm_wrap .frm_page_container,.frm-admin-page-update_translations .frm_wrap .frm_page_container{position:static}.auto-fold.frm-admin-page-styles .frm_page_container,.auto-fold .frm_wrap .frm_page_container,.frm-unfold.frm-admin-page-styles .frm_page_container,.frm-unfold .frm_wrap .frm_page_container{left:160px}.folded.frm-admin-page-styles .frm_page_container,.folded .frm_wrap .frm_page_container{left:38px}.frm-full-screen.frm-admin-page-styles .frm_page_container,.frm-full-screen .frm_wrap .frm_page_container{height:100vh;top:0;left:0}.frm-full-screen.frm-admin-page-entries .frm_page_container,.frm-new-entry .frm_page_container,.frm-admin-page-reports .frm_page_container,.frm_list_entry_page .frm_page_container{height:auto;display:block}.frm-new-entry .columns-2{border:none}.frm-white-body #frm_top_bar,.frm-white-body .columns-2{flex:0 0 auto}.columns-2 .frm-right-panel+div{padding-bottom:var(--gap-md);border-left:1px solid var(--grey-300)}.columns-2 .frm-right-panel+div,.frm_wrap #post-body-content{padding-bottom:0;padding-top:var(--gap-sm);margin-bottom:0;background:#fff;width:auto;float:none;flex:2}.frm-white-body .columns-2{flex:1;display:flex;overflow:hidden}.frm-white-body .columns-2>div{overflow-y:auto;box-sizing:border-box}.frm_wrap .columns-2 .frm-right-panel,.frm-right-panel{flex:0 0 var(--biggest-sidebar);float:none;width:var(--biggest-sidebar);min-width:var(--biggest-sidebar);background-color:var(--sidebar-color);margin:0;box-shadow:none;border:none;padding-bottom:25px}.frm-right-panel .frm_field_list,.frm_wrap .frm-right-panel #frm_adv_info,.frm_wrap #postbox-container-1 #frm_adv_info{box-shadow:none;border:none;margin-bottom:26px}#new_fields,.frm-has-modal,p.frm_has_shortcodes{position:relative}.frm-inline-modal.postbox{background:#fff;border-color:var(--grey-100);border-radius:var(--small-radius);box-shadow:var(--box-shadow-lg)}.frm_has_shortcodes .frmsvg:not(.frm_help .frmsvg),.frm_has_shortcodes i:not([class*=mce-]){position:absolute;color:var(--primary-500);border-radius:50%;border:1px solid rgba(0,0,0,0);z-index:100;text-align:center}.frm_has_shortcodes .frmsvg.frm-show-box{border-radius:6px !important}.frm_has_shortcodes input,.frm_has_shortcodes textarea{padding-left:18px;box-sizing:border-box}#form_settings_page #frm_adv_info,#frm_builder_page #frm_adv_info{display:none;top:0;width:310px;max-height:315px;min-height:200px;overflow-y:scroll;z-index:100}#form_global_settings .columns-2>div{overflow:auto;height:calc(100vh - 32px)}#form_global_settings .columns-2 .frm-right-panel,#form_settings_page .columns-2 .frm-right-panel,#wpbody-content .frm-page-skeleton .frm-right-panel{flex:0 0 var(--small-sidebar);width:var(--small-sidebar);min-width:var(--small-sidebar)}#form_global_settings .frm_grid_container{gap:0 var(--gap-md)}.frm-inner-content{padding:var(--gap-md)}.post-type-frm_display #poststuff{padding:0 0 10px 40px}#postbox-container-2 .postbox .inside{padding:15px 25px}#postbox-container-2 #frm_advanced .inside h3{margin:15px -25px;font-weight:600}#form_settings_page .frm-inner-content{padding-top:0;padding-bottom:150px;position:relative}.frm_wrap #submitdiv{margin-bottom:0;border-width:0 0 1px;width:100%;min-width:unset}.frm_wrap #frm_adv_info .handlediv,.frm_wrap #frm_adv_info .hndle{display:none}.frm_wrap .menu-settings{border:none;margin-top:0}.nodrag a{cursor:pointer}.frm_wrap #frm_adv_info .inside{margin:0}#frm_adv_info>.inside{padding:0}#frm_adv_info ul.subsubsub{padding-bottom:var(--gap-xs) !important}#frm_adv_info ul.subsubsub a{font-weight:500}#frm_adv_info ul.subsubsub .frm-vertical-separator{display:inline-block;width:1px;height:8px;background-color:var(--grey-300)}#frm_adv_info #frm-insert-condition{background-color:var(--primary-50)}#frm_adv_info #frm-insert-condition:hover{background-color:var(--primary-25)}#frm_builder_page #frm_adv_info{width:322px;max-height:356px;border-radius:var(--small-radius);overflow:hidden}#frm_builder_page #frm_adv_info #taxonomy-linkcategory{height:356px;overflow:hidden}#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div{max-height:286px;padding:0}#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div>*{padding-bottom:var(--gap-sm);max-height:unset}#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div>*:last-child{padding-bottom:var(--gap-xs)}#frm_builder_page #frm_adv_info #frm-nav-tabs{display:flex;gap:var(--gap-xs);background-color:var(--grey-100);border-radius:var(--small-radius);border:0;padding:var(--gap-xs);margin:var(--gap-xs) var(--gap-2xs) var(--gap-sm)}#frm_builder_page #frm_adv_info #frm-nav-tabs>li{flex:1;text-align:center}#frm_builder_page #frm_adv_info #frm-nav-tabs>li a{font-weight:500;line-height:1;color:var(--grey-500);border-radius:var(--small-radius);border:0;padding:var(--gap-xs);margin:0}#frm_builder_page #frm_adv_info #frm-nav-tabs>li a:hover{background-color:#eaecf0;color:var(--grey-500) !important;box-shadow:var(--box-shadow-sm)}#frm_builder_page #frm_adv_info #frm-nav-tabs>li.frm-tabs a{background-color:#fff;color:var(--grey-900) !important;box-shadow:var(--box-shadow-sm)}#frm_builder_page #frm_adv_info .frm-search,#frm_builder_page #frm_adv_info .frm-with-search{padding-top:0;margin:0}.frm-right-panel .frm-inline-modal.postbox .inside{margin:0;padding:0 14px 14px}.frm-right-panel .frm-inline-modal.postbox .inside .frm-with-line,.frm-right-panel .frm-inline-modal.postbox .inside .accordion-section-content h4{margin-left:-14px;margin-right:-14px}.frm-right-panel .frm-inline-modal .inside p:not(.howto),.frm-right-panel .frm-inline-modal .inside a{font-size:15px}.frm-inline-modal .inside a.frm_icon_font{font-size:18px}.frm-nav-tabs{margin:10px 0 20px;padding:0 var(--gap-sm);display:block;border-bottom:1px solid var(--grey-300)}#frm-nav-tabs{position:-webkit-sticky;position:sticky;top:0;background-color:var(--sidebar-color);z-index:98;margin-top:0;padding-top:5px}.frm_form_settings #frm_adv_info #frm-nav-tabs{background-color:#fff;margin:0 -4px}.frm_form_settings span.frm-with-right-icon,#frm_builder_page .frm_has_shortcodes span.frm-with-right-icon:not(.frm_hidden){display:block}.frm-inline-modal .frm-nav-tabs,#frm_adv_info .frm-nav-tabs{margin:5px 0 0}#frm_adv_info .frm-nav-tabs.frm-compact-nav{padding-right:0;padding-left:20px}.frm-nav-tabs li{display:inline-block;margin:0}.frm-nav-tabs a{color:var(--grey-700);padding:10px 1px;margin:0 9px;border-bottom:2px solid rgba(0,0,0,0)}.frm_form_settings #frm_adv_info .frm-nav-tabs a{padding:5px 1px;color:var(--grey-500)}.frm-nav-tabs.frm-compact-nav a{margin:0 5px}.frm-nav-tabs a{display:block;opacity:.9}#frm_adv_info .frm-nav-tabs a{color:var(--grey-700)}.frm-nav-tabs a:hover,.frm-nav-tabs .frm-tabs a{color:var(--primary-500) !important;border-color:var(--primary-500)}.frm_form_settings #frm_adv_info .frm-nav-tabs .frm-tabs a{font-weight:500}.frm-payments-tabs{margin-bottom:var(--gap-md);display:flex}.frm-payments-tabs .frm-payments-tab{font-weight:600;font-size:14px;color:var(--grey-900);display:inline-block;border-width:1px;border-style:solid;border-color:#eaecf0;padding:8px 12px;border-radius:6px 6px 0 0;background-color:#f9fafb}.frm-payments-tabs .frm-payments-tab-filler{border-bottom:1px solid #eaecf0;min-width:var(--gap-xs)}.frm-payments-tabs .frm-payments-tab-filler:last-child{flex:1}.frm-payments-tab.frm-active{background-color:#fff;border-bottom:none}.frm-payments-tab a{text-decoration:none;color:var(--grey-900)}#frm-bulk-modal .howto,#frm-bulk-modal h3{font-size:var(--text-sm);font-weight:400;margin:5px 0 10px;color:var(--grey)}#frm-bulk-modal h3{margin-left:20px}.frm-right-panel a.frm_add_logic_link,.frm-right-panel h3{color:var(--grey-700);font-size:var(--text-lg);font-weight:400;margin:0}.frm-right-panel h3 i{color:var(--grey-700);float:right;width:16px;cursor:pointer}.frm-settings-panel{padding:var(--gap-sm);padding-right:var(--gap-xs)}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-delimiter{top:var(--gap-xs);left:var(--gap-xs);width:calc(100% - var(--gap-sm))}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-navs{padding:var(--gap-xs) var(--gap-xs) 0}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track>div{max-height:0;visibility:hidden}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track>div.frm-active{max-height:unset;visibility:visible}.frm-settings-panel .frm-embed-field-placeholder{height:unset}.frm-settings-panel .frm-embed-field-placeholder img{height:100px}.frm-settings-panel .frm-embed-field-placeholder .frm-embed-message{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--gap-sm);max-width:unset;color:var(--grey-800);padding:var(--gap-lg);border:0;box-shadow:var(--box-shadow-sm);margin:1px}.frm-single-settings .frm-default-value-wrapper>p{margin-bottom:0}.frm-single-settings .frm-default-value-wrapper+p:empty{display:none}.frm-single-settings [class*=frm-lookup-box-] .frm_grid_container p{margin-top:0 !important}.frm-single-settings .frm_single_option[id^=frm_watch_lookup_]{margin-bottom:var(--gap-xs) !important}.frm-single-settings>h3:first-of-type{position:relative;background-color:rgba(0,0,0,0) !important;border-top:none;padding-top:0 !important;margin-top:0 !important}.frm-single-settings>h3:first-of-type::after{content:"";position:absolute;left:var(--gap-sm);right:var(--gap-sm);bottom:0;height:1px;background-color:var(--sidebar-hover)}.frm-flex-justify,.frm-right-panel .frm-single-settings h3{display:flex;justify-content:space-between;align-items:center}#post-body-content+.frm-right-panel{flex:0 0 var(--medium-sidebar);width:var(--medium-sidebar);min-width:var(--medium-sidebar);border-left:1px solid var(--sidebar-hover)}.frm-new-entry #post-body-content+.frm-right-panel,.frm-new-entry .frm-right-panel{background:none;border:none}#post-body-content+.frm-right-panel h3{padding:20px 20px 0;font-size:17px}#post-body-content+.frm-right-panel .frm_with_icons:first-of-type h3{border:none}#frm-insert-fields h3{color:var(--grey);font-size:15px;font-weight:400;border-top:none;border-bottom:1px solid var(--sidebar-hover);margin:0;padding:10px 10px 10px 25px}.frm_wrap #frm_adv_info ul.category-tabs{margin:0;padding:10px 0 9px;font-size:15px;background:rgba(0,0,0,0)}.frm_wrap #frm_adv_info ul.category-tabs li{padding:10px;background-color:rgba(0,0,0,0) !important}.frm_wrap #frm_adv_info ul.category-tabs li:first-child{border:none}.frm_wrap #frm_adv_info .categorydiv div.tabs-panel{border:none;background:rgba(0,0,0,0)}.frm_wrap #frm-categorydiv{border-right:none}#frm_adv_info #frm-conditionals{padding-top:var(--gap-sm)}#postbox-container-1 #taxonomy-linkcategory #frm-html-tags{display:none;max-height:none}#postbox-container-1 .frm_field_list #frm-insert-fields .frmbutton.dropdown{position:relative}.frm-white-body #footer-upgrade{display:none}.frm-admin-footer-links,.frm-admin-footer-links-nav,.frm-admin-footer-links-socials{display:flex;justify-content:center}.frm-admin-footer-links{gap:var(--gap-2xs);flex-direction:column;text-align:center;padding:var(--gap-xl) 0 var(--gap-lg);font-size:var(--text-xs);color:var(--grey-400)}body.frm-hidden-overflow{height:100%;overflow:hidden}.frm-admin-footer-links-nav{gap:var(--gap-2xs);margin-bottom:var(--gap-xs)}.frm-admin-footer-links-socials{gap:var(--gap-xs)}.frm-admin-footer-links-socials a{color:var(--grey-400)}.frm_list_entry_page h2{float:left}.frm_list_entry_page h2+.error{clear:both}.frm_sidebar select{width:100%;margin-left:0;margin-right:0}.frm_sidebar #search-submit{float:right}.frm_single_entry_page #submitdiv{margin:0}.frm_single_entry_page .hndle a{font-size:13px}.frm-right-panel #publishing-action{float:none}.frm-right-panel #major-publishing-actions{border-top:none;height:32px;background:rgba(0,0,0,0)}#major-publishing-actions .frm_submit_form{float:right;margin-left:5px}.frm_orange_button,.frm_reverse_button{font-size:12px;border:1px solid var(--orange);color:var(--orange);font-weight:600;padding:1px 4px;border-radius:4px;background:rgba(0,0,0,0)}.frm_reverse_button:hover,.frm_reverse_button:active,.frm_reverse_button:focus{color:#fff;background:var(--orange);border:1px solid var(--orange)}.frm_reverse_button{font-size:1em;transition:all .2s ease}.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.wp-core-ui .button.frm-button-primary,.frm-button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-search .button,.frm-white-body .search-box .button,.frm-white-body .tablenav .button,.frm_orange_button,.toplevel_page_formidable #frm_upgrade_modal .button-primary,.wp-core-ui.frm-white-body .button-primary,.wp-core-ui.frm-white-body .button-secondary,.frm-white-body .button-primary,.frm-white-body .button-secondary,#frm-form-button button,.frm-form-button button,.frm-preview-buttons button,.frm-button-red,.frm-button-tertiary{text-shadow:none;box-shadow:none;border-radius:30px;border:1px solid var(--primary-500);font-size:var(--text-sm);transition:all .2s ease;padding:7px 16px;height:auto;min-height:28px;outline:none;line-height:var(--leading);box-sizing:border-box;font-weight:500;margin-bottom:0;display:inline-block}.frm-button-primary.frm-sharp,.frm-button-secondary.frm-sharp{border-radius:12px !important}#wpcontent .frm-button-secondary.frm-button-gradient{position:relative;border-color:rgba(0,0,0,0) !important;background-clip:padding-box !important}#wpcontent .frm-button-secondary.frm-button-gradient::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;margin:-1px;border-radius:inherit;background:linear-gradient(90deg, #129efd 0%, #a334fd 100%);transition:opacity 150ms ease-out}#wpcontent .frm-button-secondary:hover::before{opacity:.5}.no-js.wp-core-ui .frm-search .button.hide-if-no-js,.js.wp-core-ui .frm-search .button.hide-if-js{display:none}.frm-button-tertiary{border-color:rgba(0,0,0,0);color:var(--primary-500)}.frm-button-tertiary:focus{outline:none}.frm-button-tertiary.frm_loading_button::before{border-right-color:var(--grey);border-bottom-color:var(--grey)}.frm-button-red,.frm-button-red:focus{--primary-color: var(--error-500);--primary-500: var(--error-500);--primary-700: var(--error-700)}.frm-button-red:not(.frm-button-tertiary),.frm-button-red:not(.frm-button-tertiary):focus{color:#fff !important}.frm-white-body h2 .button,.post-type-frm_display h2 .frm-button-primary,.frm-white-body .tablenav .button,.frm-button-primary.frm-button-sm,.frm-button-secondary.frm-button-sm,.frm-button-tertiary.frm-button-sm,.frm-button-red.frm-button-sm{padding:4px 12px !important;font-size:var(--text-xs) !important}.frm_no_style_button{background:rgba(0,0,0,0)}.frm-with-icon{display:flex;gap:var(--gap-xs);align-items:center}.frm-with-icon svg{opacity:.65}.frm-with-icon.button svg{height:var(--text-sm);width:var(--text-sm)}.frm-with-icon.frm-button-sm svg{height:var(--text-xs);width:var(--text-xs)}.frm-white-body .button.add_media{padding-left:12px !important;padding-right:12px !important;font-size:var(--text-xs);border-radius:var(--border-radius)}.wp-core-ui.frm-white-body #post-query-submit.button,.wp-core-ui.frm-white-body .button.tablenav-pages-navspan,.wp-core-ui.frm-white-body .button.first-page,.wp-core-ui.frm-white-body .button.prev-page,.wp-core-ui.frm-white-body .button.next-page,.wp-core-ui.frm-white-body .button.last-page,.wp-core-ui.frm-white-body .button.action{background-color:rgba(0,0,0,0);border-color:var(--grey-300);color:var(--grey-700);border-radius:var(--border-radius)}.post-type-frm_display.wp-core-ui .button-primary,.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.frm_single_entry_page #frm-publishing .button-primary{background-color:var(--primary-500) !important;color:#fff !important}.frm-button-primary.frm_large,.frm-button-secondary.frm_large{height:auto !important;padding:12px 16px !important}.frm-button-secondary.frm-small,.frm-button-primary.frm-small{font-size:var(--text-xs) !important;height:auto !important;padding:var(--gap-2xs) 12px !important}.frm-button-primary i::before{color:#fff}.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover,.frm-button-primary:not([disabled]):hover{background:var(--primary-700) !important;border-color:var(--primary-700) !important}.wp-core-ui .button-primary.frm-button-primary:active{vertical-align:inherit}.frm-white-body #search-submit,#frm-form-button .frm_button_submit,.frm-form-button .frm_button_submit,.frm-white-body .frm-preview-buttons button,.frm-white-body .button:not(.frm-button-primary),.wp-core-ui.frm-white-body .button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-button-secondary,.frm-button-secondary{color:var(--grey-800);border-color:var(--grey-300);background-color:#fff}#wp-content-media-buttons button,#wp-content-media-buttons a.button{border-color:var(--grey-300)}.frm_orange_button{border-color:#da791d !important;background:var(--orange);color:#fff}.frm-white-body .button:not(.frm-button-primary):focus,.frm-white-body .button:not(.frm-button-primary):active,.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:focus,.wp-core-ui.frm-white-body .tablenav .button:hover,.frm_wrap .preview>.button:hover,.frm-white-body #search-submit:hover{border-color:var(--grey-300) !important;color:var(--grey-800);background:var(--grey-50) !important;box-shadow:none !important;outline:none !important}.frm-button-primary .frmsvg{color:#fff}.frm_wrap .preview i{font-size:inherit}.frm-white-body .frm-button-primary:focus,.frm-white-body .frm-button-primary:active,#frm-addons-page .button-primary:focus,#form_global_settings .button-primary:focus,#frm_upgrade_modal .button-primary:focus{border-color:var(--primary-700) !important;background-color:var(--primary-700) !important;box-shadow:none !important;outline:none !important}.frm_wrap .preview>.button:focus,.frm_orange_button:hover,.frm_orange_button:focus,.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover,.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus,.toplevel_page_formidable .frm_wrap button.button-primary:hover,.toplevel_page_formidable .frm_wrap button.button-primary:focus{outline:none}.frm_orange_button:hover,.frm_orange_button:focus{border-color:var(--orange) !important;background:rgba(0,0,0,0);color:var(--orange);opacity:1}.major-publishing-actions.frm_create_form_header{padding:8px 0}.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner{font-size:15px;background:rgba(0,0,0,0)}.frm-menu-boxes .frm_blank_form_text{padding-bottom:26px}input.frm_insert_in_template{font-size:10px;width:98%;font-weight:400}.frm-dismissible a.dismiss:focus{box-shadow:none}.frm-dismissible a.dismiss{top:10px;right:10px;position:absolute}.frm-dismissible a.dismiss svg{color:var(--grey-800)}.frm-btn-unstyled{font:inherit;background:none;border:none;padding:0;cursor:pointer;outline:inherit}.frm-btn-unstyled:hover,.frm-btn-unstyled:focus,.frm-btn-unstyled:active{text-decoration:none;background:none;border:none;box-shadow:none}.frm-btn-unstyled:disabled,.frm-btn-unstyled[disabled]{pointer-events:none;opacity:.65}.wp-admin .frm-review-notice{position:fixed !important;bottom:var(--gap-2xl);right:var(--gap-lg);width:380px;text-align:center;border-color:var(--grey-100);padding:var(--gap-lg);border-radius:var(--medium-radius);box-shadow:var(--box-shadow-lg) !important;z-index:999;box-sizing:border-box;--gap-sm: 16px;--gap-md: 24px;--gap-2xl: 48px}.wp-admin .frm-review-notice *{box-sizing:border-box}.frm-review-notice-icon{display:inline-flex;margin-bottom:var(--gap-sm)}.wp-admin .frm-review-notice-title{font-weight:600;margin-top:0;margin-bottom:var(--gap-xs)}.wp-admin .frm-review-notice-text{margin-top:0;margin-bottom:var(--gap-md)}.frm-review-notice-signature{text-align:left;margin:var(--gap-md) 0}.frm-review-notice-signature img{width:40px;height:40px;padding:3px;box-shadow:var(--box-shadow-md);border-radius:100%}#wpwrap .frm-dismiss-review-notice{top:16px;right:19px}.frm-review-notice #frmapi-feedback [class^=frm__]{display:none}.frm-review-notice #frmapi-feedback input,.frm-review-notice #frmapi-feedback textarea{border-color:var(--grey-300);border-radius:var(--small-radius)}.frm-review-notice #frmapi-feedback input{min-height:unset;max-height:36px}.frm-review-notice #frmapi-feedback textarea{max-height:80px;padding-top:var(--gap-xs)}.frm-review-notice #frmapi-feedback .frm_message{color:var(--success-900);background-color:var(--success-25);border:1px solid var(--success-200);padding:var(--gap-sm) var(--gap-md);margin:0}.frm-review-notice #frmapi-feedback .frm_message p{margin:0}.frm-review-notice #frmapi-feedback .frm_button_submit{background-color:var(--primary-500);border-color:var(--primary-500) !important;cursor:pointer}.frm-review-notice #frmapi-feedback .frm_button_submit:hover,.frm-review-notice #frmapi-feedback .frm_button_submit:focus{color:#fff;background-color:var(--primary-700);border-color:var(--primary-700) !important}.frm-review-notice .frm_error,.frm-review-notice label{color:#444;text-align:left}.frm-review-notice label{font-size:var(--text-sm)}.frm-floating-success-message{position:fixed;z-index:999;border-radius:4px;right:10px;bottom:10px}.frm-box-shadow-xxl{box-shadow:var(--box-shadow-xxl) !important}.frm-text-white{color:#fff !important}.frm-text-primary-500{color:var(--primary-500)}.frm-text-grey-400{color:var(--grey-400) !important}.frm-text-grey-500{color:var(--grey-500) !important}.frm-text-grey-600{color:var(--grey-600) !important}.frm-text-grey-700{color:var(--grey-700)}.frm-text-grey-800{color:var(--grey-800)}.frm-text-grey-900{color:var(--grey-900)}.frm-text-success-500{color:var(--success-500)}.frm-text-warning-500{color:var(--warning-500)}.frm-underline{text-decoration:underline}.frm_no_margin,.frm-m-0{margin:0 !important}.frm-m-12{margin:var(--gap-2xl)}.frm-m-2xs{margin:var(--gap-2xs) !important}.frm_no_top_margin,.frm-mt-0{margin-top:0 !important}.frm-mt-2xs{margin-top:var(--gap-2xs) !important}.-frm-mt-2xs{margin-top:calc(-1*var(--gap-2xs)) !important}.frm-mt-xs{margin-top:var(--gap-xs) !important}.frm-mt-sm{margin-top:var(--gap-sm) !important}.frm-mt-md{margin-top:var(--gap-md) !important}.frm-mt-lg{margin-top:var(--gap-lg) !important}.frm-mt-2xl{margin-top:var(--gap-2xl) !important}.frm-mt-auto{margin-top:auto !important}.frm_no_bottom_margin,.frm-mb-0{margin-bottom:0 !important}.frm-mb-2xs{margin-bottom:var(--gap-2xs) !important}.frm-mb-6{margin-bottom:6px !important}.frm-mb-sm{margin-bottom:var(--gap-sm) !important}.frm-mb-12{margin-bottom:12px !important}.frm-mb-xs{margin-bottom:var(--gap-xs) !important}.frm-mb-md{margin-bottom:var(--gap-md) !important}.frm-mb-lg{margin-bottom:var(--gap-lg) !important}.frm-ml-2xs{margin-left:var(--gap-2xs) !important}.frm-ml-xs{margin-left:var(--gap-xs) !important}.frm-ml-auto{margin-left:auto}.-frm-ml-2xs{margin-left:calc(-1*var(--gap-2xs)) !important}.frm-mr-auto{margin-right:auto}.frm-force-mr-auto{margin-right:auto !important}.frm-mr-2xs{margin-right:var(--gap-2xs) !important}.frm-mr-xs{margin-right:var(--gap-xs) !important}.frm-mr-2{margin-right:2px !important}.frm-mx-0{margin-left:0 !important;margin-right:0 !important}.frm-mx-xs{margin-left:var(--gap-xs) !important;margin-right:var(--gap-xs) !important}.frm-mx-sm{margin-left:var(--gap-sm) !important;margin-right:var(--gap-sm) !important}.frm-my-sm{margin-top:var(--gap-sm) !important;margin-bottom:var(--gap-sm) !important}.frm-my-xs{margin-top:var(--gap-xs) !important;margin-bottom:var(--gap-xs) !important}.frm-p-0{padding:0 !important}.frm-p-1,.frm-p-2xs{padding:var(--gap-2xs)}.frm-p-sm,.frm-p-4{padding:var(--gap-sm) !important}.frm-p-xs{padding:var(--gap-xs) !important}.frm-p-sm{padding:var(--gap-sm) !important}.frm-p-6,.frm-p-md{padding:var(--gap-md) !important}.frm-p-xl{padding:var(--gap-xl) !important}.frm-px-0{padding-left:0 !important;padding-right:0 !important}.frm-py-0{padding-top:0 !important;padding-bottom:0 !important}.frm-py-2xs{padding-top:var(--gap-2xs) !important;padding-bottom:var(--gap-2xs) !important}.frm-py-sm{padding-top:var(--gap-sm) !important;padding-bottom:var(--gap-sm) !important}.frm-pt-0{padding-top:0 !important}.frm-pt-2xs{padding-top:var(--gap-2xs) !important}.frm-pt-xs{padding-top:var(--gap-xs) !important}.frm-pt-sm{padding-top:var(--gap-sm) !important}.frm-pt-md{padding-top:var(--gap-md) !important}.frm-pt-xl{padding-top:var(--gap-xl) !important}.frm-pr-lg{padding-right:var(--gap-lg) !important}.frm-pb-md{padding-bottom:var(--gap-md) !important}.frm-pb-sm{padding-bottom:var(--gap-sm) !important}.frm-pb-xs{padding-bottom:var(--gap-xs) !important}.frm-pb-2xs{padding-bottom:var(--gap-2xs) !important}.frm-pb-0{padding-bottom:0 !important}.frm-px-sm{padding-right:var(--gap-sm) !important;padding-left:var(--gap-sm) !important}.frm-px-xs{padding-right:var(--gap-xs) !important;padding-left:var(--gap-xs) !important}.frm-px-md{padding-right:var(--gap-md) !important;padding-left:var(--gap-md) !important}.frm-text-xs{font-size:var(--text-xs) !important}.frm-text-sm{font-size:var(--text-sm) !important}.frm-text-md{font-size:var(--text-md) !important}.frm-text-lg{font-size:var(--text-lg) !important}.frm-text-xl{font-size:var(--text-xl) !important}.frm-leading-none{line-height:1}.frm-italic{font-style:italic}.frm-no-italic{font-style:normal}.frm-capitalize{text-transform:capitalize}.frm-font-normal{font-weight:400 !important}.frm-font-medium{font-weight:500 !important}.frm-font-semibold{font-weight:600 !important}.frm-font-bold{font-weight:700 !important}.frm-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[class*=frm-line-clamp-]{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical}.frm-line-clamp-2{-webkit-line-clamp:2}.frm-white-space-nowrap{white-space:nowrap}.frm-rounded-6{border-radius:6px !important}.frm-rounded-sm{border-radius:var(--small-radius) !important}.frm-rounded-12{border-radius:12px !important}.frm-rounded-md{border-radius:var(--medium-radius) !important}.frm-w-auto{width:auto !important}.frm-w-full{width:100% !important}.frm-w-half{width:50% !important}.frm-w-fit{width:fit-content !important}.frm-max-w-fit{max-width:fit-content}.frm-h-auto{height:auto !important}#wpwrap .frm-force-hidden,.frm-force-hidden{display:none !important}.frm_block,.frm-block{display:block}.frm_inline{display:inline}.frm-force-inline{display:inline !important}.frm_inline_block{display:inline-block !important}.frm-inline-flex,#wpbody-content .frm-inline-flex{display:inline-flex}.frm-flex{display:flex}.frm-force-flex{display:flex !important}.frm_hidden,.js .frm-hide-js{display:none}.frm-flex-box{display:flex;gap:var(--gap-sm)}.frm-flex-col{display:flex;flex-direction:column}.frm-flex-full{flex:1}.frm-force-flex-center,.frm-flex-center{justify-content:center;align-items:center}.frm-flex-center{display:flex}.frm-force-flex-center{display:flex !important}.frm-shrink-0{flex-shrink:0}.frm-gap-0{gap:0 !important}.frm-gap-2xs{gap:var(--gap-2xs)}.frm-gap-xs{gap:var(--gap-xs)}.frm-gap-sm{gap:var(--gap-sm)}.frm-gap-md{gap:var(--gap-md)}.frm-gap-xl{gap:var(--gap-xl)}.frm-justify-start{justify-content:start !important}.frm-justify-center{justify-content:center !important}.frm-justify-between{justify-content:space-between}.frm-justify-end{justify-content:end}.frm-items-start{align-items:flex-start}.frm-items-center{align-items:center}.frm-items-stretch{align-items:stretch}.frm-self-normal{align-self:normal}#wpbody-content .frm-flex-wrap{flex-wrap:wrap}.frm-grow{flex-grow:1}.frm-order-first{order:-9999}.frm-order-last{order:9999}.frm-order-none{order:0}.frm-h-stack-sm,.frm-h-stack-xs,.frm-h-stack{display:flex !important;align-items:center}.frm-h-stack-sm>input[type=checkbox],.frm-h-stack-xs>input[type=checkbox],.frm-h-stack>input[type=checkbox],.frm-h-stack-sm>input[type=radio],.frm-h-stack-xs>input[type=radio],.frm-h-stack>input[type=radio]{margin:0 !important}.frm-h-stack{gap:var(--gap-2xs)}.frm-h-stack-xs{gap:var(--gap-xs)}.frm-h-stack-sm{gap:var(--gap-sm)}.frm-flex-row-reverse{flex-direction:row-reverse}.frm-transition-ease{transition:all .2s ease}.frm_invisible{visibility:hidden;transition:all .2s ease}.frm_disabled{opacity:.5;cursor:default;pointer-events:none}.frm_disabled .frm-show-inline-modal{pointer-events:none !important}.frm_no_float{float:none}.frm-text-right{text-align:right}.frm-text-left{text-align:left}.frm-border-b{border-bottom:1px solid var(--grey-300)}.frm-no-border{border:none !important}.frm-hr{display:block;height:1px;background-color:var(--grey-200);margin:var(--gap-xs) 0}.frm-opacity-100{opacity:1}.frm-on-bottom{z-index:-1}.frm-rotate-90{transform:rotate(90deg)}.frm-cursor-pointer{cursor:pointer}.frm-align-baseline{vertical-align:baseline !important}.frm-fields p>label.frm_hidden,#wpbody-content label.frm_hidden,.frm-lookup-modal .dismiss,.frm-right-panel .inside a.frm_hidden,#form_global_settings .frm_hidden,ul.frm_form_nav>li.frm_hidden,a.frm_hidden,.button.frm_hidden,.wp-core-ui .button.frm_hidden{display:none}.postbox .inside>p.frm_no_bottom_margin:last-child{margin-bottom:0 !important}.frm_no_section_fields.frm_block{display:block}.actions.frm_visible_overflow{overflow:visible !important}.frm_full_opacity,.frm_submit .frm_full_opacity,.frm_submit .frm-opacity-100{opacity:1}.frm-dropdown-menu.frm-on-top{z-index:99999}.frm-vertical-line{display:inline-block;width:1px;height:12px;background-color:var(--grey-300)}.frm-admin-full-screen #adminmenumain,.frm-admin-full-screen #wpadminbar,.frm-admin-full-screen #adminmenuback,.frm-admin-full-screen #adminmenuwrap,.frm-admin-full-screen #wpfooter{display:none}.frm-admin-full-screen #wpcontent,.frm-admin-full-screen.auto-fold #wpcontent{margin:0;padding:0}.frm-admin-full-screen.appearance_page_starter-templates #wpbody-content{padding:0}.frm_forms.with_frm_style{max-width:100%}.post-type-frm_display .wrap>.subsubsub,.post-type-frm_display .wrap>.icl_subsubsub,.frm_form_settings>p{margin:6px var(--gap-md);padding:0}.frm-entry-container{margin:0 40px 40px;padding:0}#form_reports_page .frm-inner-content{width:calc(100% - 40px);max-width:900px;margin:20px auto;padding:20px}.frm_inner_field_container>.frm_form_fields{clear:both}.post-type-frm_display h2,.frm_wrap h2{margin-top:0 !important;font-size:var(--text-lg);line-height:var(--leading)}.post-type-frm_display .wrap>h2:first-child,.frm_wrap .wrap>h2:first-child{padding-top:0;margin-top:0 !important;font-size:var(--text-lg)}#frm_form_editor_container{position:relative;margin-top:28px}.form-field p{background:none;border:none}.form-field label.frm_primary_label{display:block;float:none;width:auto}#frm_view_editor_left label,#frm_view_editor_left .frm_primary_label,.frm-dialog .frm-sub-label,.frm-dialog label,.dropdown .frm_primary_label,.accordion-container label,.frm-fields td>label,.frm-fields td>div>label,.frm_form_field>label:first-child,.frm-fields p>label,.frm_on_submit_type>label,.post-type-frm_display .frm_form_field>label,#new_fields .frm_primary_label,#form_global_settings .frm_primary_label,#frm_form_editor_container .frm_primary_label,#permissions_settings_settings .frm_primary_label{color:var(--grey-700);margin:0 0 6px;padding:0;width:auto;font-size:var(--text-sm);display:block;line-height:var(--leading)}#frm_form_editor_container #frm-show-fields .frm_primary_label{min-height:21px}.frm-fields td input+label{display:inline}#frm_form_editor_container .edit_field_type_end_divider .frm_primary_label,#frm_form_editor_container .edit_field_type_break .frm_primary_label{display:none}form .frm_primary_label input{font-size:12px}.with_frm_style form .form-field{margin-bottom:20px}#frm_builder_page .with_frm_style form .frm_combo_inputs_container>.form-field{margin-bottom:0}.frm_description,.with_frm_style form div.description,.frm_error,.with_frm_style form div.description textarea{padding:0;font-size:11px}.with_frm_style .description{color:inherit}#frm_form_editor_container .divider_section_only .frm_primary_label{display:flex;align-items:center;gap:var(--gap-xs);font-size:20px}#frm_form_editor_container .divider_section_only .frm_primary_label .frm-sub-label{padding:0}#frm-show-fields ul:has(>li:nth-child(7)) .frm-sub-label.frm-field-id{display:none}.frm-token-container{position:relative;display:block;direction:ltr}.frm-token-container .frm-tokens{position:absolute;top:0;left:0;max-width:calc(100% - var(--gap-xl));display:flex;align-items:center;flex-wrap:wrap;gap:var(--gap-2xs);padding:6px var(--gap-xs);margin:0}.frm-token-container .frm-token{position:relative;display:flex;align-items:center;gap:var(--gap-xs);min-height:24px;height:auto;color:var(--grey-900);background:var(--grey-100);border-radius:4px;padding:0 var(--gap-xs);font-size:var(--text-md);margin:0;z-index:2}.frm-token-container .frm-token .frm-token-value{line-height:var(--leading);white-space:normal;word-break:break-word}.frm-token-container .frm-token .frm-token-remove{display:flex;flex-shrink:0;cursor:pointer}.frm-token-container .frm-token .frm-token-remove .frmsvg{color:var(--grey-900);position:static;width:12px;height:12px;padding:0}.frm-token-container .frm-token .frm-token-remove:hover .frmsvg{color:var(--error-500)}.frm-token-container .frm-show-inline-modal{z-index:3 !important}.frm-token-container .frm-token-proxy-input{position:relative;z-index:1;padding-right:var(--gap-xl) !important}form .form-field.frm_field_loading{margin-bottom:0;min-height:0;padding:0;text-align:center}.frm_sorting>.frm_field_loading .frm_visible_spinner.frm-wait{margin-bottom:10px}.frm_sorting>.frm_field_loading~.frm_field_loading .frm_visible_spinner.frm-wait{margin-bottom:0;display:none}.frm_description,.with_frm_style form div.description,.frm_error{margin:0}.frm_error{color:#f04438}form .frm_blank_field input,form .frm_blank_field textarea,form .frm_blank_field select,form .frm_blank_field .frm-g-recaptcha iframe,form .frm_blank_field .g-recaptcha iframe{border-color:#f04438}form .frm_blank_field label{color:#f04438}.frm_required{color:#f04438}.with_frm_style .wp-editor-container textarea,.postbox .wp-editor-container textarea,.frm_remove_border{border:none}.with_frm_style .mceIframeContainer,.postbox .mceIframeContainer{background-color:#fff}.frm_pro_license_msg{clear:left;margin-top:10px}.frm-license-input{position:relative}.frm-license-input span{font-size:var(--text-sm)}.frm-license-input .frmsvg{width:20px;height:20px;margin-left:5px;vertical-align:text-top}.frm-license-input .frmsvg,.frm-license-input span,.frm-license-input i{color:#00831a}.upgrade_to_pro{padding:10px 25px 25px;max-width:700px;margin:20px auto !important}.upgrade_to_pro .error{display:none}.toplevel_page_formidable #wpbody-content>.error{margin:1px;padding:5px 12px}.frm_error_style,.frm_warning_style,.frm_note_style2,.frm_note_style,.frm_message,#post-body-content .frm_updated_message,div.frm_updated_message{border-radius:var(--small-radius);background-color:#d5f2dc;color:#1e561f;padding:var(--gap-sm) var(--gap-md);font-size:var(--text-sm);margin:var(--gap-sm) 0;text-align:left}.frm_note_style2{background:linear-gradient(90deg, #e9effa, #fcf6fe) padding-box,linear-gradient(90deg, #1961d5, #e8abef) border-box;border:1px solid rgba(0,0,0,0)}#frm_top_bar+.wrap>.frm_updated_message,#frm_top_bar+.wrap>.frm_warning_style{display:inline-block;width:100%;box-sizing:border-box}#post-body-content>.frm_updated_message{margin:5px 65px}#form_global_settings #post-body-content>.frm_updated_message,#form_global_settings #post-body-content>.frm_warning_style{margin:5px 25px}.frm_error_style{color:#973937;background-color:#ebcccc;clear:both}.frm_error_style a{text-decoration:underline;font-weight:600}.frm_error_style svg{opacity:.7}.frm_warning_style{color:#7a4d05;background-color:#fff2d2}.frm_warning_heading{font-weight:700;margin-bottom:4px}.frm_warning_style{position:relative;padding-right:calc(var(--gap-md) + 15px)}body.rtl .frm_warning_style{padding-right:var(--gap-md);padding-left:calc(var(--gap-md) + 15px)}.frm-warning-dismiss{position:absolute;top:10px;right:10px;display:flex;cursor:pointer;transition:opacity .2s ease-out}body.rtl .frm-warning-dismiss{left:10px;right:auto}.frm-warning-dismiss:hover{opacity:.8}.frm-warning-dismiss.frmsvg,.frm-warning-dismiss.frmsvg svg{width:15px;height:15px}.frm_note_style{background:rgba(188,224,253,.23);color:var(--grey-700)}.frm-banner-alert{text-align:left;margin:0;border-radius:0;padding:10px 0 10px 40px}.frm-banner-alert a{color:var(--primary-500);font-weight:400;text-decoration:none}.frm_updated_message ul,.frm_updated_message li,.frm_warning_style ul,.frm_warning_style li,.frm_error_style ul,.frm_error_style li{margin:0}.frm-inline-message{border:1px solid var(--primary-700);border-radius:var(--small-radius);color:var(--primary-700);background:#fff;text-align:center;padding:20px;font-size:var(--text-sm);line-height:var(--leading)}.frm-inline-message a{text-decoration:underline;font-weight:600;color:var(--primary-700)}.frm_pro_heading span{margin-top:10px}.frm_pro_heading .alignright{text-align:right}.frm-yes{color:var(--green);font-size:var(--text-xl)}.frm-nope{color:var(--grey-400);font-size:var(--text-xl)}.upgrade_to_pro a{color:var(--orange)}.upgrade_to_pro table .frmsvg{height:var(--text-xl);width:var(--text-xl)}.upgrade_to_pro table.widefat{background-color:#fff;border-collapse:collapse}.frm-white-body .upgrade_to_pro table th,.upgrade_to_pro table td{padding:10px 15px;border:1px solid var(--grey-300);line-height:var(--leading);font-size:var(--text-sm)}.upgrade_to_pro table th.frmcenter{text-align:center}.widefat th.frm_table_break{background-color:var(--sidebar-color)}h2.frm-h2+.howto{color:var(--medium-grey);max-width:850px;margin:5px 0 20px}.frm-card{width:100%;border-radius:10px;border:1px solid var(--grey-300);opacity:1;transition:opacity 1s}.frm-card-box{max-width:524px;background-color:#fff;border-radius:var(--medium-radius);padding:var(--gap-xl);border:1px solid var(--grey-200);box-shadow:var(--box-shadow-md)}.frm-card-box.frm-has-progress-bar{position:relative;overflow:hidden;border-radius:var(--medium-radius)}.frm-card-box-progress-bar{position:absolute;top:0;left:0;right:0;height:var(--gap-xs);background-color:var(--primary-25)}.frm-card-box-progress-bar>span{position:absolute;top:0;left:0;bottom:0;width:33%;background-color:var(--primary-500)}.frm-card-box-header{display:flex;justify-content:center;margin-bottom:var(--gap-sm)}.frm-card-box.frm-has-progress-bar .frm-card-box-header{margin-top:var(--gap-xs)}.frm-card-box-content>:last-child{margin-bottom:0}.frm-card-box-footer{display:flex;justify-content:end;gap:var(--gap-sm);margin-top:var(--gap-lg)}.frm-card-box-title{font-size:var(--text-xl) !important;font-weight:600 !important;margin-bottom:var(--gap-xs)}.frm-card-box-text{font-size:var(--text-md) !important;color:var(--grey-600) !important;margin-top:0 !important}.frm-fade{opacity:0;transition:all 1s}.frm-addons .frm-card.frm-addon-not-installed{position:relative}.frm-addons .plugin-card-top{min-height:155px;padding-top:var(--gap-lg);overflow:hidden}.frm-addons .plugin-card-top h2{margin-top:0;font-weight:400}.frm-template-row p,.frm-addons .plugin-card-top p{opacity:.8}.frm-addons .plugin-card-top>:not(p):not(h2){display:none}.frm-addons .plugin-card-bottom{padding:5px 20px 20px;text-align:center;background:rgba(0,0,0,0);border-top:none}.frm-addons .plugin-card-bottom,.frm-addons .plugin-card-bottom .button{font-size:15px}.frm-addons .button,.frm-addons .frm-button-tertiary{float:right}.frm-addons .addon-status{float:left;padding-top:4px}.frm-addon-not-installed .frm-activate-addon,.frm-addon-not-installed .frm-deactivate-addon,.frm-addon-not-installed .frm-uninstall-addon,.frm-addon-installed .frm-install-addon,.frm-addon-installed .frm-deactivate-addon,.frm-addon-active .frm-activate-addon,.frm-addon-active .frm-install-addon,.frm-addon-active .frm-uninstall-addon,.plugin-card-pro.frm-addon-active .button,.plugin-card-pro.frm-addon-active .frm-button-tertiary{display:none !important}.frm-save-and-reload-options{margin-top:10px;font-size:13px}.frm-save-and-reload,.frm-save-and-reload+.frm-button-secondary{visibility:visible !important}.addon-status-label{opacity:.7}.frm-addon-active .addon-status-label{color:var(--green);opacity:1}.frm-addon-error{position:absolute;top:55px;left:10px;right:10px;font-weight:700;text-align:center}.frm-new-template.plugin-card-bottom{overflow:visible}#frm-new-template p:first-child{margin-top:0}.frm-admin-page-formidableedit #wpbody-content>*:not(.frm-review-notice):not(.frm_previous_install):not(.frm-banner-alert):not(#frm-svg-icons-pack),#wpbody-content>.updated,#wpbody-content>#update-nag,#wpbody-content>.update-nag,#wpbody-content>.notice,#wpbody-content>.error:not(.frm_previous_install),.frm-white-body .updated,.frm-white-body .notice,.frm_wrap>.wrap>.notice,.frm-white-body .error:not(.frm_previous_install){display:none}.frm-admin-page-formidableedit #frm_builder_page{display:block !important}.frm-white-body .updated,.frm-white-body .error{margin:0;padding:10px 20px}.frm-modal:not(#frm-dismissable-cta) .postbox{max-height:600px;overflow:hidden;margin-bottom:0}.frm-modal .postbox .frm_modal_top,.frm-dialog .frm_common_modal .postbox>div:first-child,.frm-error-modal .frm_modal_top{padding:var(--gap-md) var(--gap-md) 0;position:relative}.frm-modal h2,.frm-modal .postbox .inside h2,.frm-modal .postbox .frm-modal-title,.frm-dialog .frm_common_modal .postbox>div:first-child>div:first-child,.frm-error-modal .frm-modal-title{display:inline-block;font-size:var(--text-lg);color:var(--grey-900);font-weight:600;margin:0;padding:0}.frm-modal h3{font-weight:500}.frm-inline-modal>a.dismiss,.frm-modal .postbox>a.dismiss,.frm-modal .postbox .frm-modal-title+div:last-child,.frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{position:absolute;top:19px;right:19px;display:flex;z-index:2}body.rtl .frm-inline-modal>a.dismiss,body.rtl .frm-modal .postbox>a.dismiss,body.rtl .frm-modal .postbox .frm-modal-title+div:last-child,body.rtl .frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{right:unset;left:30px}.frm-info-modal .postbox>a.dismiss,.frm-inline-modal>a.dismiss{right:13px;top:13px}.frm-modal .postbox .frm-modal-title+div:last-child a,.frm-modal a.dismiss .frmsvg,.frm_common_modal .frm_modal_top a .frmsvg{color:var(--grey-500)}.frm-modal .postbox .frm-modal-title+div:last-child a:hover,.frm-modal a.dismiss .frmsvg:hover,.frm_common_modal .frm_modal_top a .frmsvg:hover{color:var(--grey-700)}.frm-modal .frm_modal_content>div.inside,.frm_common_modal .frm_modal_content>div.inside{padding:var(--gap-md);margin:0;font-size:var(--text-sm);color:var(--grey-700)}.frm-modal p{color:var(--grey-900)}.frm_common_modal .postbox{display:flex;flex-direction:column}.frm-modal .postbox>div.inside .cta-inside{overflow-y:auto;height:auto}.frm_modal_footer{padding:0 var(--gap-md) var(--gap-sm);text-align:right}body.frm-body-with-open-modal{overflow-y:hidden}.frm-templates-list{margin-top:0}.frm-templates-list.frm_grid_container li{margin-bottom:0}.frm-templates-list li{vertical-align:top;position:relative;box-sizing:border-box;border-radius:6px;border:1px solid rgba(0,0,0,0);text-align:left}.frm-templates-list li:not(.frm_hidden){display:inline-block}.frm-templates-list.frm-categories-list li{width:100%}.frm-templates-list li.frm-selectable{cursor:pointer}.frm-templates-list li.frm-selectable:hover{background:var(--light-blue);border-color:rgba(65,153,253,.5)}.frm-templates-list li.frm-selectable:hover h3,.frm-templates-list li.frm-selectable:hover p{max-width:calc(100% - 65px)}.frm-templates-list .frm-featured-form{display:flex;width:100%}.frm-templates-list li .frm-featured-form{padding:7px 5px}.frm-templates-list li li>div{padding-left:0}.frm-templates-list li>div>div{vertical-align:middle}.frm-category-icon,.frm-icon-wrapper{background:var(--primary-500);border-radius:var(--small-radius);color:#fff;width:32px;height:32px;font-size:18px;box-sizing:border-box;align-self:center;justify-content:center;align-items:center;display:inline-flex}.frm-templates-list li .frm-category-icon{overflow:hidden}.frm-templates-list li h3,.frm-templates-list li p{text-align:left;margin:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.frm-templates-list li h3,.frm-templates-list .frm-install-template h3{font-size:var(--text-sm) !important}.frm-templates-list .frm-install-template div{text-align:left}#frm_leave_email,#frm_code_from_email{width:480px;max-width:100%}.frm-templates-list.frm-categories-list li>div>div:last-child{padding-left:0}.frm-hover-icons{position:absolute;right:0;top:17px;max-width:91px;height:100%;box-sizing:border-box;padding:0 10px 0 5px !important;border-radius:var(--small-radius);text-align:right;display:flex;gap:5px}.frm-ready-made-solution .frm-hover-icons{visibility:hidden}.frm-ready-made-solution:hover .frm-hover-icons{visibility:visible}.frm-hover-icons a{width:22px;height:22px;font-size:var(--text-md);display:inline-flex;align-items:center;justify-content:center;border-radius:50%;box-sizing:border-box;line-height:var(--leading);text-align:center}.frm-hover-icons>.frm-preview-form,.frm-hover-icons>.frm-delete-form{border:1px solid var(--primary-500)}.frm-hover-icons>.frm-create-form,.frm-ready-made-solution .frm-hover-icons a{background-color:var(--primary-500)}.frm-hover-icons>a .frmsvg{width:14px;height:14px;vertical-align:baseline}.frm-hover-icons>.frm-preview-form .frmsvg,.frm-hover-icons>.frm-delete-form .frmsvg{color:var(--primary-500)}.frm-hover-icons>.frm-unlock-form{background-color:var(--primary-500)}.frm-hover-icons>.frm-unlock-form .frmsvg{background-color:var(--primary-500)}.frm-ready-made-solution .frmsvg{width:14px;height:14px}.frm-hover-icons .frm-create-form svg,.frm-ready-made-solution .frm-hover-icons svg{color:#fff}.frm-hover-icons .frm-create-form:hover,.frm-ready-made-solution .frm-hover-icons a:hover,.frm-hover-icons>.frm-unlock-form:hover,.frm-hover-icons>.frm-unlock-form:hover .frmsvg{background-color:var(--primary-700) !important}.frm-hover-icons .frm-preview-form:hover,.frm-hover-icons .frm-delete-form:hover{border:1px solid var(--primary-700) !important}.frm-hover-icons .frm-preview-form:hover .frmsvg,.frm-hover-icons .frm-delete-form:hover .frmsvg{color:var(--primary-700) !important}.frm-application-card h4 .frmsvg,.frm-locked-template h3 .frmsvg{height:var(--text-sm);width:var(--text-sm);vertical-align:text-top;color:var(--grey-500)}.frm-modal-back{cursor:pointer;margin-right:4px}.frm-modal-cancel{float:left}.frm-meta-tag,.frm-meta-tag:hover{padding:var(--gap-2xs) var(--gap-xs);border-radius:var(--small-radius);font-weight:600;display:inline-flex;background-color:#d9ebff;gap:2px}.frm-meta-tag.frm-grey-tag,.frm-meta-tag.frm-grey-tag:hover{background-color:var(--sidebar-hover);color:var(--grey-900)}.frm-meta-tag.frm-red-tag,.frm-meta-tag.frm-red-tag:hover{background:var(--error-100);color:var(--error-700)}.frm-meta-tag.frm-orange-tag,.frm-meta-tag.frm-orange-tag:hover{background-color:#fef7f4;color:var(--orange)}.frm-meta-tag.frm-green-tag,.frm-meta-tag.frm-green-tag:hover{background-color:var(--success-500);color:#fff}.frm-entry-status-0,.frm-meta-tag.frm-lt-green-tag,.frm-meta-tag.frm-lt-green-tag:hover{background-color:var(--success-100);color:var(--success-800)}.frm-meta-tag.frm-new-pill{background-color:var(--success-500);vertical-align:text-bottom}.frm_add_field span+.frm-meta-tag{margin-left:0}.dropdown-item .frm-meta-tag{margin-left:0}.frm-entry-status{font-weight:500}.frm-entry-status-1{color:#7a4d05;background:#fff2d2}#frm-create-footer{padding:15px 20px}li .frm-hover-icons .frm-preview-form,.frm-hover-icons .frm-unlock-form,.frm-locked-template .frm-hover-icons .frm-create-form,.frm-modal-back{display:none}.frm-locked-template .frm-hover-icons .frm-unlock-form,li[data-preview] .frm-hover-icons .frm-preview-form{display:inline-flex}.frm-modal-back svg{color:#7f7f7f}#frm-upgrade-body-list-wrapper>div{display:inline-block;width:33.3333333333%;vertical-align:top;text-align:left;margin-bottom:10px}#frm-upgrade-body-list-wrapper ul{padding-left:40px}#frm-upgrade-body-list-wrapper ul li::before{content:"\2022";color:var(--primary-500);display:inline-block;width:1em;margin-left:-1em}.frm-embed-modal-content{padding:var(--gap-md)}.frm-embed-modal-content.frm-loading-page-options{display:flex;justify-content:center}#frm_embed_modal .frm_embed_example{background:var(--sidebar-color);border:1px solid var(--sidebar-hover);border-radius:var(--small-radius);color:var(--grey-900);font-size:var(--text-sm);padding-right:var(--gap-lg);width:100%;height:auto !important;resize:none}#frm_embed_modal textarea.frm_embed_example{padding-bottom:0}.frm-embed-modal-content>div a{position:absolute;right:0;top:0}.frm-embed-modal-content>div{position:relative;margin-bottom:var(--gap-sm)}.frm-embed-modal-content>div:last-child{margin-bottom:0}.frm-embed-modal-content svg[id^=frm_copy_embed_]{position:absolute;bottom:10px;right:10px;cursor:pointer;opacity:.5}.frm-border-info-box,.frm-embed-modal-option{border-radius:var(--small-radius);border:1px solid var(--grey-300);padding:var(--gap-sm);cursor:pointer;display:flex;gap:var(--gap-sm);font-size:var(--text-sm)}.frm-embed-modal-option+.frm-embed-modal-option{margin-top:var(--gap-sm)}.caret.rotate-270,.frm-embed-modal-option .caret{align-self:center;margin-left:auto;transform:rotate(-90deg)}#frm_embed_modal .frm_modal_footer{display:none}#frm_embed_modal.frm-on-page-2 .frm_modal_footer{display:block}.frm-embed-modal-content ul{max-height:300px;overflow-y:scroll}.frm-embed-modal-wrapper.frm-dialog{overflow:visible}#frm-bulk-modal .frm_grid_container{grid-template-columns:repeat(12, 8.33%);grid-gap:0}#frm-bulk-modal .frm8{border-right:1px solid var(--grey-300);padding:10px 20px 10px var(--gap-lg)}#frm-bulk-modal .frm4{padding:10px 0}.frm-inline-modal .howto{margin:5px 0 10px;color:var(--grey)}.frm-inline-modal .frm_code_list+.howto{margin-bottom:0}#frm_bulk_options{height:240px;width:100%;border:none;box-shadow:none;padding:0}.frm-bulk-edit-link{display:flex;align-items:center;justify-content:flex-end;gap:var(--gap-2xs);font-size:var(--text-sm);margin:12px 0 12px auto}.frm-bulk-edit-link .frm-bulk-edit-link{margin:0}.frm-small-add{font-size:var(--text-sm) !important}.frm-small-add span{color:var(--primary-500);font-size:12px;height:12px;width:12px}.frm_no_captcha_text{font-weight:700;color:#a00}.frm_image_from_url{height:50px}h1 .fa-caret-down{font-size:18px}.caret{display:inline-block;width:19px;height:9px;margin-right:-8px;vertical-align:middle}.caret,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,.frm_wrap .ui-autocomplete-input{background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;padding-right:var(--gap-lg) !important}.caret{padding-right:var(--gap-xs) !important;background-position-x:5px}.frm-btn-group .caret{float:right;margin-top:calc(var(--text-md)/2)}.dropdown{position:relative}.dropdown-toggle:focus{outline:0}.frm_wrap .ui-autocomplete,#frm_adv_info.frm-dropdown-menu,.frm-dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;padding-left:4px;padding-right:4px;margin:var(--gap-xs) 0 0;text-align:left;list-style:none;background:none;background-color:#fff;background-clip:padding-box;border:1px solid var(--grey-100);border-radius:.25rem;box-shadow:var(--box-shadow-lg);max-height:200px;overflow-y:auto;overflow-x:hidden;font-size:var(--text-md);width:auto;min-width:160px}.frm6 .frm-dropdown-menu{min-width:100px;max-width:99%}#frm_bs_dropdown .frm-dropdown-menu{max-width:400px}.field_type_list .frm-dropdown-menu{min-width:150px !important}#frm_field_group_controls .frm-dropdown-menu,.frm-field-action-icons .frm-dropdown-menu{min-width:180px !important}.frm-field-action-icons .frm-dropdown-toggle svg,#frm_field_group_controls .frm-dropdown-toggle svg{color:#9ea9b8}.multiselect-container.frm-dropdown-menu,#search-submit .frm-dropdown-menu{min-width:200px !important}.preview .frm-dropdown-menu{min-width:230px !important}.frm-dropdown-menu.dropdown-menu-right{right:0;left:auto}.frm-dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.frm-dropdown-menu>.dropdown-item{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu .frm_dropdown_li{clear:both;font-weight:400;white-space:nowrap;text-decoration:none;border-radius:var(--small-radius)}.frm-dropdown-menu>.active>a,.frm-dropdown-menu>.active>a:hover,.frm-dropdown-menu>.active>a:focus{text-decoration:none;outline:0}.frm-select-list-item.disabled,.frm-dropdown-menu>.disabled>a,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{color:#999}.frm-select-list-item.disabled:hover,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{text-decoration:none;background-color:rgba(0,0,0,0);background-image:none;cursor:not-allowed}.open>.frm-dropdown-menu{display:block}.open>a{outline:0}.dropdown-header{display:block;padding:3px 10px;font-size:var(--text-xs);color:var(--grey-400)}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.dropdown-menu-right>.frm-dropdown-menu,.pull-right>.frm-dropdown-menu{right:0;left:auto}.navbar-fixed-bottom .dropdown .caret{border-top:0 dotted;border-bottom:4px solid #000;content:""}.navbar-fixed-bottom .dropdown .frm-dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.btn{border:1px solid #ddd;background:#fff;height:28px;line-height:var(--leading)}a.frm_option_icon::before{color:var(--primary-500);font-size:22px;width:22px;height:22px}a.frm_option_icon:focus::before,a.frm_option_icon:hover::before{color:var(--primary-700)}.frm_top_left .frm-dropdown-toggle{color:#999}.frm-card ol{margin-left:15px}.frm-dropdown-toggle{text-decoration:none}.frm-card .frm-dropdown-toggle{border:1px solid var(--grey-300);border-radius:var(--small-radius);font-size:13px;color:var(--grey-700);padding:7px 20px}.frm-dropdown-menu .frm_icon_font{vertical-align:middle;color:#5f6c72;margin-right:3px}.multiselect-container.frm-dropdown-menu{top:auto;left:auto;font-size:var(--text-sm);padding:4px;margin-bottom:3px}#post-body-content+.frm-right-panel h3.accordion-section-title{padding:7px 10px 8px 14px;font-size:var(--text-md);color:var(--grey-700)}.frm-with-line,.accordion-section-content h4{font-size:var(--text-md);font-weight:400;margin:20px -20px 10px;padding:0 20px;color:var(--grey-700);position:relative;border:none !important}.frm-with-line span,.accordion-section-content h4 span{background:#fff;padding:0 var(--gap-xs);position:relative;display:inline-block;z-index:2}.accordion-section-content h4 span{background:var(--sidebar-color)}.frm-right-panel .frm-with-line span{background:var(--sidebar-color) !important;margin-left:-4px}.frm-right-panel .frm-inline-modal .frm-with-line span{background:#fff !important}.frm-with-line::before,.accordion-section-content h4::before{content:"";display:block;position:absolute;border-bottom:1px solid var(--grey-300);left:0;width:100%;top:50%}.control-section .accordion-section-title::after,.customize-pane-child .accordion-section-title::after{top:15px}.accordion-container .frm-dropdown-menu{min-width:40px}.frm-btn-group .multiselect.dropdown-toggle{box-sizing:border-box;min-height:unset;cursor:pointer}.accordion-container .frm-dropdown-menu::before,.accordion-container .multiselect.dropdown-toggle::before{font-family:"s11-fp" !important}.multiselect-container{position:absolute;list-style-type:none;margin:0;padding:0;width:100%;max-width:250px}.multiselect-container button.multiselect-option{width:100%;text-align:left;border:none;margin-bottom:4px}.multiselect-container button.multiselect-option label{margin-left:5px}.accordion-container .multiselect-container label{padding:3px 19px 3px 7px}.frm-btn-group.btn-group>.btn-group:nth-child(2)>.multiselect.btn{border-top-left-radius:4px;border-bottom-left-radius:4px}.frm-btn-group.btn-group,.frm-btn-group.btn-group-vertical{display:block}.multiselect-option label{max-width:calc(100% - 22px);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.frm_scale{text-align:center;float:left;margin-right:10px}.frm_scale input{display:block;margin:5px}.frm_multi_fields_container{float:left}.frm_multi_fields_container,.frm_form_builder .frm_form_fields input[type=tel] .frm_form_builder .frm_form_fields input[type=range],.frm_form_builder .frm_form_fields input[type=text]{width:100%;height:auto}.frm_form_builder .frm_time_wrap .frm_time_sep{vertical-align:sub;vertical-align:-webkit-baseline-middle}.frm_form_builder input[type=range]::-webkit-slider-runnable-track{background-color:var(--blue-border)}.frm_form_builder input[type=range]::-moz-range-track{background-color:var(--blue-border)}.frm_form_builder input[type=range]::-ms-fill-lower{background-color:var(--blue-border)}.frm_form_builder input[type=range]::-ms-fill-upper{background-color:var(--blue-border)}.frm-embed-field-placeholder{text-align:center;height:145px;display:flex;align-items:center;justify-content:center}.frm-fake-field{display:block;height:25px;background-color:var(--light-blue);border:1px solid var(--grey-300);margin:10px 0;border-radius:var(--small-radius)}.frm-embed-message{position:absolute;background:#fff;border:1px solid var(--grey-300);color:var(--grey-700);padding:var(--gap-md);font-size:var(--text-lg);max-width:200px;min-width:50%;margin:0 var(--gap-md);overflow:hidden;text-overflow:ellipsis}.frm-summary-message{top:50%;left:50%;padding:15px 0;font-size:var(--text-md);transform:translate(-50%, -50%)}.frm-summary-learn-more{font-size:inherit !important}.frm-single-settings .frm-embed-message{width:100%;position:static;border-radius:var(--small-radius)}#new_fields input[type=text],#new_fields input[type=number],.frm_field_box .frm_form_fields>textarea,.frm_form_fields .frm_form_field>textarea,.frm_form_fields .frm_form_field>input[type=email],.frm_form_fields .frm_form_field>input[type=url],.frm_form_fields .frm_form_field>input[type=number],.frm_form_fields .frm_form_field>input[type=tel],.frm_form_fields .frm_form_field>input[type=text],.frm_form_fields .frm_form_field>input[type=range]{width:100%}.frm_form_fields textarea.wp-editor-area{width:100%;border:none}.frm_form_fields input[type=file],.frm_form_fields input[type=file]:disabled{background:rgba(0,0,0,0);border:none;box-shadow:none;width:auto}.frm_form_fields select{width:auto;max-width:100%}input[type=radio],input[type=checkbox]{width:16px;padding:0}.frm_grid_container>p,.frm_grid_container>p.frm_form_field,.frm_grid_container>div.frm_form_field,#new_fields .frm_grid_container>p{margin-top:8px;margin-bottom:8px;margin-right:0}.frm_grid_container>p>label:only-child,.frm_grid_container>p.frm_form_field>label:only-child,.frm_grid_container>div.frm_form_field>label:only-child,#new_fields .frm_grid_container>p>label:only-child{margin-bottom:0}.frm_grid_container>.frm-has-modal>p:only-child{margin-bottom:var(--gap-xs)}#new_fields div.frm_grid_container>.frm_primary_label{margin-top:8px}#new_fields .frm_primary_label+p,#new_fields .frm_primary_label+.frm6+.frm6,#new_fields .frm_primary_label+.frm6+.frm-inline-modal+.frm6{margin-top:0}.frm_catlevel_2,.frm_catlevel_3,.frm_catlevel_4,.frm_catlevel_5{margin-left:18px}.frm_wrap .frm-fields .auto_width,.frm_form_fields input.auto_width,.frm_form_fields select.auto_width,.frm_form_fields textarea.auto_width{width:auto !important}.frm_form_fields select.auto_width{min-width:60px}.frm_form_fields input:focus,.frm_form_fields select:focus,.frm_form_fields textarea:focus,.frm_focus_field input{background-color:#fff;border-color:#ddd}.frm_form_builder .frm_radio,.frm_form_builder .frm_checkbox{display:block;margin-bottom:2px}.frm_form_builder .frm_radio label,.frm_form_builder .frm_checkbox label{font-size:var(--text-sm)}.horizontal_radio .frm_radio,.horizontal_radio .frm_checkbox{margin-right:5px;display:inline-block}.frm_form_builder .frm_opt_container .frm_radio.frm_image_option label,.frm_form_builder .frm_opt_container .frm_checkbox.frm_image_option label{display:flex;align-items:center;gap:9px;white-space:normal}.frm_form_field.frm_two_col .frm_opt_container,.frm_form_field.frm_three_col .frm_opt_container,.frm_form_field.frm_four_col .frm_opt_container{display:grid;grid-template-columns:repeat(2, 1fr);grid-auto-rows:max-content;grid-gap:0 2.5%}.frm_form_field.frm_three_col .frm_opt_container{grid-template-columns:repeat(3, 1fr)}.frm_form_field.frm_four_col .frm_opt_container{grid-template-columns:repeat(4, 1fr)}.frm_form_field.frm_two_col .frm_radio,.frm_form_field.frm_two_col .frm_checkbox,.frm_form_field.frm_three_col .frm_radio,.frm_form_field.frm_three_col .frm_checkbox,.frm_form_field.frm_four_col .frm_radio,.frm_form_field.frm_four_col .frm_checkbox{grid-column-end:span 1}.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox],.frm_wrap .with_frm_style .frm_radio input[type=radio],.frm_wrap input[type=checkbox],.frm-white-body input[type=checkbox],.field-group input[type=checkbox],.frm_scale input[type=radio],.frm_radio input[type=radio],.frm_checkbox input[type=checkbox]{width:15px;min-width:15px;height:15px;border:1px solid var(--grey-300);box-shadow:var(--box-shadow-sm);-webkit-appearance:none}.frm_wrap input[type=radio]{border-color:var(--grey-300);box-shadow:var(--box-shadow-sm)}.frm_wrap input[type=radio]:checked::before{background-color:var(--primary-500)}.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox],.frm_wrap input[type=checkbox],.frm-white-body input[type=checkbox],.field-group input[type=checkbox],.frm_checkbox input[type=checkbox]{border-radius:4px}.frm-white-body input[type=checkbox]:checked,.frm_wrap input[type=checkbox]:checked{background-color:var(--border-color-active, var(--primary-500)) !important;border-color:var(--border-color-active, var(--primary-500)) !important}.frm-white-body input[type=checkbox]:checked:focus,.frm_wrap input[type=checkbox]:checked:focus{border-color:var(--border-color-active, var(--primary-500))}.frm-white-body input[type=checkbox]:checked::before,.frm_wrap input[type=checkbox]:checked::before{content:"";display:block;width:100% !important;height:100% !important;background-image:url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.6667 1.5L4.25001 7.91667L1.33334 5' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A") !important;background-size:8px !important;background-repeat:no-repeat !important;background-position:center !important;margin:0}.frm_radio input[type=radio],.frm_checkbox input[type=checkbox]{margin-right:5px}.frm_inner_field_container{margin-bottom:10px}.frm_conf_inline .frm_inner_field_container,.frm_conf_inline .frm_inner_conf_container{width:49%;float:left}.frm_conf_inline .frm_inner_field_container{margin-right:2%;clear:both}.frm_inner_field_container>label{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.frm_field_box:not(.edit_field_type_divider):hover>.frm_inner_field_container>label,.frm_field_box .divider_section_only:hover>.frm_inner_field_container>label,li.ui-state-default.selected>.frm_inner_field_container>label{max-width:calc(100% - 100px)}.frm-drag-fade{background-color:var(--lightest-grey) !important;border-radius:4px}.frm-drag-fade *{opacity:0}.frm-dragging .divider_section_only,.frm-dragging .frm_field_box{pointer-events:none}.frm_form_settings #op-popup,.frm_form_settings com-1password-op-button,.frm_conf_below .frm_conf_field_container .frm_primary_label,.frm_conf_inline .frm_inner_field_container .frm-show-click a,.frm_conf_below .frm_conf_field_container .frm-show-click a{display:none !important}.frm_conf_inline .frm_inner_field_container .frm-field-action-icons{position:absolute;right:5px}.frm_conf_below .frm_conf_field_container{margin-top:10px}.frm_calc_dec{width:50px}.frm_ext_sc{display:none}.frm_long_input{width:100% !important;box-sizing:border-box}.frmcenter{text-align:center}img.frm_help{margin-left:2px;vertical-align:middle;padding-bottom:2px}.frm_spinner.frm-wait,.frm_spinner.spinner{float:left;visibility:hidden;margin:0 10px}.frm_visible_spinner.frm-wait,.frm_visible_spinner.spinner{visibility:visible;float:none}.frm_form_action_settings .frm_spinner.frm-wait,.frm_form_action_settings .frm_spinner.spinner{visibility:visible;float:none;vertical-align:bottom}.frm_form_action_settings .frm_loading{font-size:15px;text-align:center}.frm_ajax_settings_tab .frm-wait,.frm_ajax_settings_tab .spinner{visibility:visible;float:none;margin-top:20px}.wp-core-ui .frm_loading_button.button-primary.frm-button-primary,.frm_loading_button,.frm_loading_form.frm_button_submit{position:relative !important;opacity:.8;color:rgba(0,0,0,0) !important;text-shadow:none !important}.frm_loading_button:hover,.frm_loading_button:active,.frm_loading_button:focus,.frm_loading_form.frm_button_submit:hover,.frm_loading_form.frm_button_submit:active,.frm_loading_form.frm_button_submit:focus{cursor:not-allowed;color:rgba(0,0,0,0) !important;outline:none !important;box-shadow:none}.frm-wait{margin:20px;width:20px;height:20px;position:relative;display:inline-block}#frm-show-fields .frm-wait:only-child{position:absolute;left:50px;top:30px}.frm-wait::before,.frm_loading_button::before,.frm_loading_form.frm_button_submit::before{content:"";display:inline-block;position:absolute;background:rgba(0,0,0,0);border:1px solid #fff;border-top-color:rgba(0,0,0,0);border-left-color:rgba(0,0,0,0);border-radius:50%;box-sizing:border-box;top:50%;left:50%;margin-top:-10px;margin-left:-10px;width:20px;height:20px;animation:spin 2s linear infinite}.frm-wait::before{border-bottom-color:var(--primary-700);border-right-color:var(--primary-700)}.frm_loading_button.frm-button-secondary::before{border-bottom-color:var(--primary-500);border-right-color:var(--primary-500)}input[type=submit]:focus{outline:none !important}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}label input[type=checkbox],label input[type=radio]{vertical-align:inherit}#editorcontainer #dyncontent{margin:0;width:100%;padding:6px;line-height:var(--leading);border:0 none;outline:none;box-sizing:border-box}.frm_postbox_icon{margin:-6px 0 0 -10px}.frm_form_builder a:hover{text-decoration:underline}.frm_form_builder .widget-title h4{padding:10px 15px}.frm_form_builder .widget-top a.widget-action::after{margin:7px 12px 0}.frmbutton.frm_tgateway{display:none !important}.frm_html_legend pre{display:inline}#ed_fullscreen{display:none !important}.frm_posttax_opt_list{overflow:auto;max-height:200px;background-color:#fff}.frm_posttax_opt_list p.howto{font-size:12px}.frm_border_bottom{border-bottom:1px solid var(--grey-300);margin-bottom:10px;padding-bottom:10px}.frm_posttax_opt_list .frm_border_bottom span.howto{padding-right:10px}.frm_posttax_opt_list .frm_border_bottom input{margin-right:1px}.frm_add_remove div.frm_form_field{padding-bottom:5px}.frm_field_opts_list{max-height:260px;overflow:auto}.frm_white_bg,.frm-bg-white{background-color:#fff}.frm-bg-grey-50{background-color:var(--grey-50)}.frm-bg-grey-200{background-color:var(--grey-200)}.frm-bg-grey-800{background-color:var(--grey-800)}.frm-bg-primary-500{background-color:var(--primary-500)}.frm_border_light{border:solid 1px #ddd}#new_fields .form-table input[type=text],#new_fields .form-table select,.form-table .form-field input,.form-table .form-field .quicktags-toolbar input,.form-field input,.form-field .quicktags-toolbar input{width:auto}.frm_aff_link{float:right}.frm_select_box{text-align:center;font-weight:700;width:100%;background-color:rgba(0,0,0,0) !important}.wp-list-table input.frm_select_box{text-align:left;font-weight:400;font-size:inherit !important;border:none;padding:0 !important;background-color:rgba(0,0,0,0) !important}.wp-list-table input.frm_select_box:focus{outline:none;box-shadow:none}.wp-list-table .frm_no_items.frm_select_box{text-align:center;font-weight:700;width:500px;max-width:100%;font-size:inherit}#frm-options-panel{padding:0 var(--gap-sm);color:var(--grey-900);overflow:hidden}.frm-right-panel a.frm_add_logic_link,#frm-options-panel h3,.frm-collapsible{font-size:var(--text-md);font-weight:500;background-color:#fff;border-radius:var(--small-radius);padding:18px var(--gap-sm);margin:2px calc(-1*var(--gap-sm));transition:background-color 200ms ease-out,box-shadow 200ms ease-out,color 200ms ease-out}.frm-right-panel a.frm_add_logic_link .frmsvg,#frm-options-panel h3 .frmsvg,.frm-collapsible .frmsvg{width:13px;height:13px;color:var(--grey-500);transition:transform 300ms ease-in}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type),.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child,#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type),#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child,.frm-collapsible:not(.frm-collapsed):not(:first-of-type),.frm-collapsible:not(.frm-collapsed):first-of-type:first-child{color:var(--grey-700);box-shadow:var(--box-shadow-sm)}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type) .frmsvg,.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child .frmsvg,#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type) .frmsvg,#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child .frmsvg,.frm-collapsible:not(.frm-collapsed):not(:first-of-type) .frmsvg,.frm-collapsible:not(.frm-collapsed):first-of-type:first-child .frmsvg{transform:rotate(-180deg)}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div,#frm-options-panel h3:not(.frm-collapsed)+div,.frm-collapsible:not(.frm-collapsed)+div{padding-top:6px;padding-bottom:6px}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div.frm_grid_container,#frm-options-panel h3:not(.frm-collapsed)+div.frm_grid_container,.frm-collapsible:not(.frm-collapsed)+div.frm_grid_container{padding-bottom:14px}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div.frm_grid_container>p:first-child,#frm-options-panel h3:not(.frm-collapsed)+div.frm_grid_container>p:first-child,.frm-collapsible:not(.frm-collapsed)+div.frm_grid_container>p:first-child{margin-top:var(--gap-sm)}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div.frm_grid_container>p:first-child.frm6+.frm6,#frm-options-panel h3:not(.frm-collapsed)+div.frm_grid_container>p:first-child.frm6+.frm6,.frm-collapsible:not(.frm-collapsed)+div.frm_grid_container>p:first-child.frm6+.frm6{margin-top:var(--gap-sm)}.frm-right-panel a.frm_add_logic_link.frm-collapsed,#frm-options-panel h3.frm-collapsed,.frm-collapsible.frm-collapsed{color:var(--grey-500);background-color:rgba(0,0,0,0)}.frm-right-panel a.frm_add_logic_link:hover,#frm-options-panel h3:hover,.frm-collapsible:hover{color:var(--grey-700);background-color:#fff;box-shadow:var(--box-shadow-sm)}.frm-right-panel a.frm_add_logic_link:focus-visible,#frm-options-panel h3:focus-visible,.frm-collapsible:focus-visible{outline:1px solid var(--primary-500) !important;outline-offset:-1px}h4.frm-collapsible:hover{box-shadow:none}.frm-right-panel a.frm_add_logic_link:focus{outline:auto}.frm_field_key{background-color:#f7f7f7}#frm_form_editor_container #edit-slug-box{padding:0}.frm-alt-table{position:relative;width:100%;border-collapse:collapse;margin-top:.5em;font-size:15px}#form_show_entry_page .frm-alt-table:not(.frm-zebra-striping)::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-color:#fff}.frm-alt-table th{width:200px}.frm-alt-table tr,.frm-alt-table tr.frm-odd{background-color:rgba(0,0,0,0)}.frm-alt-table tr.frm-even{background-color:var(--sidebar-color)}.frm-alt-table th,.frm-alt-table td{background-color:rgba(0,0,0,0);vertical-align:top;text-align:left;padding:20px}.frm-alt-table h3{margin-bottom:0}.form-field .frm_cb_button{height:22px;line-height:20px;margin-bottom:10px;margin-right:5px}.edit_field_type_select .frm_option_val_label{margin-left:12px}.frm_rte{background:url(../images/rte.png) no-repeat}.frm_rte .howto{margin:10px 0 46px}.subform_section{margin:25px}.subform_section,.subform_section label,.subform_section input{opacity:80}.subform_section .frm_sortable_field_opts{display:none}#frm_form_editor_container .subform_section .frm_primary_label{display:block}.subform_section.subform_break{border-top:1px dashed #ccc}.button-secondary.frm_html_field{background-color:#ededed;padding:10px 20px;line-height:inherit;width:auto;height:auto !important;border-radius:0;box-sizing:content-box}.frm_html_field_placeholder{margin-bottom:10px;text-align:center}.recaptcha_placeholder{border:1px solid #d3d3d3;width:300px}.turnstile_placeholder{width:300px}.frm_sorting .frm_rte textarea{width:653px;background:#fff;margin:1px 0 0;border:1px solid #dfdfdf;border-top:none;border-radius:0;float:none !important}.frm_full_rte textarea{width:98%;padding:0}.frm_field_box{padding:5px;min-height:20px;margin:10px 0}.frm_indent_opt,td.frm_indent_opt{padding-left:25px}.frm_charts object{background:rgba(0,0,0,0)}.frm_charts h2{height:34px}.frm_single_option.ui-sortable-placeholder,li.sortable-placeholder{border:none;margin:0;visibility:visible !important;box-shadow:2px -10px 0 2px var(--primary-500)}#frm_form_editor_container>ul>.frm_single_option.ui-sortable-placeholder,#frm_form_editor_container>ul>li.sortable-placeholder{width:calc(100% - 5px) !important;height:0 !important}#frm_form_editor_container>ul>li>ul{position:relative}#frm_form_editor_container>ul>li>ul>li.sortable-placeholder,#frm_form_editor_container ul.start_divider>li>ul>li.sortable-placeholder{position:absolute;top:20px;bottom:0}.edit_field_type_divider+li.sortable-placeholder{box-shadow:2px 5px 0 2px var(--primary-500)}.start_divider li.sortable-placeholder{box-shadow:2px -5px 0 2px var(--primary-500)}.frm-is-collapsed+.sortable-placeholder{box-shadow:2px 15px 0 2px var(--primary-500)}.frm_single_option.ui-sortable-placeholder{box-shadow:0 0 1px 1px var(--primary-500)}.frm_sorting>li.edit_field_type_end_divider:first-child,.frm-show-click,li.ui-state-default.edit_field_type_divider .frm-show-click{display:none}.frm_form_field.ui-sortable-helper .frm-field-action-icons,.frm_form_field.ui-sortable-helper .frm_form_fields,.frm_form_field.ui-sortable-helper .frm_description,.frm_form_field.ui-sortable-helper .description{display:none}.frm_form_field.ui-sortable-helper .frm_primary_label,.frm_form_field.ui-sortable-helper .frm_inner_field_container{margin:0 !important}.frm-single-settings .frm-show-click{display:block !important}.frm-show-hover,.frm_single_visible_hover,li.ui-state-default.edit_field_type_divider .frm-show-hover{opacity:0;transition:opacity .15s ease-in-out}#frm-show-fields .frm-field-settings-open .frm-show-hover{opacity:1}.frm_sortable_field_opts{margin-top:5px}.frm_single_option{clear:both;margin:0 !important;padding-bottom:5px}.frm_single_option input[type=radio],.frm_single_option input[type=checkbox]{margin-top:0}.frm_single_option .frm-with-right-icon input[type=text]+.frmsvg{position:relative;right:27px;width:14px;height:14px;padding:0;margin:var(--gap-2xs) 0 0}.frm_product_price_wrapper,.frm_image_preview_wrapper,#new_fields .frm_single_option select,#new_fields .frm_single_option input[type=text]{width:calc(100% - 106px) !important;flex-grow:1}.frm-right-panel .frm_single_option a.frm_remove_tag,.frm_single_option a{padding-left:7px}.frm_single_option:hover .frm_single_visible_hover{opacity:100}.frm_single_option .frm-drag{font-size:23px;width:24px;height:24px;margin-left:-6px;margin-right:var(--gap-xs);color:var(--grey-500)}.frm_single_option .frm-drag::before{vertical-align:middle}.frm-drag,.frm_single_option.ui-sortable-helper{cursor:move}.frm_single_option .frm_option_key.frm_image_preview_wrapper,.frm-type-ranking .frm_single_option .frm_option_key{margin-left:21px !important}.frm_option_key input[type=text]{margin-top:var(--gap-xs) !important;margin-left:11px !important}.frm_option_key input[type=checkbox]+input[type=text],.frm_option_key input[type=radio]+input[type=text]{margin-left:30px !important}.frm-type-ranking .frm_option_key input[id*=field_key_]{margin-left:30px !important}li.ui-state-default.selected .frm-show-click,li.ui-state-default.selected.edit_field_type_divider .frm-show-click{display:inline;vertical-align:top}.frm_field_box:not(.edit_field_type_divider):hover>.frm_inner_field_container>.frm-show-hover,.frm_field_box .divider_section_only:hover>.frm_inner_field_container>.frm-show-hover,li.ui-state-default.selected>.frm_inner_field_container>.frm-show-hover,li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover{opacity:100}li.frm_field_box>ul.frm_grid_container{position:relative}.frm_sorting span.ui-icon{width:16px}body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) .frm_image_options .frm_image_option_container{--field-border-width: 1px;--border-color: var(--grey-300);--border-color-active: var(--primary-500);--border-radius: var(--small-radius)}#form_show_entry_page .frm_file_link,#form_show_entry_page .frm_image_option_container{display:inline-flex;flex-wrap:nowrap;flex-direction:column;text-align:center;align-items:center;width:150px;margin-right:10px;margin-bottom:10px}#form_show_entry_page .frm_image_option_container img{width:150px;height:150px;object-fit:cover}#form_show_entry_page .frm_file_link img{max-width:150px;height:auto}#form_show_entry_page .frm_file_link~br{display:none}#form_show_entry_page .frm_upload_label{padding:10px}#form_show_entry_page.frm_wrap .postbox{overflow:hidden}.frm_image_option_container .frm_image_placeholder_icon svg{height:150px}.frm_list_entry_page .frm_file_link,.frm_list_entry_page .frm_image_option_container.frm_label_with_image{display:block;text-align:center}.frm_list_entry_page .frm_image_option_container img{width:75px;height:75px;object-fit:cover}.frm_list_entry_page img{max-width:100%;height:auto}.frm_image_option_container .frm_empty_url{background-color:var(--sidebar-color)}.frm_list_entry_page .frm_image_option_container .frm_text_label_for_image{display:block;padding:5px 0 10px}.frm_list_entry_page .frm_upload_label,.frm-summary-page-wrapper .frm_text_label_for_image{display:block}#frm-welcome .frm_image_options .frm_image_option_container,#form_global_settings .frm_image_options .frm_image_option_container{background:var(--sidebar-color)}#frm-welcome .frm_image_option_container svg,#form_global_settings .frm_image_option_container svg{max-width:calc(100% - 20px)}#frm-new-template .frm_image_option_container svg{height:50px;margin:10px auto 0}.frm_image_option_container{position:relative}.frm_text_label_for_image>svg{width:30px;position:absolute;top:5px;right:calc(50% - 15px)}.frm_single_option .frm_option_key{margin-top:17px}.frm_single_option .frm_option_key.frm_image_preview_wrapper{margin-top:var(--gap-xs)}.frm_image_data{margin-left:var(--gap-sm);display:flex;flex-direction:column;font-size:var(--text-sm);justify-content:space-around;min-width:0}.frm_image_styling_frame{display:flex;align-items:stretch;margin-left:36px;margin-bottom:var(--gap-xs);width:100%}.frm_image_styling_frame img{height:54px;width:54px;min-width:auto;min-height:auto;border-radius:3px;object-fit:cover;object-position:center}.frm_image_styling_frame .frm_email_attachment_icon img{height:auto;width:auto;max-width:54px}.frm_image_preview_title{color:var(--grey-500);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;flex:1 1 auto}.frm_wrap .frm_choose_image_box{cursor:pointer;color:var(--primary-500);background-color:#fff;margin-left:32px;text-align:center;width:100%}.frm-type-ranking .frm_option_key .frm_choose_image_box{margin-left:11px !important}.frm_wrap .frm_choose_image_box:hover{background:#fff}a.frm_remove_image_option,.frm_remove_image_option{color:var(--grey-400);cursor:pointer}a.frm_remove_image_option:hover .frmsvg,a.frm_remove_image_option:hover,.frm_remove_image_option:hover{color:rgba(40,47,54,.8)}.frm-form-setting-tabs{margin-top:var(--gap-sm) !important}.frm-right-panel>.postbox{background-color:rgba(0,0,0,0);border:none;box-shadow:none;margin:0}.frm-right-panel .postbox.frm_with_icons .inside,.frm-right-panel .postbox .inside,.frm-right-panel .inside{font-size:var(--text-md);padding:15px 20px 20px;color:var(--grey-700)}.frm-right-panel .misc-pub-section{padding:var(--gap-xs) 0;position:relative}.frm-right-panel .inside a,.frm-form-setting-tabs a{font-size:var(--text-md);color:var(--grey-700);padding:var(--gap-sm);display:block}.frm-form-setting-tabs a{color:var(--grey-900);padding:var(--gap-sm) var(--gap-md)}.frm-right-panel .inside a{padding:0;color:var(--primary-500);display:inline-block}.frm-right-panel .inside a:hover{color:var(--primary-700)}.frm-form-setting-tabs a:hover{background:var(--sidebar-hover);color:var(--grey-900)}.frm-right-panel .inside i,.frm-form-setting-tabs a i,.frm-form-setting-tabs a .frmsvg{margin:0 5px;display:inline-block;width:20px;height:20px;color:var(--grey-500)}.frm-form-setting-tabs a .frmsvg{margin:0}.frm-right-panel .inside a:hover i,.frm-right-panel .inside a:hover .frmsvg,.frm-form-setting-tabs a:hover .frmsvg,.frm-form-setting-tabs a:hover span{color:var(--grey-700)}.frm_settings_form .tabs-panel{padding:0 25px}#form_settings_page .tabs-panel,.frm_settings_form .tabs-panel{max-height:initial !important;min-height:50px !important}#frm_adv_info .tabs-panel{min-height:0 !important;overflow-x:hidden;padding:0;border:none;background:rgba(0,0,0,0)}select.frm_cancelnew,input.frm_enternew{width:175px}.frm_posttax_opt_list{border:1px solid var(--grey-300);padding:var(--gap-md);border-radius:var(--small-radius);margin:5px 0 5px var(--gap-md)}.frm_settings_form .wp-picker-open+.wp-picker-input-wrap,.frm-right-panel .wp-picker-open+.wp-picker-input-wrap{position:absolute;margin-left:calc((100% - 35px)*-1);margin-top:1px;width:calc(100% - 36px)}.frm_settings_form .wp-picker-container input[type=text].wp-color-picker,.frm-right-panel .wp-picker-container input[type=text].wp-color-picker{border:none;padding:5px 8px;font-family:inherit;color:var(--grey-700);font-size:var(--text-md);width:100%;line-height:var(--leading)}.frm_settings_form .wp-picker-input-wrap .wp-picker-clear,.frm-right-panel .wp-picker-input-wrap .wp-picker-clear{display:none !important}.frm_settings_form .wp-picker-holder,.frm-right-panel .wp-picker-holder{position:absolute;z-index:999}.frm_settings_form .wp-picker-input-wrap label,.frm-right-panel .wp-picker-input-wrap label{margin-bottom:0}.frm_settings_form .wp-picker-container .wp-color-result.button,.frm-right-panel .wp-picker-container .wp-color-result.button{width:100%;overflow:hidden;margin:0 !important;height:var(--h-md) !important;padding:0 0 0 var(--gap-lg) !important;border-radius:var(--small-radius);border-color:var(--grey-300)}.frm_settings_form .wp-color-result-text,.frm-right-panel .wp-color-result-text{line-height:var(--leading) !important;font-size:var(--text-md);background:#fff !important;color:var(--grey-900);padding:5px 8px;border-color:var(--grey-300);text-align:left}.frm_settings_form .color-alpha,.frm-right-panel .color-alpha{width:var(--gap-lg) !important}.frm_grid_container .wp-picker-container{width:100%;position:relative}.wp-picker-container button.wp-color-result{border:1px solid var(--grey-300) !important}.wp-picker-container .wp-picker-input-wrap input.hex.wp-color-picker{max-width:100%;position:relative}.frm_end .wp-picker-holder{margin-left:-145px}.frm_end.frm6 .wp-picker-holder{margin-left:-86px}.frm_toggle_opt{padding:0;white-space:normal;display:inline;vertical-align:middle;font-weight:400}.frm_on_label,.frm_off_label{color:var(--grey-700)}.frm_toggle{position:relative;display:inline-block;width:40px;height:var(--h-xs);vertical-align:middle}.frm_toggle_block{display:inline-flex !important;gap:var(--gap-xs);align-items:center}.frm_toggle input,.frm_toggle_block input{display:none !important}.frm_toggle_slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--grey-200);transition:.4s;border-radius:30px}.frm_toggle_slider::before{box-sizing:border-box;content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E");position:absolute;left:2px;bottom:2px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:20px;line-height:20px;background-color:#fff;border-radius:50%;transition:.4s;box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider{background-color:var(--primary-500)}input:focus+.frm_toggle .frm_toggle_slider{box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider::before{transform:translateX(16px);content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E")}input[disabled]+.frm_toggle_slider,input[disabled]+.frm_toggle .frm_toggle_slider{pointer-events:none;cursor:text;opacity:.5}.frm_toggle_opt~.frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before{content:"" !important}.rtl .frm_toggle_opt{padding:0 8px}.rtl .frm_toggle_slider::before{left:17px}.rtl input:checked+.frm_toggle .frm_toggle_slider::before{transform:none !important;left:1px}.frm_toggle_off,.frm_toggle_on{display:none;color:#fff;z-index:999;position:absolute;font-size:10px;line-height:20px;left:6px}.frm_toggle_off{display:inline;left:auto;right:5px;color:var(--dark-grey)}.frm_toggle_long{width:80% !important;height:28px;display:inline-block !important}.frm_toggle_long .frm_toggle_slider{background:var(--primary-700);box-shadow:0 0 0 2px var(--primary-700)}.frm_toggle_long .frm_toggle_off,.frm_toggle_long .frm_toggle_on{width:50%;text-align:center;font-size:13px;line-height:28px}.frm_toggle_long .frm_toggle_on{left:0}.frm_toggle_long .frm_toggle_off{right:0}.frm_toggle_long .frm_toggle_slider::before{width:50%;left:0;top:0;border-radius:var(--border-radius) 0 0 var(--border-radius);height:100%;background-color:#fff;color:var(--primary-color);content:"" !important}.frm_toggle_long input:checked+.frm_toggle_slider::before{transform:translateX(101%);border-radius:0 var(--border-radius) var(--border-radius) 0}input:checked+.frm_toggle_slider+.frm_toggle_on{display:inline}input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:none}.frm_toggle_long .frm_toggle_on,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:inline;color:var(--primary-500);font-weight:400}.frm_toggle_long .frm_toggle_off,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on{color:#fff;font-weight:700}.tabs-panel{height:auto !important;min-height:260px}.tabs-panel.panel_secondary{min-height:20px;margin-top:10px;margin-left:150px}label.frm-example-icon{margin-right:20px !important;display:inline-block !important}#frm_stripe_icon{border-radius:5px}#captcha_settings .frm_primary_label{margin-top:var(--gap-sm)}.frm-long-icon-buttons{display:flex;gap:var(--gap-md)}.frm-long-icon-buttons>label{border:1px solid var(--grey-300);color:var(--grey-700);border-radius:var(--small-radius);display:flex;padding:var(--gap-sm);gap:var(--gap-sm);justify-content:center;align-items:center;width:calc(33% - var(--gap-sm));box-sizing:border-box}.frm-long-icon-buttons>label:hover{color:var(--primary-500)}.frm-long-icon-buttons input[type=radio]{display:none}.frm-long-icon-buttons input[type=radio]:checked+label{border-color:var(--primary-500);box-shadow:0 0 0 1px var(--primary-color)}.frm-long-icon-buttons label>svg{height:21px}.frm-example-icon .frmsvg,.frm-example-icon i{height:20px;width:20px;font-size:20px;color:var(--grey-700)}.frm_license_msg{margin-top:0}.frm_authorized_box .frm-show-unauthorized,.frm_unauthorized_box .frm-show-authorized{display:none}.edd_frm_status_icon.frmsvg{margin:0 5px}.edd_frm_license_row .frm_action_success .frmsvg{color:green}.edd_frm_license_row .frm_action_error .frmsvg{color:#d54e21}#form_global_settings .tabs-panel .num svg{display:none}.frm_no_items{margin:0 auto 50px;text-align:center;color:var(--grey-700);max-width:500px}.frm-subscribe{margin:var(--gap-lg) 0}.frm_inbox_count{color:#fff;border-radius:50%;display:inline-block;margin-right:8px;font-size:11px;text-align:center;min-width:18px;height:18px;margin-left:2px;vertical-align:text-bottom}#payments_settings .frm_payments_section .form-table td{padding-left:0;padding-right:0}#payments_settings .frm_payments_section .form-table{margin-top:0}#frm_authnet_general_settings>tr:first-of-type>td:first-of-type{padding-top:0}#frm_authnet_general_settings h3{margin-bottom:0}.frm_payment_settings_tab .frmsvg{height:22px}.frm_payment_settings_tab[for=frm_toggle_paypal_settings] .frmsvg{width:83px}.frm_payment_settings_tab[for=frm_toggle_authorize_net_settings] .frmsvg{width:99px}.frm_payment_settings_tab[for=frm_toggle_square_settings] .frmsvg{width:89px}.frm_payment_settings_tab[for=frm_toggle_stripe_settings] .frmsvg{width:53px}.frm-email-style{float:left;margin-right:var(--gap-md)}.frm-email-style:last-of-type{margin-right:0}.frm-email-style__card{position:relative}.frm-email-style__name{margin-top:var(--gap-xs);padding-top:var(--gap-2xs);text-align:center}.frm-email-style__name .frmsvg{vertical-align:sub}.frm-email-style__click{display:block;border-radius:12px;border:1px solid var(--grey-200);box-shadow:0 .47px .94px 0 rgba(16,24,40,.0588235294)}.frm-email-style__click:focus,.frm-email-style--selected .frm-email-style__click{border-color:var(--primary-500);outline:1px solid var(--primary-500)}.frm-email-style__click img{width:160px;display:block}.frm-email-style--disabled .frm-email-style__click::after{content:"";display:block;position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--grey-100);opacity:.5}.frm-email-style__buttons{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;display:none;flex-direction:column;justify-content:center;align-items:center;gap:12px}.frm-email-style__button{cursor:pointer;display:block}.frm-email-style__button:disabled{cursor:not-allowed;display:none;background:var(--primary-700) !important;border-color:var(--primary-700) !important}.frm-email-style--selected .frm-email-style__button:disabled{display:block}.frm-email-style--selected .frm-email-style__button[data-action=choose]{display:none}.frm-email-style--disabled .frm-email-style__button[data-action=choose]{display:none}.frm-email-style:hover .frm-email-style__buttons,.frm-email-style__click:focus+.frm-email-style__buttons,.frm-email-style:focus-within .frm-email-style__buttons{display:flex}#frm-send-test-email,.frm-upload-image-btn,.frm-remove-image-btn,.frm-reset-colors-btn{cursor:pointer}#frm-send-test-email-modal .postbox{padding:var(--gap-sm) var(--gap-md)}#frm-send-test-email-modal .postbox *{box-sizing:border-box}#frm-send-test-email-modal .inside{margin:0;padding:0}.frm-lite .xml_opts .frm-export-xml-items{display:none}.csv_opts #frm_csv_col_sep{width:45px}#frm_advanced td.frm_left_label{width:20%;padding-right:2px}#frm_where_options select{max-width:200px}#frm_where_options select.frm_insert_where_options{width:30%}#frm_where_options select.frm_where_is_options{width:20%}#frm_where_options span.frm_where_val{width:32%;display:inline-block;position:relative}#frm_where_options span.frm_where_val .frm_tooltip_icon,#frm_where_options span.frm_where_val .frm_help{left:-4px;position:absolute}#frm_where_options span.frm_where_val.frm_hidden{display:none}#frm_where_options span.frm_where_val input,#frm_where_options span.frm_where_val select{width:90%;margin-left:10px}#frm_where_options{min-height:31px}.tabs-panel.active .tabs-panel,.frm_settings_form .tabs-panel .tabs-panel{border:none;padding:0}.frm-feature-banner{background:var(--grey-700);color:#fff;border-radius:var(--small-radius);padding:20px;margin:10px 0}.frm-feature-banner p{font-size:var(--text-sm)}.frm-feature-banner .dismiss{margin-top:-10px;margin-right:-10px}.frm-feature-banner .dismiss svg{color:#fff}.frm-feature-banner .frm-big-icon{padding-right:20px;float:left;min-height:60px}.frm-big-icon svg{height:60px;width:60px}.frm-feature-banner p{margin-top:0}.frm_98_width{width:100% !important}h2.frm-h2,.frm_form_settings h2{border-bottom:1px solid var(--grey-300);color:var(--grey-900);font-weight:400 !important;padding:9px 0 5px;margin:0}.frm_settings_form h3,.frm_form_settings h3,.frm_form_settings span.frm_add_logic_link{font-size:var(--text-md);border-top:1px solid var(--grey-300);padding-top:var(--gap-sm);margin:var(--gap-sm) 0;font-weight:400;text-transform:uppercase;color:var(--medium-grey);display:block}.frm_form_settings .howto{color:var(--grey-500);font-size:var(--text-sm);margin-top:8px}.frm_form_settings .advanced_settings .form-table{margin-top:0}.frm_form_settings td.frm_175_width{width:175px}.frm_form_settings #success_url{width:95%}.frm_wrap .ui-autocomplete{padding:3px 0;max-height:310px}.frm_wrap .ui-widget{font-family:inherit}.frm_wrap .ui-autocomplete li{padding:2px 4px;background:none;color:var(--grey-700);border:none;font-weight:400}.frm_wrap .ui-autocomplete .ui-menu-item-wrapper.ui-state-active{border:none;font-weight:inherit}.frm_select_with_label{margin:7px 0 0}#frm-insert-fields-box,#frm-conditionals{max-height:none}#frm-conditionals,#frm-adv-info-tab{display:none;max-height:355px}#frm-insert-fields-box ul.subsubsub,#frm-conditionals ul.subsubsub{float:right;margin:0}#frm-insert-fields-box ul.alignleft,#frm-conditionals ul.alignleft{margin:4px 0 0}#frm_adv_info ul.frm_code_list.frm-full-hover{clear:both;max-height:215px;overflow:auto}#frm-insert-fields-box ul.frm_code_list li.clear.frm_block{height:10px}#frm_adv_info .frm_noallow{display:none}#frm_adv_info #frm-conditionals .frm_noallow{display:block}#frm_html_tab.frm_hidden{display:none}#frm_html_tab.active{display:inline}.frm_email_reply_container select,.frm_email_reply_container input,.form-table td.frm_150_width{width:170px}#frm_notification_settings .frm_no_top_padding{padding-top:0}.frm_email_settings.frm_email_settings.widgets-holder-wrap{overflow:auto;box-shadow:none}#frm_notification_settings .widget-top .widget-action,#frm_form_editor_container .widget-top .widget-action{border:0;margin:0;padding:8px;background:0 0;cursor:pointer;outline:0}#frm_notification_settings .widget-top .widget-action{padding-top:13.5px}#frm_email_addon_menu{border:1px solid var(--grey-300);padding:var(--gap-sm);border-radius:4px;margin:var(--gap-md) 0 var(--gap-sm)}#frm_email_addon_menu .frm-search{float:right;margin:0}#frm_email_addon_menu h3.frm-no-border{clear:none;padding-top:7px}.frm_email_settings .widget .widget-top{background-color:var(--sidebar-color)}.frm_email_settings .widget .widget-top,.frm_email_settings .widget .widget-top h3{cursor:pointer !important}.frm_email_settings .widget{margin-bottom:var(--gap-sm)}.frm_form_action_settings .widget-top{box-shadow:none;border-color:var(--grey-300);border-radius:var(--small-radius);background:var(--lightest-grey);color:var(--grey-700)}.frm_form_action_settings:hover .widget-top{border-color:var(--grey)}.frm_form_action_settings.open .widget-top{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}.frm_form_action_settings.open:hover .widget-top{border-color:var(--grey-300)}.frm_form_action_settings>.widget-inside{display:none}.frm_form_action_settings.open>.widget-inside{display:block}.frm_form_action_settings .widget-inside{min-height:25px;padding:15px;border-color:var(--grey-300);border-bottom-left-radius:4px;border-bottom-right-radius:4px}.frm_form_action_settings .widget-title h4,.frm_form_action_settings .widget-title h3{display:inline-block;border-bottom:none;padding:10px 10px 5px;font-size:var(--text-md);font-weight:500}#frm_email_addon_menu h3{margin:0 0 var(--gap-sm);clear:both}.frm_single_api_settings p>label{display:inline}.frm_form_action_icon{margin-right:5px}.frm_actions_list{margin:0;display:inline}.frm_actions_list li{float:left;width:15.6%;margin:10px .5% 15px;height:100px;text-align:center}.frm-limited-actions .frm-group-heading,.frm-limited-actions #frm-hide-groups,.frm-all-actions #frm-show-groups,.frm-limited-actions .frm-not-installed:not(.frm-search-result):not(.frm-default-show){display:none}label.frm_action_events{padding-left:15px}#frm-hide-groups,#frm-show-groups{font-size:var(--text-md);float:right}.frm_actions_list a:active,.frm_actions_list a:focus{outline:none}.frm_actions_list a{font-size:var(--text-sm);color:var(--grey-700);word-break:break-word}.frm_actions_list span.frm-outer-circle{background-color:var(--grey-100);padding:10px;text-align:center;border-radius:50%;display:block;width:30px;height:30px;margin:0 auto 15px;line-height:1;box-sizing:content-box}.frm_email_settings .widget-title h4{color:var(--grey-700)}.frm_disabled_action .widget-title h4{color:var(--grey)}.frm_actions_list a .frmsvg,.frm_actions_list a i{height:18px;width:18px;font-size:18px;padding:2px;color:var(--lightest-grey);box-sizing:content-box}span.frm-inner-circle,.frm_email_settings .widget-title .frm_form_action_icon{background-color:var(--grey-400);border-radius:50%;display:inline-block;text-align:center;line-height:1}span.frm-inner-circle{background-color:var(--primary-700);height:22px;width:22px;padding:4px;color:#fff;box-sizing:content-box}.frm-inner-circle svg{fill:currentColor}.frm_email_settings .widget-title .frm_form_action_icon{height:15px;width:15px;padding:5px;color:#fff;vertical-align:middle}.frm_actions_list .frmsvg,.frm_actions_list i::before,.frm_email_settings .widget-title .frm_form_action_icon i,.frm_email_settings .widget-title .frm_form_action_icon .frmsvg{height:15px;width:15px;vertical-align:text-top}.frm_actions_list i::before{vertical-align:middle}.frm_email_settings .widget-title:hover .frm_form_action_icon{background-color:var(--grey)}span.frm-inner-circle.frm-inverse{background-color:rgba(0,0,0,0);color:var(--primary-700);padding:0;height:30px;width:100%}.frm_actions_list span.frm-inverse i,.frm_actions_list span.frm-inverse .frmsvg{color:var(--primary-700);height:30px;width:30px;font-size:30px;padding:0}.frm_actions_list i.frm-inverse::before{height:30px;width:100%;font-size:30px}.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse{background:#fff;padding:0;height:24px;width:24px}.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse .frmsvg,.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse i::before{color:var(--grey-400);height:24px;width:24px;font-size:24px}.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse .frmsvg,.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse i::before{color:var(--grey-500)}.frm_email_icons{padding:10px 0 5px 6px;font-size:20px}.frm_email_icons a{margin-left:8px;color:var(--grey);opacity:0;transition:all .2s ease}.frm_email_icons a .frmsvg{color:var(--grey)}.frm_email_icons a:hover,.widget-top:hover .frm_email_icons a{opacity:1}.frm_actions_list a.frm_inactive_action{color:var(--grey)}.frm_inactive_action .frm-inner-circle,.frm_actions_list .frm_inactive_action i{opacity:.4}table td,.form-table tr td{vertical-align:top}#new_fields .form-table tr td{display:block;padding:7px 0 0}#new_fields .form-table tr td:first-child{margin:0}#new_fields .form-table tr td:last-child{margin-bottom:9px}.form-table #list-table th{text-align:center}#form_settings_page th,#form_settings_page td,.frm_settings_form td,#frm_notification_settings .frm_form_action_settings td p{padding:7px 0}#permissions_settings_settings .frm_grid_container{align-items:center}#frm_notification_settings .form-table>tbody>tr>th{width:150px;font-weight:400;padding-right:10px}#frm_notification_settings .frm_single_email_settings .form-table>tbody>tr>th{width:80px}#frm_notification_settings table tr td:first-child{padding-left:0}#frm_notification_settings table tr td:last-child{padding-right:0}#frm_notification_settings .frm_left_label{float:none;width:auto !important}.frm-fields .frm_autoresponder_rows select{width:auto}#frm_notification_settings .frm_with_left_label,#frm_notification_settings .frm_left_label+textarea,#frm_notification_settings .frm_left_label+select,#frm_notification_settings .frm_left_label+input[type=text]{width:100%}#frm_notification_settings .frm_email_buttons{padding:var(--gap-2xs);background:var(--light-blue);color:var(--primary-700);border-radius:var(--small-radius);border-color:var(--blue-border);line-height:1;height:auto;min-height:12px;font-size:var(--text-xs);box-shadow:none}p.frm_bcc_cc_container,p.frm_reply_to_container{position:relative;float:right;margin:-4px 0 0;z-index:1}.frm_email_row .frm_cancel1_icon::before{vertical-align:bottom}.frm_cc_row.frm_email_row .frm-with-right-icon,.frm_bcc_row.frm_email_row .frm-with-right-icon,.frm_reply_to_row.frm_email_row .frm-with-right-icon{width:calc(100% - 20px);display:inline-block}.frm_email_row .frm_remove_field .frm_close_icon{position:relative;fill:var(--grey-500);vertical-align:middle}.frm-inline-select,p.frm-inline-select,.frm_logic_rows .frm-collapse-me{line-height:var(--h-md) !important}.frm_logic_row{padding:var(--gap-xs) 0 0}.frm-single-settings ul.frm_sortable_field_opts{border-bottom:1px solid var(--grey-200);padding-bottom:var(--gap-xs);margin-bottom:var(--gap-xs)}.frm-single-settings .frm-add-other svg.frm_add_tag{position:relative;top:5px;margin-right:4px}.frm-single-settings .frm_single_option .frm_remove_tag::before{content:""}.frm-single-settings input[type=checkbox][readonly]{opacity:.5;pointer-events:none}.advanced_settings .frm_logic_row{margin:14px 0}.advanced_settings .frm_logic_row select,.advanced_settings .frm_logic_row input{max-width:30% !important}.frm_form_action_settings .frm_logic_row p{margin-top:0;margin-bottom:0;padding:0}#poststuff .widgets-holder-wrap .frm_form_action_settings .widget-inside{padding-bottom:0}#poststuff .frm_form_settings .widgets-holder-wrap .widget-inside{padding-left:15px;padding-right:15px}#form_global_settings h3{font-size:var(--text-sm);margin-top:25px}#form_global_settings .tabs-panel+h3{margin-top:0;border:none}#poststuff .frm_form_settings .widget-inside h3,#poststuff .frm_form_settings .advanced_settings h3,#poststuff .frm_settings_form h3,#frm_advanced .inside h3{border-top:1px solid #eee;border-bottom:none;margin:15px -15px 0;padding:8px 15px;font-size:var(--text-sm)}#poststuff .frm_form_settings h3.frm_first_h3,#poststuff h3.frm_first_h3{border:none;margin-top:0}h3.frm_add_logic_link{margin-bottom:0 !important}a.frm_add_logic_link.frm_hidden{display:none}a.frm_add_logic_link.frm_hidden+.frm_logic_rows{height:auto}.frm_icon_font{color:#a0a0a0;color:var(--grey)}.frm-fields label .frm_icon_font{font-size:inherit}.misc-pub-revisions.frm_icon_font,.misc-pub-revisions.frm_icon_font:hover{color:inherit}.postbox.frm_with_icons .inside{padding:0;margin:0}.frm_add_tag::before{content:"\e602"}.frm_remove_tag::before{content:"\e600"}.frm_logic_row .frm1>.frm_remove_tag{padding:0}.frm_tooltip_icon::before{font-size:13px;vertical-align:top}.frm_help svg,.frm_help .frmsvg{height:13px;width:13px;vertical-align:top;color:var(--grey-400)}.form-field input[type=text].frm_other_input{width:30%;margin-left:10px}.frm-add-other{text-align:right}.frm-add-other .frm_add_tag{vertical-align:20%}.frm_action_icon{margin:5px 0 0 5px}span.frm_action_icon{margin:0 4px 0 0}.frm_action_icon:active{outline:none}a.frm_action_icon:hover{text-decoration:none}.frm_action_icon.frm_error_icon::before{content:"\e608"}.frm_inactive_icon.frm_action_icon.frm_error_icon::before{content:"\e606"}.frm-field-action-icons{text-align:right;position:absolute;top:2px;right:2px;max-width:100%}.frm-field-action-icons .frm-field-id{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:80px;max-width:calc(100% - 50px);position:relative;top:2px}.frm-field-action-icons>a{font-size:var(--text-md);width:17px}.frm-field-action-icons a:hover{text-decoration:none}.frm-field-action-icons .dropdown{display:inline-block}.frm-field-action-icons>a .frmsvg{color:var(--grey-500) !important;font-size:17px;width:17px;height:17px}.frm-field-action-icons>a .frmsvg,.frm-field-action-icons>div>a .frmsvg{vertical-align:baseline}.edit_field_type_end_divider .frm-field-action-icons{display:none !important}.frm-move{cursor:grab}span.howto{display:inline}.frm_import_message{margin:15px 0;line-height:2.5}.frm_sorting .form-field .widget input[type=text],.frm_sorting .form-field .widget input[type=number],.frm_sorting .form-field .widget select,#wpcontent .frm_sorting .form-field .widget select,.frm_sorting .form-field .widget textarea{width:auto}.tagchecklist span.no_taglist{display:inline;float:none;line-height:15px;margin-right:0;font-size:inherit}.tagchecklist .frm_exclude_cat_list span{display:inline}.tagchecklist span a::before{line-height:23px;text-align:start}.frm_form_action_settings .frm_email_row .frm_tooltip_icon{position:relative;bottom:2px}.frm_no_entries_form{padding:60px 0}.frm_no_entries_form .frm_no_entries_header{font-size:20px;margin-bottom:10px}.frm_no_entries_form .frm_no_entries_text{line-height:var(--leading)}#form_entries_page #the-list .no-items{height:240px}#form_reports_page img.frm_no_reports{max-width:100%}.frm_wrap .google-visualization-table .gradient,.frm_wrap .google-visualization-table-tr-head,.frm_wrap .google-visualization-table-tr-odd,.frm_wrap .google-visualization-table-tr-odd.google-visualization-table-tr-over{background:var(--lightest-grey)}.frm_wrap .google-visualization-table-tr-over{background:#fff}.frm_wrap .google-visualization-table-table th,.frm_wrap .google-visualization-table-table td{border-right-width:0;padding:10px !important}.frm_wrap .google-visualization-table-tr-head,.frm_wrap .google-visualization-table-tr-head th{white-space:pre-wrap;font-size:var(--text-md);font-weight:400 !important;text-align:left}.frm_wrap .google-visualization-table-td-number{text-align:inherit}#form_reports_page .postbox{text-align:center;float:none;display:inline-block;margin-right:2%;width:20%;min-width:175px}#form_views_page img.frm_no_views{max-width:100%}.frm_field_opts_popup{min-width:300px;background-color:#fff}.frm_field_opts_popup #wpadminbar{display:none}.frm_prepop{width:100%;list-style:none;overflow:auto;margin:0;max-height:295px}.frm_prepop li{margin:0}.frm_prepop li a{display:block;text-decoration:none;cursor:pointer;padding:5px 20px}.frm_prepop li a:hover{background:var(--sidebar-color)}#frm_form_editor_container #frm_form_key_box{width:13em;max-width:30%}#frm_form_editor_container #frm_form_desc{width:70%}#frm_form_editor_container .ui-widget-content{display:none;padding:15px}#frm_form_editor_container .ui-widget-content label{float:left;width:170px;text-align:right;padding-right:5px;clear:both}#frm_form_editor_container .ui-widget-content label.nofloat{clear:none;float:none;margin-left:10px}#frm_form_editor_container .ui-state-default{color:#333 !important}.frm_green{color:var(--green) !important}#frm_form_editor_container .ui-state-default a.frm_orange,.frm-right-panel a.frm_orange,#postbox-container-1 a.frm_orange{color:#d54e21}#styling_settings input[type=checkbox],#styling_settings input[type=radio]{border:solid 1px #bbb}#styling_settings .widget .widget-top,#frm_form_editor_container .widget .widget-top{cursor:pointer}.frm_sorting .widget,.frm_settings_page .widget{background:#fff}.frm_sorting .widget-title h4{font-weight:400}.frm_sorting .widget,#postbox-container-1 .widget,.frm-right-panel .widget,.frm_settings_page .widget{margin-bottom:0}.frm_settings_page .widget-inside{padding:0 5px 5px}.frm_sorting .widget,.widget-inside,.frm_sorting .form-field .widget{display:none}#frm-show-fields{min-height:350px;padding:0 0 35px;margin:0;position:relative}.frm-has-fields #frm-show-fields{min-height:50px}#frm_builder_page .frm-lite-credit-card-element,body.frm-admin-page-styles .frm-lite-credit-card-element{position:relative}#frm_builder_page .frm-lite-credit-card-element>div,body.frm-admin-page-styles .frm-lite-credit-card-element>div{position:absolute;top:calc(50% - 1px);transform:translateY(-50%);right:10px;color:#d0d4dd}#frm_builder_page #frm_field_group_controls{position:absolute;padding:5px;border-radius:4px 4px 0 0;text-align:right;box-sizing:border-box;right:0;top:-28px;height:28px;z-index:3}.frm-field-group-hover-target,.frm-has-open-field-group-popup,#frm_builder_page #frm_field_group_controls,.frm-selected-field-group{background:rgba(65,153,253,.04)}.frm-selected-field-group{position:relative}#frm_builder_page #frm_field_group_controls>span:first-child{margin-right:5px}#frm_builder_page #frm_field_group_controls svg{pointer-events:none}#frm_field_group_controls{visibility:hidden}.frm-field-group-hover-target #frm_field_group_controls{visibility:visible}#frm_field_group_controls .dropdown-item a span{color:var(--grey-700)}#frm_field_group_controls .dropdown-item a:hover{text-decoration:none}.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider{display:none !important}.frm-right-panel .ui-state-default,#postbox-container-1 .ui-state-default,.frm_sorting>li.ui-state-default,.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover{border:1px solid rgba(0,0,0,0);font-weight:400 !important;background-color:rgba(0,0,0,0);background-image:none;padding:5px;margin:0;box-shadow:none;display:block;text-align:inherit !important;overflow:visible;position:relative}#frm-show-fields li.frm_cancel_sort{display:none}.divider_drop{text-align:center}.divider_drop .howto .frm_icon_font{font-style:normal}.show_repeat_sec{display:none}.repeat_section .show_repeat_sec{display:inline-block;margin:5px 0 0}.repeat_section tr.show_repeat_sec{display:table-row}.repeat_format .frm_repeat_label,.repeat_formattext .frmsvg,.repeat_formattext i{display:none}.frm_button{text-decoration:none;border:1px solid #eee;padding:5px;color:#444;vertical-align:middle;box-shadow:none !important}a.frm_button:hover{text-decoration:none !important}.frm_button,.frm_button .frm_icon_font::before{font-size:13px;vertical-align:middle}.frm_button .frmsvg{width:13px;height:13px}.frm-right-panel .ui-state-default,#postbox-container-1 .ui-state-default{padding:0;margin:0}ul.start_divider{padding:8px 13px 0 8px;min-height:115px;transition:all .4s linear}.frm-section-collapsed .frm_no_section_fields,.frm-section-collapsed ul.start_divider{height:0;min-height:0 !important}.frm-section-collapsed ul.start_divider{overflow:hidden}.frm-section-collapsed .frm_no_section_fields{overflow:hidden;padding:0;opacity:0}.frm-section-collapsed .divider_section_only .frm-collapsed-label{display:inline}.frm-page-collapsed .frm_clone_icon,.frm-page-collapsed .frm_delete_field,.frm-page-collapsed .frm_clone_field,.frm-section-collapsed .frm_clone_icon{opacity:.5;cursor:not-allowed}.edit_field_type_summary .frm_more_options_li:nth-child(2){display:none !important}.edit_field_type_submit .frm_more_options_li:not(:last-child){display:none !important}.frm_no_section_fields:not(.frm_block)+ul.start_divider{padding:0;min-height:132px}.frm_sorting li.ui-state-default .divider_section_only{padding:6px;margin-top:-10px;border:2px solid rgba(0,0,0,0);border-radius:var(--small-radius);z-index:2;position:relative}.divider_section_only>.frm_inner_field_container{padding:5px 0;margin:0}.frm-collapsed-label,.divider_section_only>.frm_inner_field_container .frm_form_fields{display:none}.frm-section-collapsed .divider_section_only::after,.divider_section_only::before{content:"";display:block;padding:2px 0;line-height:1px;border-top:2px solid var(--grey-300);top:-2px;position:absolute;width:100%;transition:.5s border-color ease-in-out}.frm-section-collapsed .divider_section_only::after{top:auto;bottom:-6px}.frm-section-collapsed .divider_section_only:hover::after,li.selected.frm-section-collapsed .divider_section_only::before,li.selected.frm-section-collapsed .divider_section_only::after,.divider_section_only:hover::before,li.selected .divider_section_only::before{border-color:rgba(0,0,0,0)}.frm_sorting li.ui-state-default.edit_field_type_divider{overflow:visible;position:relative;padding:0 0 0 20px;margin:25px 0 0 -5px;border-left:1px solid var(--primary-700);transition:border .7s ease-out}.frm-section-collapsed{border-left-color:rgba(0,0,0,0) !important}.frm_sorting li.edit_field_type_end_divider,.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover{margin:0 0 var(--gap-sm)}.frm-first-page .frm_prev_page{display:none}#frm_builder_page .frm_remove_form_row.frm_button,#frm_builder_page .frm_add_form_row.frm_button{border-radius:var(--small-radius);border:1px solid var(--blue-border)}#frm_builder_page .frm_remove_form_row .frmsvg,#frm_builder_page .frm_remove_form_row i::before,#frm_builder_page .frm_add_form_row .frmsvg,#frm_builder_page .frm_add_form_row i::before{color:var(--primary-700)}.frm-preview-buttons .frm_button_submit{margin:0 5px}.frm-page-break{border-top:1px dashed var(--primary-700);margin-top:var(--gap-lg);position:relative}.frm-page-break::before,.frm-page-break::after{content:"";position:absolute;background-color:#fff;border-radius:50%;border:1px solid var(--primary-700);text-rendering:auto;-webkit-font-smoothing:antialiased}.edit_field_type_divider .frm-divider-icon.frmsvg{padding:2px;position:absolute;left:-12px;color:#fff;background-color:var(--primary-700);border-radius:50%}.edit_field_type_divider .start_divider .frm-divider-icon.frmsvg{height:8px;width:8px;padding:0;bottom:-4px;left:-24.5px;color:var(--primary-700);background-color:#fff}.edit_field_type_divider.selected .frm-divider-icon.frmsvg,.edit_field_type_divider:hover .frm-divider-icon.frmsvg{background:var(--primary-500)}.edit_field_type_divider.selected .start_divider .frm-divider-icon.frmsvg,.edit_field_type_divider:hover .start_divider .frm-divider-icon.frmsvg{background-color:#fff;color:var(--primary-500)}.frm-page-break::before,.frm-page-break::after{width:8px;height:8px;top:-6px;border-color:var(--grey)}.frm-page-break::after{right:0}#frm-fake-page .frm-page-break{border-color:var(--grey)}#frm-fake-page{padding:0 5px}.frm_sorting li.edit_field_type_divider:hover,.frm_sorting li.edit_field_type_divider.selected{border-left-color:var(--primary-500)}.frm-section-collapsed::after{border-color:rgba(0,0,0,0) !important;color:rgba(0,0,0,0)}.frm-page-break .frm-collapse-page.button{margin-left:46%;margin-top:-16px;padding:6px 12px !important}#frm-fake-page.frm-page-collapsed{margin-bottom:0}.frm-page-collapsed{position:relative;overflow:visible !important;margin-bottom:var(--gap-lg)}.frm-collapse-page .frmsvg,.frm-collapse-page .frm_arrowdown6_icon{width:var(--text-sm);height:var(--text-sm);font-size:var(--text-sm);text-align:center;margin-left:2px;color:currentColor;transition:transform 300ms ease-in-out}.frm-page-collapsed .frm-collapse-page .frmsvg{transform:rotate(180deg)}#frm-fake-page .frm_arrowdown6_icon{color:currentColor}.frm-collapsed i::before,.frm-page-collapsed .frm_arrowdown6_icon::before{content:"\e913"}.frm-collapse-section svg{fill:var(--primary-color);transition:transform .2s ease-out,fill .2s ease-out}.frm-collapse-section:hover svg{fill:var(--primary-700)}.frm-section-collapsed .frm-collapse-section svg{transform:rotate(-90deg)}.open .widget-top .widget-title-action button .frmsvg{transform:rotate(90deg)}.widget-top .widget-title-action button .frmsvg use{color:var(--grey)}.frm-collapsed+.frm-collapse-me{overflow:hidden !important}.frm-collapse-me{padding-bottom:10px}.frm-collapse-me.frm_grid_container:has(.dropdown-toggle.multiselect){position:relative;z-index:1}.frm-collapsed+div{height:0;padding:0}.frm-collapsed+div.frm-collapse-me{display:none}.frm-collapsible{display:flex;justify-content:space-between;align-items:center;font-weight:700;padding:var(--gap-xs) 0;margin:0;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.frm-collapsible.frm-collapsed{font-weight:400}.frm-collapsible:not(.frm-collapsed) .frmsvg{transform:rotate(-180deg)}h4.frm-collapsible{font-size:var(--text-md)}.frm-collapsible+.frm-collapse-me{padding-bottom:0}.frm-collapsible:focus-visible{outline:1px solid var(--primary-500)}.frm_sorting .divider_section_only>.frm_ipe_field_label{font-size:116%}#frm_form_editor_container .edit_field_type_break .frm_primary_label.frm_ipe_field_label.button{width:150px;text-align:center;margin-bottom:3px;display:block}tr.frm_options_heading td{padding-bottom:0}.frm_sorting .widget-inside .form-table td p,.frm_sorting .widget-inside .form-wrap label{padding:10px 0}.frm_no_fields,.frm_no_section_fields{text-align:center;position:absolute;color:var(--medium-grey);font-size:var(--text-md);box-sizing:border-box;border:1px dashed var(--grey-300);outline:2px solid rgba(0,0,0,0)}.frm-over-droppable+.frm_no_fields{border-style:solid;border-color:var(--primary-500);outline-color:var(--primary-500)}.frm_no_section_fields{display:none;margin:0;padding:20px 0 0;width:calc(100% - 20px);height:121px;transition:all .4s linear}.frm-empty-fields .frm_updated_message~.frm_no_fields{top:60px}#frm_form_editor_container:not(.frm-has-fields) #frm-show-fields>.frm_field_box:last-child{visibility:hidden}.frm-has-fields .frm_no_fields{display:none}#frm_form_editor_container:not(.frm-has-fields) #frm_drag_placeholder{display:none}#frm-form-button{display:none;margin:0 7px 25px}.frm-has-fields #frm-form-button{display:block}.frm-large-plus.frmsvg{color:var(--primary-700);height:45px;width:45px}.frm_no_section_fields p{color:var(--grey);font-size:15px}.frm_no_fields{top:0;width:calc(100% - 24px);min-height:320px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--gap-md);padding:var(--gap-md);border:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Crect width='99%25' height='99%25' fill='none' stroke='%23D0D5DD' stroke-width='1' stroke-dasharray='8,8' rx='8' ry='8' x='0.5%25' y='0.5%25' stroke-linecap='square' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");border-radius:var(--medium-radius);margin:var(--gap-sm) 12px}.frm_no_fields img{margin-left:calc(-1*var(--gap-lg))}.frm_no_fields .frm_drag_inst{font-size:20px;font-weight:600;margin:0 0 12px}.frm_no_fields p{color:var(--grey-600);font-size:var(--text-md);margin:0}.frm_product_price_wrapper{display:inline-block;vertical-align:middle}.frm_prod_type_single .frm_product_price_wrapper{width:100%}#new_fields .frm_product_price_wrapper input:first-child{width:60% !important;float:left}#new_fields .frm_product_price_wrapper input:nth-child(2){width:37% !important;float:right}li.frm_single_option{padding-bottom:var(--gap-sm);border-bottom:0}.frm_prod_type_single input[type=radio],.frm_prod_type_single .frm_drag_icon,.frm_prod_type_single .frm_sortable_field_opts li:nth-child(n+3),.frm_prod_type_single .frm_sortable_field_opts .frm_remove_tag,.frm_prod_type_single .frm_form_field:not(.frm_product_type):not(.frm_sep_val_product),.frm_prod_type_single .frm-bulk-edit-link,.frm_prod_type_user_def.frm_grid_container,.frm_prod_options_heading.frm_prod_user_def{display:none}.frm_prod_type_single .frm-ai-generate-options-modal-trigger{display:none !important}.frm_prod_type_single .frm_option_key{margin-left:0 !important}.frm_prod_type_single .frm_option_key input[type=checkbox]+input[type=text],.frm_prod_type_single .frm_option_key input[type=radio]+input[type=text]{margin-left:0 !important}.plugin-card-bottom .frm-trash{color:#a00}.frm-fields p>.frm_inline_label,.frm_inline_label{padding-left:3px;margin-right:12px;display:inline-block}.frm_left_label{clear:both;float:left;width:32% !important;margin-right:2% !important;line-height:2em}table td.frm_left_label{float:none;line-height:inherit;padding:5px 0 5px 2%}.frm_left_label.frm_alignright{padding-right:10px;text-align:right}.frm-fields .frm_left_label+textarea,.frm-fields .frm_left_label+select,.frm-fields .frm_left_label+input[type=text],.frm_with_left_label{width:66%}td.frm_left_label+td{width:66%;padding-top:0}#html_settings label{display:block}#html_settings .frm_field_html_box{width:100%}.frm-has-required .frm-required{color:var(--error-500)}ul.frm-category-tabs{margin-top:2px}.frm-category-tabs>li a,.frm-category-tabs>li a:active{outline:none;box-shadow:none;display:flex;gap:var(--gap-xs);align-items:center}.frm-category-tabs>li.active .frmsvg,.frm-category-tabs>li.active i,.frm-category-tabs>li.active span,.frm-category-tabs>li.active a{color:var(--primary-500)}.frm_wrap .manage-menus{margin-top:0;border:none;border-bottom:1px solid var(--grey-300);background:var(--lightest-grey)}.general_settings .postbox .manage-menus{border-top:none;border-left:none;border-right:none}.frm-postbox-no-h3{padding-top:10px}.frm-right-panel .ui-state-default,#postbox-container-1 .ui-state-default{color:var(--grey-900)}.no_repeat_section .frm_sorting>li.ui-state-default.edit_field_type_end_divider:hover{box-shadow:none}.frm-selected-field-group li.ui-state-default,.start_divider.frm_sorting li.ui-state-default.frm_not_divider.selected,.start_divider.frm_sorting li.ui-state-default.frm_not_divider:hover,.frm_sorting li.ui-state-default.frm_not_divider:hover,.frm_sorting li.ui-state-default.ui-sortable-helper,.frm_sorting li.ui-state-default.edit_field_type_divider .divider_section_only:hover,.frm_sorting .repeat_section li.ui-state-default.edit_field_type_end_divider:hover,.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only,.frm_update_msg,.frm_sorting li.ui-state-default.frm_not_divider.selected,.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only{border-color:var(--primary-500);transition:.5s border-color ease-in-out}.frm_sorting li.ui-state-default.frm_not_divider.selected{box-shadow:0 0 1px 0 var(--primary-500)}.frm_sorting li.ui-state-default{transition:.7s box-shadow ease-in-out,.7s height linear}.frm_sorting li.ui-state-default.frm-newly-added{box-shadow:inset 0 0 2px 1px var(--blue-border)}.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover{visibility:visible !important;display:inline !important}.edit_field_type_end_divider>label{display:none !important}.frm_email_actions.feature-filter{font-weight:700;border:1px solid #dfdfdf;background-color:#eee;padding:3px 5px 2px;font-size:var(--text-md);line-height:20px}.frm_update_msg{border-style:solid;margin:10px 0;color:#21759b;padding:8px 15px;border-radius:4px}.frm_update_msg.wrap{margin:10px 20px 0 2px}#frm-insert-fields-box .frm_update_msg{margin-right:.9em}.frm_update_msg a{font-weight:700}.widefat td{width:auto}.widefat .column-id{width:3.7em}.widefat .column-show_count{width:5em}.widefat .column-shortcode{width:9em}.toplevel_page_formidable .column-shortcode div{display:flex;gap:var(--gap-xs)}.widefat .column-entries,.widefat .column-link{width:10%;text-align:center}.widefat .column-form_key,.widefat .column-created_at{width:10%}.frm-white-body .search-box,.frm_wrap .frm-search{float:right;margin:0;clear:right}.frm-white-body .search-box,.frm-search{min-width:32%;position:relative;display:flex;gap:var(--gap-sm);align-items:center}.frm-inline-modal .frm-search,#frm_adv_info .frm-search{float:none;width:100%;clear:both;margin:var(--gap-xs) 0}.frm-button-group a{margin:0 7px !important}.frm_has_textarea .frm-with-right-icon{display:block}.frm-with-left-icon,.frm-with-right-icon{position:relative}i.frm-show-box,i.frm-show-inline-modal,.frm-with-left-icon i,.frm-with-right-icon i:not([class*=mce-]),.frmsvg.frm-show-box,.frmsvg.frm-show-inline-modal,.frm-with-left-icon .frmsvg,.frm-with-right-icon .frmsvg,.frm-search>.frmsvg,.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select){position:absolute;padding:0 14px;pointer-events:none;left:0;color:var(--grey-400);font-size:var(--text-xs)}.frm-search>.frmsvg,.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select){padding-left:var(--gap-xs);padding-right:var(--gap-xs)}.frm-search>.frmsvg{box-sizing:unset}.frm-with-right-icon .frmsvg,.frm-with-right-icon i:not([class*=mce-]){right:0;top:-3px;left:auto;padding:0 10px 0 5px}.frm_form_settings .frm-with-right-icon .frmsvg{top:0}.frm_form_settings .wp-editor-container .frm-with-right-icon .frmsvg,#frm_builder_page .wp-editor-container .frm-with-right-icon .frmsvg{top:auto;bottom:var(--gap-sm)}.frm_form_settings .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg,#frm_builder_page .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg{bottom:var(--gap-lg)}.frm_form_settings .frm_has_textarea .frm-with-right-icon .frmsvg{top:auto;bottom:6px}.frmsvg.frm-show-box,.frmsvg.frm-show-inline-modal,i.frm-show-box,i.frm-show-inline-modal{top:auto;background-color:var(--primary-50);color:var(--primary-500);border-radius:6px;padding:var(--gap-2xs);margin:5px;margin-bottom:0;z-index:1;cursor:pointer;pointer-events:initial}.frmsvg.frm-show-box:focus,.frmsvg.frm-show-inline-modal:focus,i.frm-show-box:focus,i.frm-show-inline-modal:focus{outline:1px solid var(--primary-500)}.frm_form_settings .frmsvg.frm-show-box,.frm_form_settings .frmsvg.frm-show-inline-modal,.frm_form_settings i.frm-show-box,.frm_form_settings i.frm-show-inline-modal{margin:4px 4px 0}.frm-open+.frm-inline-modal{top:-10px;margin-bottom:0}.frm-open+.frm-inline-modal.frm-modal-no-dismiss .inside>.frm-search:first-child{margin-top:var(--gap-sm)}.frm_grid_container>.frm-open+.frm-inline-modal{top:-4px}.frm_grid_container>.frm-open+.frm-inline-modal.frm-modal-no-dismiss{top:0 !important}.frm-with-left-icon input{padding-left:37px !important}.frm_wrap .frm-with-right-icon textarea,.frm_wrap .frm-with-right-icon input,.frm_wrap .frm-with-right-icon input[type=text]{padding-right:var(--gap-md)}#frm-show-fields .frm-with-left-icon .frmsvg,#frm-show-fields .frm-with-left-icon i{padding-top:10px}.frm-search input[name=s],.frm-search .dropdown-toggle,.frm-search input.frm-search-input{color:var(--grey-800);border-color:var(--grey-300);border-radius:var(--small-radius);box-shadow:var(--box-shadow-xs)}.frm-search input[type=search],.frm-search input[type=text]{padding-left:var(--gap-lg) !important}.frm-search .dropdown-toggle{width:100%;float:none;max-width:200px;background:rgba(0,0,0,0);padding:7px;padding-left:33px !important;min-height:32px;text-align:inherit;overflow:hidden;text-overflow:ellipsis}.frm-search #search-submit a{color:var(--grey-800)}.frm-search #search-submit .caret{opacity:.7}.frm-white-body .search-box input[name=s],#wpwrap .frm-search input[type=search]{flex:1;font-size:var(--text-md);line-height:var(--text-xl);padding:var(--gap-xs)}span.multiselect-selected-text{white-space:nowrap;display:inline-block;max-width:calc(90% - var(--gap-xs));text-overflow:ellipsis;overflow:hidden}.frm-not-set input{color:var(--primary-500) !important;font-size:13px}.frm-not-set .frmsvg,.frm-not-set i{color:var(--primary-700);opacity:1}.post-type-frm_display select[name=m]+#post-query-submit,select[name=m]{display:none}.frm_shortcode_select optgroup option{margin-left:1em}.frm_shortcode_select optgroup{padding-top:5px}.frm_shortcode_select .frm_subopt{margin-left:2em}.misc-pub-section a.edit-frm_shortcode,.misc-pub-section a.edit-form-status{float:none;font-size:13px}.frm-grid{border-collapse:collapse;border:none;margin-right:10px}.frm-grid td,.frm-grid th{padding:5px;border:1px solid #000}.post-type-frm_display #poststuff #post-body.columns-2{margin-right:var(--big-sidebar)}.post-type-frm_display #post-body.columns-2 #postbox-container-1{margin-right:calc(var(--big-sidebar)*-1);width:calc(var(--big-sidebar) - 40px)}.post-type-frm_display #poststuff #post-body.columns-2 #side-sortables{width:100%}#frm_dyncontent .hndle,#frm_dyncontent .handlediv{display:none !important}.post-type-frm_display .meta-box-sortables .frm_form_nav>li>a,.post-type-frm_display .frm_form_nav .nav-tab-active{padding:0 2px 5px;line-height:1.4}.post-type-frm_display #advanced-sortables h2.hndle,.post-type-frm_display #side-sortables h2.hndle,.post-type-frm_display #normal-sortables h2.hndle{border-bottom:1px solid var(--grey-300);margin:10px 0 0 !important;padding:0 25px 8px}.post-type-frm_display #side-sortables h2.hndle{margin-top:0 !important;padding-top:10px}.post-type-frm_display #post-body-content{margin-top:var(--gap-lg)}.post-type-frm_display.edit-php #wpbody-content>.wrap{margin:0}.post-type-frm_display .postbox .hndle,.post-type-frm_display .postbox{border-color:var(--grey-300)}.post-type-frm_display #postbox-container-1 .postbox,.post-type-frm_display #postbox-container-2 .postbox{border-radius:var(--small-radius);border-color:var(--grey-300);box-shadow:none}.post-type-frm_display #side-sortables .postbox{border-radius:0;border-top-width:0;margin-bottom:0}.post-type-frm_display #side-sortables .misc-pub-section{padding:15px 20px 10px}.post-type-frm_display .misc-pub-section .frmsvg,.post-type-frm_display #post-body .misc-pub-post-status::before,.post-type-frm_display #post-body #visibility::before,.post-type-frm_display .curtime #timestamp::before,.post-type-frm_display #post-body .misc-pub-revisions::before,.post-type-frm_display span.wp-media-buttons-icon::before{color:var(--grey)}.post-type-frm_display #frm_top_bar+#poststuff #submitdiv #publishing-action,.post-type-frm_display #frm_top_bar+#poststuff #submitdiv #minor-publishing-actions,.post-type-frm_display #frm_top_bar+#poststuff #edit-slug-box,.post-type-frm_display .wrap h1.wp-heading-inline,.post-type-frm_display .wrap>.page-title-action{display:none}.post-type-frm_display #poststuff h2.nav-tab-wrapper{padding-left:10px;margin-bottom:0;padding-bottom:0}.post-type-frm_display .nav-menus-php .wrap{margin:10px 0 0}.post-type-frm_display .nav-menus-php .wrap p{padding-left:12px;padding-right:12px}.post-type-frm_display .nav-tab{display:inline-block;background-color:#f4f4f4}.post-type-frm_display .nav-tab.frm_hidden{display:none}.post-type-frm_display .nav-tab:hover{background-color:#e4e4e4}.frm_order_row,.frm_where_row{margin-bottom:7px;line-height:30px}.frm-single-settings .frm_prod_field_opt_cont{margin-top:initial;margin-bottom:20px}select.texture{display:none}.post-type-frm_display #wp-content-editor-tools,#wp-content-editor-tools{background-color:rgba(0,0,0,0)}.post-type-frm_display #major-publishing-actions{border-color:var(--grey-300);background:var(--sidebar-color)}.post-type-frm_display #frm_adv_info{width:calc(var(--big-sidebar) - 40px);height:calc(100vh - 32px);overflow:hidden}.post-type-frm_display #frm_adv_info:not(.frm_fixed){top:0 !important}.post-type-frm_display #frm_adv_info.frm_fixed{position:fixed;z-index:9999;top:32px}.post-type-frm_display #frm_adv_info ul.frm_code_list.frm-full-hover{max-height:calc(100vh - 180px)}.frm_col_one{margin-right:4%;clear:both}ul .frm_col_one{float:left}ul .frm_col_two{float:right}ul.frm_two_col{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:var(--gap-sm)}.frm_two_col li{margin-bottom:0}.frm-info-modal a,.frm-info-modal ul,.frm-info-modal p,.frm-info-modal,.settings-lite-cta a,.settings-lite-cta ul,.settings-lite-cta{color:var(--grey-500);font-size:var(--text-md);box-shadow:none !important}.frm-info-modal h3,.settings-lite-cta h3{font-size:17px !important}.frm-green-icons .frmsvg{color:var(--green)}.frm-info-modal .postbox .inside,.settings-lite-cta .postbox .inside{padding:var(--gap-md);margin:0}.cta-inside a{color:var(--orange)}.info-modal-inside a.frm-standard-link{color:var(--primary-500)}.info-modal-inside a.frm-standard-link:hover{color:var(--primary-700)}.frm_no_p_margin>p{margin:0}.frm_code_list a.button{display:block;text-align:center;font-size:11px;overflow:hidden}#frm-navbarDrop+.frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0;min-width:300px;max-height:256px}.frm_code_list.frm-full-hover li{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu>.dropdown-item>a:visited,.frm-dropdown-menu>.dropdown-item>a:link,.frm-dropdown-menu .frm_dropdown_li,.frm_code_list.frm-full-hover a{display:flex;color:var(--grey-700);padding:5px 10px;font-size:var(--text-md);gap:var(--gap-xs);align-items:center}.multiselect-container button.multiselect-option.disabled{opacity:.5}.frm_code_list.frm-full-hover a span{max-width:83px;margin-right:var(--gap-xs);margin-left:auto}.frm_code_list.frm-full-hover a{border-radius:var(--small-radius)}.frm_code_list.frm-full-hover a:not(#frm-insert-condition),.frm_code_list.frm-full-hover a span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frm_code_list.frm-full-hover a:focus span:last-child{outline:1px solid var(--primary-500);outline-offset:var(--gap-2xs)}.frm_code_list.frm-full-hover.frmcenter a{display:block}#frm-layout-classes frm-full-hover a span{max-width:45%}.frm-select-list-item.active,.frm-select-list-item:hover,.frm_wrap .ui-autocomplete li div.ui-state-active,.frm_wrap .ui-autocomplete li.ui-state-focus,.multiselect-container button.multiselect-option.active,.multiselect-container button.multiselect-option:hover,.frm-dropdown-menu>.dropdown-item>a:hover,.frm_code_list.frm-full-hover a:hover span,.frm_code_list.frm-full-hover a:hover{background:var(--primary-25);color:var(--primary-500)}.frm-select-list-item .frmsvg,.frm-dropdown-menu>.dropdown-item>a .frmsvg{opacity:.8}.frm-select-list-item:hover .frmsvg,.frm-dropdown-menu>.dropdown-item>a:hover .frmsvg{opacity:1}.frm-dropdown-menu.frm_code_list>li>a{padding:3px 15px;width:300px}#frm_edit_box_content_modal .frm-with-search,.frm-dropdown-menu .frm-with-search{padding:var(--gap-xs) 10px 0}.frm-dropdown-menu .subsubsub{padding:0 10px}.frm_grid_container{overflow:visible}.frm_code_list.frm_grid_container{grid-gap:var(--gap-xs)}.frm_code_list.frm_grid_container li{width:auto;margin:0}.frm_code_list.frm_grid_container a{display:block;font-size:var(--text-md) !important;font-weight:500;text-align:center;color:var(--primary-500);background-color:var(--light-blue);border:1px solid var(--primary-300);border-radius:var(--small-radius);padding:10px 0;box-shadow:var(--box-shadow-sm)}.frm_code_list.frm_grid_container a:hover{background-color:var(--primary-500);color:#fff}.frm_code_list.frm_grid_container a:focus-visible{outline:2px solid var(--primary-500);outline-offset:-1px}.frm-single-settings .frm_code_list.frm-full-hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{padding:0;margin:var(--gap-xs) -10px 0}.frm-single-settings .frm_code_list.frm-full-hover>li>a,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a{font-size:var(--text-md);color:var(--grey-900);padding:var(--gap-xs) 12px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span{margin:0}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:first-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:first-child{max-width:130px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:last-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:last-child{max-width:120px;margin-left:auto}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover{font-weight:500}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover .frmsvg,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover .frmsvg,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover span{color:var(--primary-500)}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg{width:20px;height:20px}.frm_field_list #frm-insert-fields{max-height:none;font-size:var(--text-sm)}.frm_field_list #frm-insert-fields .button a{display:block;max-width:95%;overflow:hidden}#frm-insert-fields{padding:0 var(--gap-xs);overflow:hidden}#frm-insert-fields .frm-search{float:none;margin:0 0 var(--gap-md);width:auto}#frm-insert-fields li,#frm-insert-fields li a{text-decoration:none;font-weight:500;font-size:var(--text-md) !important;color:var(--grey-900)}#frm-insert-fields li.frm_show_upgrade{cursor:pointer;opacity:.5}#frm-insert-fields li.frm_show_update{cursor:pointer}#frm-insert-fields li span:not(.frm-new-pill){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}#frm-insert-fields li a.disabled:hover{cursor:not-allowed}#frm-insert-fields li.ui-draggable-disabled{opacity:.5}#frm-insert-fields li a:not(.disabled):hover .frmsvg,#frm-insert-fields li a:not(.disabled):hover i{color:var(--grey-600)}#frm-insert-fields li.frm_show_upgrade,#frm-insert-fields li.frm_show_update,#frm-insert-fields li a{text-decoration:none;display:inline-flex !important;gap:var(--gap-xs);align-items:center;border-radius:var(--small-radius) !important;padding:11px var(--gap-md) 11px var(--gap-xs) !important;color:var(--grey-900) !important}#frm-insert-fields li a{display:flex !important;transition:background-color .2s ease-out,box-shadow .2s ease-out}#frm-insert-fields li a:not(.disabled):hover{background:#fff;box-shadow:var(--box-shadow-md)}#frm-insert-fields li a:focus-visible{outline:1px solid var(--primary-500)}#frm-insert-fields li.frm_show_upgrade.frm_hidden,#frm-insert-fields li.frm_show_update.frm_hidden{display:none !important}#frm-insert-fields .frm-with-line{padding:12px var(--gap-md);font-weight:500;font-size:var(--text-sm)}#frm-insert-fields .frm-with-line::before{margin-left:calc(-1*var(--gap-sm));width:calc(100% + var(--gap-md))}.frm_code_list{clear:both}.frm_code_list.frm-full-hover a.frm_hidden,.frm_code_list .frmkeys{display:none}.frmsvg{fill:currentColor;width:18px;height:18px;vertical-align:middle}.frmsvg svg{pointer-events:none}.frmsvg.frm_svg40{width:40px;height:40px}.frmsvg.frm_svg24{width:24px;height:24px}.frmsvg.frm_svg20{width:20px;height:20px}.frmsvg.frm_svg15{width:15px;height:15px}.frmsvg.frm_svg14{width:14px !important;height:14px !important}.frmsvg.frm_svg13{width:13px;height:13px}.frmsvg.frm_svg12{width:12px;height:12px}.frmsvg.frm_svg9{width:9px;height:9px}.frmsvg.frm_svg7{width:7px;height:7px}input[disabled]{pointer-events:none}.frmbutton.ui-sortable-helper .frmsvg,.field_type_list li.frmbutton .frmsvg,.frmbutton.ui-sortable-helper i,.field_type_list li.frmbutton i,.frm_code_list a .frmsvg,.frm_code_list a i{color:var(--grey-500);display:inline-block;vertical-align:middle;width:var(--text-md);font-size:var(--text-md)}.field_type_list.frm_grid_container{gap:10px;margin:13px 0}.field_type_list li{margin:0;padding:0}.field_type_list li.frmbutton .frmsvg{width:24px;height:24px;font-size:24px}.frm_code_list i::before{font-size:inherit}.frmbutton.ui-draggable-dragging{pointer-events:none}.frmbutton.ui-draggable-dragging a{color:var(--grey-900) !important;background:var(--grey-100);text-decoration:none;display:inline-flex !important;gap:var(--gap-xs);align-items:center;border-radius:var(--small-radius) !important;padding:11px var(--gap-md) 11px var(--gap-xs) !important;box-shadow:var(--box-shadow-md)}.frmbutton.frm_at_limit{opacity:.5}.frmbutton.ui-draggable-dragging a{border:1px solid var(--grey-300);box-shadow:var(--box-shadow-md)}.frmbutton.ui-draggable-dragging span{font-size:15px}#frm-show-fields .frmbutton.ui-sortable-helper i,.frmbutton.ui-draggable-dragging i,.frmbutton.ui-draggable-dragging .frmsvg{color:#fff !important}.frmbutton.ui-draggable-dragging i,.frmbutton.ui-draggable-dragging .frmsvg{color:var(--grey-700) !important}.frm_sorting li.ui-state-default.ui-sortable-helper,.frmbutton.ui-sortable-helper{transition:opacity .2s;opacity:1;position:fixed;z-index:99999}#frm-insert-fields .frmbutton.ui-sortable-helper a,#frm-show-fields .frmbutton.ui-sortable-helper a{min-width:100px}.ui-draggable-dragging .frm-meta-tag.frm-new-pill{display:none}li.frm_noallow.button,.frm_noallow{opacity:.5}.frm_actions_list a.frm_show_upgrade.frm_inactive_action::before,li.frm_noallow.button.frm_show_upgrade,li.frm_noallow.button.frm_show_update{cursor:pointer}.field_type_list li.frm_noallow.button.frm_show_upgrade:hover,.field_type_list li.frm_noallow.button.frm_show_update:hover{border-color:inherit}.frm_noallow a{color:inherit}#frm_upgrade_modal_image{max-width:200px}#frm_upgrade_modal .cta-inside{display:flex;flex-direction:column;gap:var(--gap-sm)}#frm_upgrade_modal .frm-upgrade-message img{width:100%;margin:var(--gap-sm) 0 10px}#frm_upgrade_modal .frm-oneclick.frm_hidden{display:none !important}#frm_upgrade_modal .frm-oneclick-button{margin-left:auto}#frm_upgrade_modal .frm-upgrade-modal-actions{flex-direction:row-reverse;justify-content:flex-start;margin:0 !important}#frm_upgrade_modal .frm-upgrade-link{align-self:end}#frm_upgrade_modal.frm-success .frm-circled-icon svg{width:24px;height:24px}#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-prefix,#frm_upgrade_modal.frm-success .frm_are_not_installed{display:none !important}#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-suffix{display:inline !important}#frm_upgrade_modal.frm-success .frm-addon-status{margin:0}#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options{display:flex;gap:var(--gap-xs);flex-direction:row-reverse;margin:0}#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options .frm-save-and-reload{margin:0}.frm-dialog[aria-describedby=frm_upgrade_modal]{position:fixed !important;top:50% !important;left:50% !important;transform:translate(-50%, -50%) !important}.frm-tab-message{max-width:600px;margin:20px auto;color:rgba(63,75,91,.8)}.frm-settings-screenshot-toolbar{min-height:39px;display:flex}.frm-settings-screenshot-toolbar .frm-minmax-icon{height:8px;width:8px;border-radius:50%;align-self:center;margin-left:10px}.frm-settings-screenshot-toolbar .frm-minmax-icon:first-of-type{margin-left:20px}.frm-settings-screenshot-toolbar img{object-fit:contain;align-self:flex-end;margin-left:25px}.frm-settings-screenshot-toolbar+div{background:#fff;padding-top:25px;border-radius:0 0 16px 16px}.frm-settings-screenshot-toolbar+div img{max-width:calc(100% - 40px)}.frm-settings-screenshot-wrapper{max-width:700px;margin:50px auto 0;box-shadow:0 4px 4px rgba(189,196,205,.25),0 12px 56px rgba(42,57,75,.25);border-radius:16px;background:#ebecf1}.frm-dialog{z-index:100;padding:0 !important;border-radius:16px;border:none;background-color:#fff;max-width:100% !important}.frm-dialog .postbox{background:rgba(0,0,0,0);box-shadow:none;border:none;line-height:var(--leading)}.frm-dialog input[type=text],.frm-dialog textarea{font-size:var(--text-md)}.frm-dialog textarea{height:75px}.frm-dialog button.frm-button-primary{margin-right:10px}.frm-dialog .frm-sub-label,.frm-sub-label{color:var(--grey);text-transform:none;padding-left:8px}h2 .frm-sub-label{font-size:var(--text-md)}.frm-views-editor-body .ui-widget-overlay,.frm-white-body .ui-widget-overlay,.toplevel_page_formidable .ui-widget-overlay,body[class*=formidable-payments] .ui-widget-overlay,body.plugins-php .ui-widget-overlay{position:fixed;width:100%;height:100%;top:0;left:0;right:0;bottom:0;background:var(--grey-500);opacity:.5;z-index:2}.frm-circled-icon{width:60px;height:60px;border-radius:50%;background-color:var(--primary-25)}.frm-circled-icon-large{width:80px;height:80px}.frm-circled-icon-green{background-color:var(--success-50)}.frm-circled-icon .frmsvg{width:21px;height:24px}.frm-circled-icon .frmsvg.frm_svg32{width:32px !important;height:32px !important}.frm-circled-icon-large .frmsvg{width:24px}.frm-circled-icon .frmsvg use{color:var(--primary-500)}.frm-circled-icon-green .frmsvg use{color:var(--success-500)}.frm-border-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--grey-300);border-radius:var(--small-radius)}.frm-upgrade-message img{max-width:100%}a.frm-link-secondary{color:#c4c4c4;font-size:var(--text-sm);text-decoration:underline}.field_type_list li.button.frm_noallow,.field_type_list li.button.frm_noallow:hover,.button.frm_noallow,.button.frm_noallow:hover{color:inherit;border-color:#ccc;background:inherit}iframe#dyncontent_ifr{min-height:150px}/*! +/*!*********************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/admin/frm_admin.scss ***! + \*********************************************************************************************************************************************************************************************************************************/ +@charset "UTF-8"; +/** + * Formidable Admin Styles + * + * Note: Do not modify the import order unless the change is part of a deliberate refactor. + */ +/** + * Base & Foundation + * + * Core variables, typography, and essential base styles + */ +/** + * Font Icons + */ +@font-face { + font-family: "s11-fp"; + src: url("../fonts/s11-fp.woff?v=7") format("woff"); + font-weight: 400; + font-style: normal; +} +.frm-submenu-highlight { + background: #1da867; +} + +.frm-submenu-highlight a span { + color: #fff; + font-weight: 600; +} + +.frmfont, +.frm_icon_font { + text-decoration: none; + text-shadow: none; + font-weight: 400; + display: inline-block; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + text-rendering: auto; + line-height: 1.5; + transition: color 0.1s ease-in-out, opacity 0.1s ease-in-out; + font-size: 18px; +} + +i.frmfont, +i.frm_icon_font { + font-style: normal; + font-variant: normal; + speak: none; +} + +.frmfont::before, +select.frmfont, +.frm_icon_font::before, +select.frm_icon_font { + font-family: "s11-fp" !important; + text-align: center; +} + +.frmfont, +a.frmfont, +.frmfont:hover, +a.frmfont:hover .frm_icon_font, +a.frm_icon_font, +.frm_icon_font:hover, +a.frm_icon_font:hover { + text-decoration: none !important; + box-shadow: none; +} + +.frmfont:focus, +.frm_icon_font:focus { + box-shadow: none; +} + +.frmfont:active, +.frm_icon_font:active { + outline: none; +} + +.frm_trigger .frm_icon_font { + padding: 0 5px; +} + +.frm_tooltip_icon::before { + content: "\e611"; +} + +.frm_delete_icon::before { + content: "\e610" !important; +} + +.frm_arrowdown6_icon::before { + content: "\e62a"; +} + +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +/** + * Base - Font + */ +@font-face { + font-family: "Inter"; + src: url("../fonts/Inter-VariableFont_slnt,wght.ttf?v=1") format("truetype"); +} +.with_frm_style, +.frm-white-body .wpbody-content, +.frm_wrap { + font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; +} + +/* Safari 11+ */ +@media not all and (min-resolution: 0.001dpcm) { + @supports (-webkit-appearance: none) and (stroke-color: transparent) { + .with_frm_style, +.frm-white-body .wpbody-content, +.frm_wrap { + -webkit-font-smoothing: antialiased; + } + } +} +/** + * Utilities - Z-index + */ +.frm-sm-z-index { + z-index: 1; +} + +.frm-md-z-index { + z-index: 5; +} + +/** + * Base - Text + */ +.frm-white-body, +.frm-white-body p, +.frm_wrap, +.frm_wrap p, +.frm-modal, +.frm-white-body .postbox .inside { + font-size: var(--text-sm); + color: var(--grey-500); + line-height: var(--leading); +} + +.frm-white-body p, +.frm_wrap p { + margin: var(--gap-sm) 0; +} + +body:not(.frm-admin-page-styles):not(.frm-admin-page-style) .with_frm_style .frm_form_fields > fieldset { + --fieldset-padding: 15px 0; +} + +a, +.widget .widget-top, +.stuffbox h3, +.frm-collapsed { + cursor: pointer; + text-decoration: none; +} + +/** + * Layout & Primary Components + * + * Core structure and primary UI elements + */ +/** + * Layout - Wrap + */ +.post-type-frm_display .wrap > #posts-filter, +.wrap.frm-with-margin, +.frm_wrap > .wrap { + margin: var(--gap-sm) var(--gap-md) var(--gap-md); +} + +#frm_top_bar + .wrap { + margin: var(--gap-xl); +} + +.frm-full-screen #wpbody-content > .wrap { + margin: 0; +} + +.post-type-frm_display .wrap { + margin: 0; +} + +.toplevel_page_formidable #post-body-content { + overflow-x: visible; +} + +/** + * Components - Full Screen + */ +.frm-full-screen { + height: 100%; + overflow: hidden; +} + +.frm-full-screen.frm-admin-page-reports, +.frm-full-screen.frm-admin-page-entries, +.frm-full-screen.post-type-frm_display { + overflow: auto; +} + +.frm-full-screen #wpadminbar, +.frm-full-screen #adminmenumain, +.frm-full-screen .wp-header-end { + display: none; +} + +body.frm-white-body:not(.frm-full-screen) .mce-fullscreen { + top: 32px; + left: 160px; +} + +.frm-full-screen #wpbody-content, +.frm-full-screen #wpbody, +.frm-full-screen #wpcontent { + padding: 0; + overflow: hidden; + margin: 0 !important; +} + +/** + * Layout - Screen Meta + */ +.frm-white-body #wpbody-content { + position: relative; /* For screen meta links */ + padding-bottom: 0; +} + +.post-new-php.post-type-frm_display #screen-meta-links, +.post-php.post-type-frm_display #screen-meta-links { + display: none; +} + +.frm-white-body #screen-meta-links { + position: fixed; + bottom: 0; + right: 20px; +} + +.frm-full-screen #screen-meta-links .screen-meta-toggle { + right: 55px; +} + +.frm-white-body #screen-meta-links .show-settings { + border-radius: var(--small-radius) var(--small-radius) 0 0; + border: 1px solid var(--grey-300); + border-bottom: none; +} + +.frm-white-body.frm-lite #screen-meta-links .screen-meta-toggle { + right: 125px; /* Don't cover the lite upgrade button */ +} + +.frm-white-body #screen-meta { + margin: 0; +} + +.frm-white-body #screen-meta-links .show-settings::after { + color: var(--grey); +} + +/** + * Layout - Columns + */ +.frm-white-body .columns-2 { + border-bottom: 1px solid var(--grey-300); +} + +.frm-full-screen .columns-2 { + border: none; +} + +/** + * Layout - Body + */ +body.post-type-frm_display.edit-php, +body.frm-white-body { + background: #fff; +} + +body.frm-white-body ul#adminmenu a.wp-has-current-submenu::after, +body.frm-white-body ul#adminmenu > li.current > a.current::after { + border-right-color: #fff; +} + +.frm-white-body #wpcontent { + padding-left: 0; + padding-right: 0; +} + +.frm-white-body .wrap #post-body { + padding: 0 20px; +} + +.frm-grey-body #wpbody { + background: var(--grey-100); +} + +.frm-grey-body #frm_top_bar { + background: #fff; +} + +/** + * Components - Table Nav + */ +.post-type-frm_display .tablenav, +.frm_wrap .tablenav { + margin-bottom: 10px; +} + +.frm-white-body .tablenav .actions select, +.wp-admin .frm_wrap .tablenav select { + margin-right: var(--gap-xs); +} + +.tablenav .actions .button { + margin-top: 1px; +} + +/** + * Components - Table Widefat + */ +.frm-white-body table.widefat { + background: var(--lightest-grey); + border-width: 0; + box-shadow: none; + margin: 20px 0; +} + +.frm-white-body table.widefat tfoot, +.frm-white-body table.widefat thead { + background: #fff; +} + +.frm-white-body table.widefat th { + font-size: var(--text-md); +} + +.frm-white-body table.widefat th a { + color: var(--grey-700); +} + +.frm-white-body table.widefat strong a { + color: var(--primary-700); +} + +/** + * Components - Scroll Box + */ +.frm-scroll-box { + clear: both; + overflow: auto; + max-height: 405px; + border: 1px solid var(--grey-300); + border-radius: var(--small-radius); +} + +.frm_form_field.frm_scroll_box .frm_opt_container { + height: 100px; + overflow: auto; + border: 1px solid var(--grey-300); +} + +.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden) + p, +.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden) + div, +.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden) + span { + grid-column: span 6/span 6; + align-content: center; +} + +.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden) + p, +.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden) + div, +.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden) + span { + grid-column: span 12/span 12 !important; + align-content: center; +} + +.frm_form_field.frm-phone-type ~ [id*=frm-field-format-custom-] > label, +.frm_form_field.frm-format-dropdown ~ [id*=frm-field-format-custom-] > label { + opacity: 0; /* Hide the label for the format input in the phone field. */ +} + +.frm_form_field.frm-format-dropdown ~ [id*=frm-field-format-custom-] { + grid-column: span 6/span 6; +} + +/* Adjust "CSS Layout Classes" to full width when the "Format" setting is present. */ +.frm-single-settings.frm-type-textarea > .frm_grid_container [id*=frm-field-format-custom-] + p { + grid-column: span 12/span 12; +} + +.frm-single-settings .frm_grid_container { + column-gap: var(--gap-sm); +} + +.frm-content-center { + align-content: center; +} + +.frm-self-end { + align-self: end; +} + +/** + * Components - Short List + */ +.frm-short-list { + overflow: auto; + max-height: 190px; +} + +/** + * Components - Table Elements + */ +.frm-white-body table.frm-border td { + font-size: var(--text-sm); +} + +.frm-white-body .striped > tbody > :nth-child(odd) { + background-color: #fff; +} + +.frm_wrap td.column-title strong { + display: inline; +} + +/** + * Layout - Top Bar + */ +#frm_top_bar { + display: flex; + gap: var(--gap-sm); + width: 100%; + height: 72px; + margin: 0; + box-sizing: border-box; + text-align: center; + padding: 0 var(--gap-md); +} + +#frm_top_bar > .frm-full-close:last-child, +#frm_top_bar > #frm-publishing:last-child { + margin-left: auto; +} + +#frm_top_bar { + border-bottom: 1px solid var(--grey-300); + padding: 0 var(--gap-md); + overflow: visible; +} + +/** + * Base - Headings + */ +.frm-white-body h1, +.frm-white-body h2, +.frm-white-body h3, +.frm-white-body h4 { + color: var(--grey-900); + font-weight: 400; + line-height: var(--leading) !important; +} + +.frm-white-body .wrap h1, +.frm-white-body h1 { + font-size: var(--text-xl); +} + +.frm-white-body .wrap h2, +.frm-white-body h2 { + font-size: var(--text-lg); + font-weight: 500; +} + +.frm-white-body .wrap h3, +.frm-white-body h3 { + font-size: var(--text-md); +} + +.frm-white-body .wrap h4, +.frm-white-body h4 { + font-size: var(--text-sm); + font-weight: 500; +} + +/** + * Components - Error Modal + */ +#frm_error_modal .frm_lock_simple { + padding: 20px; + border-radius: 50%; + background-color: var(--primary-25); + display: inline-block; +} + +#frm_error_modal #frm_lock_simple { + color: var(--primary-500); +} + +#frm_error_modal .frm-modal-title { + display: block; +} + +#frm_error_modal .frm-modal-title h2 { + font-weight: 600; + font-size: var(--text-xl); + margin: 0; +} + +#frm_error_modal .frm_modal_content { + padding: var(--gap-md); + color: var(--grey-900); +} + +/** + * Layout - Editor Overrides + */ +/* Override CSS in Views plugin. */ +.frm-views-editor-body .frm_page_container #frm_top_bar h1 { + padding: 0 !important; + color: var(--grey-900); + font-size: var(--text-xl) !important; +} + +.post-type-frm_display .frm_top_left { + padding-bottom: 0 !important; +} + +.frm-new-table-view-option.frm-selected-table-view-option { + border-radius: var(--small-radius); + background: var(--primary-25); +} + +.frm-views-editor-body #frm_adv_info .tabs-panel { /* Views sidebar */ + padding-left: 4px; + padding-right: 4px; +} + +#frm_edit_box_content_modal .frm_modal_footer { + padding-top: var(--gap-sm); + border-top: 1px solid var(--grey-300); +} + +#frm_edit_box_content_modal .frm_modal_footer > div { + display: flex; + justify-content: space-between; +} + +#frm_edit_box_content_modal #frm_modal_box_select_area, +#frm_edit_box_content_modal #frm_box_content_wysiwyg_wrapper, +#frm_edit_box_content_modal .frm_modal_content { + max-height: calc(100vh - 176px) !important; +} + +#frm_edit_box_content_modal #frm_modal_box_select_area { + height: calc(100vh - 176px) !important; +} + +#frm_edit_box_content_modal #wp-content-editor-tools { + padding-top: 0; +} + +#frm_edit_box_content_modal.frm-modal .postbox .frm-modal-title + div:last-child { + right: var(--gap-md); +} + +.frm_code_list.frm-full-hover .frm-dropdown-view a { + flex-direction: row-reverse; /* Switch in the HTML */ +} + +#frm_view_editor_left.frm-right-panel .accordion-section-title::before { + content: "" !important; + margin: 0; +} + +/** End Temporary View CSS */ +/** + * Components - Upgrade Bar + */ +.frm-gradient, +.frm-upgrade-bar { + background: linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important; + color: #fff !important; + border: 0 !important; +} + +.frm-gradient.frm-button-primary:not([disabled]), +.frm-gradient.frm-button-primary:not([disabled]):hover, +.frm-gradient.frm-button-primary:not([disabled]):focus { + background: linear-gradient(90deg, #1961d5, #816cfa) !important; +} + +.frm-upgrade-bar, +.frm-gradient { + position: relative; +} + +.frm-upgrade-bar::before, +.frm-gradient::before { + content: ""; + display: none; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background-color: rgba(255, 255, 255, 0.1); + z-index: 0; +} + +.frm-upgrade-bar:hover::before, +.frm-gradient:hover::before, +.frm-gradient:focus::before { + display: block; +} + +.frm-upgrade-bar-inner, +.frm-gradient > * { + position: relative; + z-index: 1; +} + +.frm-upgrade-bar { + border-bottom: 1px solid var(--sidebar-hover); + padding: 9px 0; + font-size: 12px; + text-align: center; +} + +.frm-upgrade-bar a { + color: currentColor !important; + text-decoration: underline; +} + +.frm-upgrade-bar a:focus { + outline: 1px dotted var(--sidebar-hover); +} + +.frm-upgrade-bar span { + opacity: 0.9; +} + +/** + * Components - Links + */ +a h1 .frmsvg { + color: var(--grey-400); + vertical-align: middle; + min-width: var(--text-sm); +} + +a .frmsvg { + color: currentColor; +} + +.frm_wrap .view-switch a.current::before, +.frm-white-body a, +.frm_wrap a, +.frm_wrap a i { + color: var(--primary-color); +} + +.frm_wrap a:active, +.frm_wrap a:hover { + color: var(--primary-700); + box-shadow: none; +} + +.post-type-frm_display a:focus, +.frm_wrap a:focus { + box-shadow: none; +} + +/** + * Layout - Top Bar - Navigation + */ +.frm_top_left { + text-align: left; + float: left; + white-space: nowrap; + max-width: 250px; + overflow: hidden; + text-overflow: ellipsis; + align-self: center; +} + +.post-type-frm_display .frm_top_left, +.frm_top_left.frm_top_wide { + max-width: 100%; +} + +.post-type-frm_display .frm_nav_bar .frm-header-logo, +.frm_nav_bar .frm-header-logo { + margin: 18px 0 10px; +} + +#frm_top_bar .frm_form_nav { + flex: 1; +} + +ul.frm_form_nav { + margin: 0 auto; + padding-top: 18px; + display: block; + min-width: 240px; +} + +.nav-tab-wrapper.frm_form_nav { + padding: 0 25px; +} + +ul.frm_form_nav > li { + margin: 0 min(3.5%, 32px) 0 0; + display: inline-block; +} + +.post-type-frm_display #advanced-sortables h2.hndle, +.post-type-frm_display #side-sortables h2.hndle, +.post-type-frm_display #normal-sortables h2.hndle, +.post-type-frm_display .frm_form_nav .nav-tab-active, +.frm_form_nav > li > a { + font-size: 1.3em; + text-decoration: none; + display: block; + padding: 6px 2px 4px; + font-weight: 500; + color: var(--grey-700); + border-bottom: 2px solid transparent; +} + +.post-type-frm_display.js .postbox .handlediv .toggle-indicator::before { + margin-top: 10px; +} + +.frm-nav-tabs a:focus, +.frm-nav-tabs a:active, +.frm_form_nav a:active, +.frm_form_nav a:focus { + outline: none; + box-shadow: none; +} + +.frm_form_nav > li > a { + font-size: var(--text-md); + font-weight: 400; + color: var(--grey-500); +} + +.frm_form_nav > li > a:hover { + border-color: var(--primary-700); +} + +.frm_form_nav .frm-dropdown-menu a:hover { + background-color: #eaf2fa; +} + +.post-type-frm_display .frm_form_nav .nav-tab-active, +.post-type-frm_display .frm_form_nav .nav-tab-active:hover, +.frm_form_nav > li a.current_page { + color: var(--primary-500); + border-color: var(--primary-500); + background: transparent; + opacity: 1; + font-weight: 600; +} + +/** + * Components - Full Close + */ +.frm-full-close { + display: none; + padding-left: var(--gap-md); + border: 0 solid var(--grey-300); + border-left-width: 1px; /* Make RTL a bit less maintenance */ + height: 100%; + box-sizing: border-box; +} + +.frm-full-screen .frm-full-close { + display: flex; + align-items: center; +} + +.frm-full-close a { + display: block; +} + +.frm-full-close .frmsvg { + font-size: 20px; + width: 20px; + height: 20px; + color: var(--grey-500); +} + +/** + * Layout - Top Bar - Elements + */ +#frm_top_bar h1 { + font-weight: 400; + padding: 0; + margin: 0; + color: var(--grey-900); + display: inline-flex; + gap: var(--gap-sm); + align-items: center; + text-align: left; + min-width: 200px; +} + +#frm_top_bar h1 span { + max-width: 175px; + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; + display: inline-block; + vertical-align: bottom; +} + +#frm_top_bar ul.frm_form_nav, +#frm_top_bar .frm-header-logo, +#frm_top_bar #frm_bs_dropdown { + align-self: center; + margin-top: 0; + margin-bottom: 0; + padding-top: 0; +} + +#frm_top_bar .frm-header-logo { + display: flex; /* Get rid of extra padding below logo */ +} + +#frm_top_bar h2 { + float: left; + margin: 0 0 0 var(--gap-sm); + padding: 2px 0 2px var(--gap-sm); + font-weight: 400; + border-left: 2px solid var(--grey); +} + +.frm_wrap > #frm_top_bar #frm-publishing { + margin-top: 0; +} + +#frm-publishing { + min-width: 225px; + align-self: center; + align-items: center; + display: flex; + flex-direction: row-reverse; + gap: 0 var(--gap-sm); + flex-wrap: wrap; +} + +/** + * Layout - Postbox + */ +.frm_wrap .postbox { + border-color: var(--grey-300); + border-radius: 6px; + box-shadow: none; +} + +.frm_wrap .postbox h3.hndle { + cursor: default; + padding: 10px 20px; + margin: 0; + line-height: 1.4em; + border-color: var(--grey-300); +} + +.frm-pre-hndle { + font-size: 15px; + padding: 5px; + margin: 9px 15px; +} + +/** + * Components - Table - Row + */ +.frm-empty-row { + display: none; +} + +.frm-child-row { + box-shadow: 5px 0 0 0 inset var(--sidebar-hover); +} + +/** + * Utilities - Effects - Animate + */ +.frm_animate_bg { + transition: background 200ms linear, color 200ms linear; +} + +/** + * Components - List - Subsubsub + */ +.wrap > .subsubsub { + clear: both; + margin: 0; +} + +.frm_wrap .subsubsub a { + line-height: var(--leading); + font-size: var(--text-sm); +} + +/** + * Layout - Container + */ +.frm-admin-page-styles .frm_page_container, +.frm_wrap .frm_page_container { /* Use .frm_wrap to avoid messing up Views editor layout */ + height: calc(100vh - 32px); + display: flex; + flex-direction: column; + overflow: hidden; + padding-top: 0; + position: fixed; + top: 32px; + bottom: 0; + left: 0; + right: 0; +} + +.frm-admin-page-translate .frm_wrap .frm_page_container, +.frm-admin-page-update_translations .frm_wrap .frm_page_container { + position: static; +} + +.auto-fold.frm-admin-page-styles .frm_page_container, +.auto-fold .frm_wrap .frm_page_container, +.frm-unfold.frm-admin-page-styles .frm_page_container, +.frm-unfold .frm_wrap .frm_page_container { + left: 160px; +} + +.folded.frm-admin-page-styles .frm_page_container, +.folded .frm_wrap .frm_page_container { + left: 38px; +} + +.frm-full-screen.frm-admin-page-styles .frm_page_container, +.frm-full-screen .frm_wrap .frm_page_container { + height: 100vh; + top: 0; + left: 0; +} + +.frm-full-screen.frm-admin-page-entries .frm_page_container, +.frm-new-entry .frm_page_container, +.frm-admin-page-reports .frm_page_container, +.frm_list_entry_page .frm_page_container { + height: auto; + display: block; +} + +/** + * Layout - Container - Columns Elements + */ +.frm-new-entry .columns-2 { + border: none; +} + +.frm-white-body #frm_top_bar, +.frm-white-body .columns-2 { + flex: 0 0 auto; +} + +.columns-2 .frm-right-panel + div { + padding-bottom: var(--gap-md); + border-left: 1px solid var(--grey-300); +} + +.columns-2 .frm-right-panel + div, +.frm_wrap #post-body-content { + padding-bottom: 0; + padding-top: var(--gap-sm); + margin-bottom: 0; + background: #fff; + width: auto; + float: none; + flex: 2; +} + +.frm-white-body .columns-2 { + flex: 1; + display: flex; + overflow: hidden; +} + +.frm-white-body .columns-2 > div { + overflow-y: auto; + box-sizing: border-box; +} + +.frm_wrap .columns-2 .frm-right-panel, +.frm-right-panel { + flex: 0 0 var(--biggest-sidebar); + float: none; + width: var(--biggest-sidebar); + min-width: var(--biggest-sidebar); + background-color: var(--sidebar-color); + margin: 0; + box-shadow: none; + border: none; + padding-bottom: 25px; +} + +.frm-right-panel .frm_field_list, +.frm_wrap .frm-right-panel #frm_adv_info, +.frm_wrap #postbox-container-1 #frm_adv_info { + box-shadow: none; + border: none; + margin-bottom: 26px; +} + +/** + * Components - Settings - Has Shortcodes + */ +#new_fields, +.frm-has-modal, +p.frm_has_shortcodes { + position: relative; +} + +.frm-inline-modal.postbox { + background: #fff; + border-color: var(--grey-100); + border-radius: var(--small-radius); + box-shadow: var(--box-shadow-lg); +} + +.frm_has_shortcodes .frmsvg:not(.frm_help .frmsvg), +.frm_has_shortcodes i:not([class*=mce-]) { + position: absolute; + color: var(--primary-500); + border-radius: 50%; + border: 1px solid transparent; + z-index: 100; + text-align: center; +} + +.frm_has_shortcodes .frmsvg.frm-show-box { + border-radius: 6px !important; +} + +.frm_has_shortcodes input, +.frm_has_shortcodes textarea { + padding-left: 18px; + box-sizing: border-box; +} + +/** + * Components - Settings - Adv Info + */ +#form_settings_page #frm_adv_info, +#frm_builder_page #frm_adv_info { + display: none; + top: 0; + width: 310px; + max-height: 315px; + min-height: 200px; + overflow-y: scroll; + z-index: 100; +} + +#form_global_settings .columns-2 > div { + overflow: auto; + height: calc(100vh - 32px); +} + +#form_global_settings .columns-2 .frm-right-panel, +#form_settings_page .columns-2 .frm-right-panel, +#wpbody-content .frm-page-skeleton .frm-right-panel { + flex: 0 0 var(--small-sidebar); + width: var(--small-sidebar); + min-width: var(--small-sidebar); +} + +#form_global_settings .frm_grid_container { + gap: 0 var(--gap-md); +} + +.frm-inner-content { + padding: var(--gap-md); +} + +.post-type-frm_display #poststuff { + padding: 0 0 10px 40px; +} + +#postbox-container-2 .postbox .inside { + padding: 15px 25px; +} + +#postbox-container-2 #frm_advanced .inside h3 { + margin: 15px -25px; + font-weight: 600; +} + +#form_settings_page .frm-inner-content { + padding-top: 0; + padding-bottom: 150px; + position: relative; +} + +.frm_wrap #submitdiv { + margin-bottom: 0; + border-width: 0 0 1px; + width: 100%; + min-width: unset; +} + +.frm_wrap #frm_adv_info .handlediv, +.frm_wrap #frm_adv_info .hndle { + display: none; +} + +.frm_wrap .menu-settings { + /* for add-on reverse compatibility */ + border: none; + margin-top: 0; +} + +.nodrag a { + cursor: pointer; +} + +.frm_wrap #frm_adv_info .inside { + margin: 0; +} + +#frm_adv_info > .inside { + padding: 0; +} +#frm_adv_info ul.subsubsub { + padding-bottom: var(--gap-xs) !important; +} +#frm_adv_info ul.subsubsub a { + font-weight: 500; +} +#frm_adv_info ul.subsubsub .frm-vertical-separator { + display: inline-block; + width: 1px; + height: 8px; + background-color: var(--grey-300); +} +#frm_adv_info #frm-insert-condition { + background-color: var(--primary-50); +} +#frm_adv_info #frm-insert-condition:hover { + background-color: var(--primary-25); +} + +#frm_builder_page #frm_adv_info { + width: 322px; + max-height: 356px; + border-radius: var(--small-radius); + overflow: hidden; +} +#frm_builder_page #frm_adv_info #taxonomy-linkcategory { + height: 356px; + overflow: hidden; +} +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div { + max-height: 286px; + padding: 0; +} +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div > * { + padding-bottom: var(--gap-sm); + max-height: unset; +} +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div > *:last-child { + padding-bottom: var(--gap-xs); +} +#frm_builder_page #frm_adv_info #frm-nav-tabs { + display: flex; + gap: var(--gap-xs); + background-color: var(--grey-100); + border-radius: var(--small-radius); + border: 0; + padding: var(--gap-xs); + margin: var(--gap-xs) var(--gap-2xs) var(--gap-sm); +} +#frm_builder_page #frm_adv_info #frm-nav-tabs > li { + flex: 1; + text-align: center; +} +#frm_builder_page #frm_adv_info #frm-nav-tabs > li a { + font-weight: 500; + line-height: 1; + color: var(--grey-500); + border-radius: var(--small-radius); + border: 0; + padding: var(--gap-xs); + margin: 0; +} +#frm_builder_page #frm_adv_info #frm-nav-tabs > li a:hover { + background-color: rgb(234, 236, 240); + color: var(--grey-500) !important; + box-shadow: var(--box-shadow-sm); +} +#frm_builder_page #frm_adv_info #frm-nav-tabs > li.frm-tabs a { + background-color: #fff; + color: var(--grey-900) !important; + box-shadow: var(--box-shadow-sm); +} +#frm_builder_page #frm_adv_info .frm-search, +#frm_builder_page #frm_adv_info .frm-with-search { + padding-top: 0; + margin: 0; +} + +/** + * Components - Modal - Inline Modal + */ +.frm-right-panel .frm-inline-modal.postbox .inside { + margin: 0; + padding: 0 14px 14px; +} +.frm-right-panel .frm-inline-modal.postbox .inside .frm-with-line, +.frm-right-panel .frm-inline-modal.postbox .inside .accordion-section-content h4 { + margin-left: -14px; + margin-right: -14px; +} + +.frm-right-panel .frm-inline-modal .inside p:not(.howto), +.frm-right-panel .frm-inline-modal .inside a { + font-size: 15px; +} + +.frm-inline-modal .inside a.frm_icon_font { + font-size: 18px; +} + +/** + * Components - Nav Tabs + */ +.frm-nav-tabs { + margin: 10px 0 20px; + padding: 0 var(--gap-sm); + display: block; + border-bottom: 1px solid var(--grey-300); +} + +#frm-nav-tabs { + position: -webkit-sticky; + position: sticky; + top: 0; + background-color: var(--sidebar-color); + z-index: 98; /* must be < 99 */ + margin-top: 0; + padding-top: 5px; +} + +.frm_form_settings #frm_adv_info #frm-nav-tabs { + background-color: #fff; + margin: 0 -4px; +} + +.frm_form_settings span.frm-with-right-icon, +#frm_builder_page .frm_has_shortcodes span.frm-with-right-icon:not(.frm_hidden) { + display: block; +} + +.frm-inline-modal .frm-nav-tabs, +#frm_adv_info .frm-nav-tabs { + margin: 5px 0 0; +} + +#frm_adv_info .frm-nav-tabs.frm-compact-nav { + padding-right: 0; + padding-left: 20px; +} + +.frm-nav-tabs li { + display: inline-block; + margin: 0; +} + +.frm-nav-tabs a { + color: var(--grey-700); + padding: 10px 1px; + margin: 0 9px; + border-bottom: 2px solid transparent; +} + +.frm_form_settings #frm_adv_info .frm-nav-tabs a { + padding: 5px 1px; + color: var(--grey-500); +} + +.frm-nav-tabs.frm-compact-nav a { + margin: 0 5px; +} + +.frm-nav-tabs a { + display: block; + opacity: 0.9; +} + +#frm_adv_info .frm-nav-tabs a { + color: var(--grey-700); +} + +.frm-nav-tabs a:hover, +.frm-nav-tabs .frm-tabs a { + color: var(--primary-500) !important; + border-color: var(--primary-500); +} + +.frm_form_settings #frm_adv_info .frm-nav-tabs .frm-tabs a { + font-weight: 500; +} + +/* Payments Page */ +.frm-payments-tabs { + margin-bottom: var(--gap-md); + display: flex; +} +.frm-payments-tabs .frm-payments-tab { + font-weight: 600; + font-size: 14px; + color: var(--grey-900); + display: inline-block; + border-width: 1px; + border-style: solid; + border-color: rgb(234, 236, 240); + padding: 8px 12px; + border-radius: 6px 6px 0 0; + background-color: rgb(249, 250, 251); +} +.frm-payments-tabs .frm-payments-tab-filler { + border-bottom: 1px solid rgb(234, 236, 240); + min-width: var(--gap-xs); +} +.frm-payments-tabs .frm-payments-tab-filler:last-child { + flex: 1; +} + +.frm-payments-tab.frm-active { + background-color: white; + border-bottom: none; +} + +.frm-payments-tab a { + text-decoration: none; + color: var(--grey-900); +} + +/** + * Components - Modal - Bulk Modal + */ +#frm-bulk-modal .howto, +#frm-bulk-modal h3 { + font-size: var(--text-sm); + font-weight: 400; + margin: 5px 0 10px; + color: var(--grey); +} + +#frm-bulk-modal h3 { + margin-left: 20px; +} + +/** + * Layout - Sidebar + */ +.frm-right-panel a.frm_add_logic_link, +.frm-right-panel h3 { + color: var(--grey-700); + font-size: var(--text-lg); + font-weight: 400; + margin: 0; +} +.frm-right-panel h3 i { + color: var(--grey-700); + float: right; + width: 16px; + cursor: pointer; +} + +.frm-settings-panel { + /* Right padding reduced to compensate for scrollbar width (~8px) */ + padding: var(--gap-sm); + padding-right: var(--gap-xs); +} +.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-delimiter { + top: var(--gap-xs); + left: var(--gap-xs); + width: calc(100% - var(--gap-sm)); +} +.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-navs { + padding: var(--gap-xs) var(--gap-xs) 0; +} +.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track > div { + max-height: 0; + visibility: hidden; +} +.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track > div.frm-active { + max-height: unset; + visibility: visible; +} +.frm-settings-panel .frm-embed-field-placeholder { + height: unset; +} +.frm-settings-panel .frm-embed-field-placeholder img { + height: 100px; +} +.frm-settings-panel .frm-embed-field-placeholder .frm-embed-message { + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; + gap: var(--gap-sm); + max-width: unset; + color: var(--grey-800); + padding: var(--gap-lg); + border: 0; + box-shadow: var(--box-shadow-sm); + margin: 1px; +} + +.frm-single-settings .frm-default-value-wrapper > p { + margin-bottom: 0; +} +.frm-single-settings .frm-default-value-wrapper + p:empty { + display: none; +} +.frm-single-settings [class*=frm-lookup-box-] .frm_grid_container p { + margin-top: 0 !important; +} +.frm-single-settings .frm_single_option[id^=frm_watch_lookup_] { + margin-bottom: var(--gap-xs) !important; +} +.frm-single-settings > h3:first-of-type { + position: relative; + background-color: transparent !important; + border-top: none; + padding-top: 0 !important; + margin-top: 0 !important; +} +.frm-single-settings > h3:first-of-type::after { + content: ""; + position: absolute; + left: var(--gap-sm); + right: var(--gap-sm); + bottom: 0; + height: 1px; + background-color: var(--sidebar-hover); +} + +.frm-flex-justify, +.frm-right-panel .frm-single-settings h3 { + display: flex; + justify-content: space-between; + align-items: center; +} + +/* right sidebar */ +#post-body-content + .frm-right-panel { + flex: 0 0 var(--medium-sidebar); + width: var(--medium-sidebar); + min-width: var(--medium-sidebar); + border-left: 1px solid var(--sidebar-hover); +} + +.frm-new-entry #post-body-content + .frm-right-panel, +.frm-new-entry .frm-right-panel { + background: none; + border: none; +} + +#post-body-content + .frm-right-panel h3 { + padding: 20px 20px 0; + font-size: 17px; +} +#post-body-content + .frm-right-panel .frm_with_icons:first-of-type h3 { + border: none; +} + +#frm-insert-fields h3 { + color: var(--grey); + font-size: 15px; + font-weight: 400; + border-top: none; + border-bottom: 1px solid var(--sidebar-hover); + margin: 0; + padding: 10px 10px 10px 25px; +} + +.frm_wrap #frm_adv_info ul.category-tabs { + margin: 0; + padding: 10px 0 9px; + font-size: 15px; + background: transparent; +} +.frm_wrap #frm_adv_info ul.category-tabs li { + padding: 10px; + background-color: transparent !important; +} +.frm_wrap #frm_adv_info ul.category-tabs li:first-child { + border: none; +} + +.frm_wrap #frm_adv_info .categorydiv div.tabs-panel { + border: none; + background: transparent; +} +.frm_wrap #frm-categorydiv { + border-right: none; +} + +#frm_adv_info #frm-conditionals { + padding-top: var(--gap-sm); +} + +#postbox-container-1 #taxonomy-linkcategory #frm-html-tags { + display: none; + max-height: none; +} +#postbox-container-1 .frm_field_list #frm-insert-fields .frmbutton.dropdown { + position: relative; +} + +/** + * Components - Admin Footer + */ +.frm-white-body #footer-upgrade { + display: none; +} + +.frm-admin-footer-links, +.frm-admin-footer-links-nav, +.frm-admin-footer-links-socials { + display: flex; + justify-content: center; +} + +.frm-admin-footer-links { + gap: var(--gap-2xs); + flex-direction: column; + text-align: center; + padding: var(--gap-xl) 0 var(--gap-lg); + font-size: var(--text-xs); + color: var(--grey-400); +} + +body.frm-hidden-overflow { + height: 100%; + overflow: hidden; +} + +.frm-admin-footer-links-nav { + gap: var(--gap-2xs); + margin-bottom: var(--gap-xs); +} + +.frm-admin-footer-links-socials { + gap: var(--gap-xs); +} + +.frm-admin-footer-links-socials a { + color: var(--grey-400); +} + +/** + * Layout - List Entry Page + */ +.frm_list_entry_page h2 { + float: left; +} + +.frm_list_entry_page h2 + .error { + clear: both; +} + +/** + * Layout - Sidebar - Elements + */ +.frm_sidebar select { + width: 100%; + margin-left: 0; + margin-right: 0; +} + +.frm_sidebar #search-submit { + float: right; +} + +/** + * Layout - Single Entry Page + */ +.frm_single_entry_page #submitdiv { + margin: 0; +} + +.frm_single_entry_page .hndle a { + font-size: 13px; +} + +/** + * Components - Publish Actions + */ +.frm-right-panel #publishing-action { + float: none; +} + +.frm-right-panel #major-publishing-actions { + border-top: none; + height: 32px; + background: transparent; +} + +#major-publishing-actions .frm_submit_form { + float: right; + margin-left: 5px; +} + +/** + * Components - Button + */ +.frm_orange_button, +.frm_reverse_button { + font-size: 12px; + border: 1px solid var(--orange); + color: var(--orange); + font-weight: 600; + padding: 1px 4px; + border-radius: 4px; + background: transparent; +} + +.frm_reverse_button:hover, +.frm_reverse_button:active, +.frm_reverse_button:focus { + color: #fff; + background: var(--orange); + border: 1px solid var(--orange); +} + +.frm_reverse_button { + font-size: 1em; + transition: all 0.2s ease; +} + +.frm-button-primary, +.wp-core-ui .button-primary.frm-button-primary, +.wp-core-ui .button.frm-button-primary, +.frm-button-secondary, +.wp-core-ui .button-secondary.frm-button-secondary, +.wp-core-ui .button.frm-button-secondary, +.frm-white-body .frm-search .button, +.frm-white-body .search-box .button, +.frm-white-body .tablenav .button, +.frm_orange_button, +.toplevel_page_formidable #frm_upgrade_modal .button-primary, +.wp-core-ui.frm-white-body .button-primary, +.wp-core-ui.frm-white-body .button-secondary, +.frm-white-body .button-primary, +.frm-white-body .button-secondary, +#frm-form-button button, +.frm-form-button button, +.frm-preview-buttons button, +.frm-button-red, +.frm-button-tertiary { + text-shadow: none; + box-shadow: none; + border-radius: 30px; + border: 1px solid var(--primary-500); + font-size: var(--text-sm); + transition: all 0.2s ease; + padding: 7px 16px; + height: auto; + min-height: 28px; + outline: none; + line-height: var(--leading); + box-sizing: border-box; + font-weight: 500; + margin-bottom: 0; + display: inline-block; +} + +.frm-button-primary.frm-sharp, +.frm-button-secondary.frm-sharp { + border-radius: 12px !important; +} + +#wpcontent .frm-button-secondary.frm-button-gradient { + position: relative; + border-color: transparent !important; + background-clip: padding-box !important; +} +#wpcontent .frm-button-secondary.frm-button-gradient::before { + content: ""; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: -1; + margin: -1px; + border-radius: inherit; + background: linear-gradient(90deg, #129efd 0%, #a334fd 100%); + transition: opacity 150ms ease-out; +} +#wpcontent .frm-button-secondary:hover::before { + opacity: 0.5; +} + +.no-js.wp-core-ui .frm-search .button.hide-if-no-js, +.js.wp-core-ui .frm-search .button.hide-if-js { + display: none; +} + +.frm-button-tertiary { + border-color: transparent; + color: var(--primary-500); +} + +.frm-button-tertiary:focus { + outline: none; +} + +.frm-button-tertiary.frm_loading_button::before { + border-right-color: var(--grey); + border-bottom-color: var(--grey); +} + +.frm-button-red, +.frm-button-red:focus { + --primary-color: var(--error-500); + --primary-500: var(--error-500); + --primary-700: var(--error-700); +} + +.frm-button-red:not(.frm-button-tertiary), +.frm-button-red:not(.frm-button-tertiary):focus { + color: #fff !important; +} + +.frm-white-body h2 .button, +.post-type-frm_display h2 .frm-button-primary, +.frm-white-body .tablenav .button, +.frm-button-primary.frm-button-sm, +.frm-button-secondary.frm-button-sm, +.frm-button-tertiary.frm-button-sm, +.frm-button-red.frm-button-sm { + padding: 4px 12px !important; + font-size: var(--text-xs) !important; +} + +.frm_no_style_button { + background: transparent; +} + +.frm-with-icon { + display: flex; + gap: var(--gap-xs); + align-items: center; +} + +.frm-with-icon svg { + opacity: 0.65; /* Get close to grey-500 without overriding hover colors */ +} + +.frm-with-icon.button svg { + height: var(--text-sm); + width: var(--text-sm); +} + +.frm-with-icon.frm-button-sm svg { + height: var(--text-xs); + width: var(--text-xs); +} + +.frm-white-body .button.add_media { + /* Media buttons above RTE */ + padding-left: 12px !important; + padding-right: 12px !important; + font-size: var(--text-xs); + border-radius: var(--border-radius); +} + +.wp-core-ui.frm-white-body #post-query-submit.button, +.wp-core-ui.frm-white-body .button.tablenav-pages-navspan, +.wp-core-ui.frm-white-body .button.first-page, +.wp-core-ui.frm-white-body .button.prev-page, +.wp-core-ui.frm-white-body .button.next-page, +.wp-core-ui.frm-white-body .button.last-page, +.wp-core-ui.frm-white-body .button.action { + background-color: transparent; + border-color: var(--grey-300); + color: var(--grey-700); + border-radius: var(--border-radius); +} + +.post-type-frm_display.wp-core-ui .button-primary, +.frm-button-primary, +.wp-core-ui .button-primary.frm-button-primary, +.frm_single_entry_page #frm-publishing .button-primary { + background-color: var(--primary-500) !important; + color: #fff !important; +} + +.frm-button-primary.frm_large, +.frm-button-secondary.frm_large { + height: auto !important; + padding: 12px 16px !important; +} + +.frm-button-secondary.frm-small, +.frm-button-primary.frm-small { + font-size: var(--text-xs) !important; + height: auto !important; + padding: var(--gap-2xs) 12px !important; +} + +.frm-button-primary i::before { + color: #fff; +} + +.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover, +.frm-button-primary:not([disabled]):hover { + background: var(--primary-700) !important; + border-color: var(--primary-700) !important; +} + +.wp-core-ui .button-primary.frm-button-primary:active { + vertical-align: inherit; +} + +.frm-white-body #search-submit, +#frm-form-button .frm_button_submit, +.frm-form-button .frm_button_submit, +.frm-white-body .frm-preview-buttons button, +.frm-white-body .button:not(.frm-button-primary), +.wp-core-ui.frm-white-body .button-secondary, +.wp-core-ui .button-secondary.frm-button-secondary, +.wp-core-ui .button.frm-button-secondary, +.frm-white-body .frm-button-secondary, +.frm-button-secondary { + color: var(--grey-800); + border-color: var(--grey-300); + background-color: #fff; +} + +#wp-content-media-buttons button, +#wp-content-media-buttons a.button { + border-color: var(--grey-300); +} + +.frm_orange_button { + border-color: #da791d !important; + background: var(--orange); + color: #fff; +} + +.frm-white-body .button:not(.frm-button-primary):focus, +.frm-white-body .button:not(.frm-button-primary):active, +.frm-white-body .frm-button-secondary:hover, +.wp-core-ui.frm-white-body .frm-button-secondary:hover, +.wp-core-ui.frm-white-body .button-secondary:hover, +.wp-core-ui.frm-white-body .button-secondary:focus, +.wp-core-ui.frm-white-body .tablenav .button:hover, +.frm_wrap .preview > .button:hover, +.frm-white-body #search-submit:hover { + border-color: var(--grey-300) !important; + color: var(--grey-800); + background: var(--grey-50) !important; + box-shadow: none !important; + outline: none !important; +} + +.frm-button-primary .frmsvg { + color: #fff; +} + +.frm_wrap .preview i { + font-size: inherit; +} + +.frm-white-body .frm-button-primary:focus, +.frm-white-body .frm-button-primary:active, +#frm-addons-page .button-primary:focus, +#form_global_settings .button-primary:focus, +#frm_upgrade_modal .button-primary:focus { + border-color: var(--primary-700) !important; + background-color: var(--primary-700) !important; + box-shadow: none !important; + outline: none !important; +} + +.frm_wrap .preview > .button:focus, +.frm_orange_button:hover, +.frm_orange_button:focus, +.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover, +.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus, +.toplevel_page_formidable .frm_wrap button.button-primary:hover, +.toplevel_page_formidable .frm_wrap button.button-primary:focus { + outline: none; +} + +.frm_orange_button:hover, +.frm_orange_button:focus { + border-color: var(--orange) !important; + background: transparent; + color: var(--orange); + opacity: 1; +} + +.major-publishing-actions.frm_create_form_header { + padding: 8px 0; +} + +.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner { + font-size: 15px; + background: transparent; +} + +.frm-menu-boxes .frm_blank_form_text { + padding-bottom: 26px; +} + +input.frm_insert_in_template { + font-size: 10px; + width: 98%; + font-weight: 400; +} + +.frm-dismissible a.dismiss:focus { + box-shadow: none; +} + +.frm-dismissible a.dismiss { + top: 10px; + right: 10px; + position: absolute; +} + +.frm-dismissible a.dismiss svg { + color: var(--grey-800); +} + +.frm-btn-unstyled { + font: inherit; + background: none; + border: none; + padding: 0; + cursor: pointer; + outline: inherit; +} +.frm-btn-unstyled:hover, .frm-btn-unstyled:focus, .frm-btn-unstyled:active { + text-decoration: none; + background: none; + border: none; + box-shadow: none; +} +.frm-btn-unstyled:disabled, .frm-btn-unstyled[disabled] { + pointer-events: none; + opacity: 0.65; +} + +/** + * Components - Review Request + */ +.wp-admin .frm-review-notice { + position: fixed !important; + bottom: var(--gap-2xl); + right: var(--gap-lg); + width: 380px; + text-align: center; + border-color: var(--grey-100); + padding: var(--gap-lg); + border-radius: var(--medium-radius); + box-shadow: var(--box-shadow-lg) !important; + z-index: 999; + box-sizing: border-box; + --gap-sm: 16px; + --gap-md: 24px; + --gap-2xl: 48px; +} + +.wp-admin .frm-review-notice * { + box-sizing: border-box; +} + +.frm-review-notice-icon { + display: inline-flex; + margin-bottom: var(--gap-sm); +} + +.wp-admin .frm-review-notice-title { + font-weight: 600; + margin-top: 0; + margin-bottom: var(--gap-xs); +} + +.wp-admin .frm-review-notice-text { + margin-top: 0; + margin-bottom: var(--gap-md); +} + +.frm-review-notice-signature { + text-align: left; + margin: var(--gap-md) 0; +} + +.frm-review-notice-signature img { + width: 40px; + height: 40px; + padding: 3px; + box-shadow: var(--box-shadow-md); + border-radius: 100%; +} + +#wpwrap .frm-dismiss-review-notice { + top: 16px; + right: 19px; +} + +.frm-review-notice #frmapi-feedback [class^=frm__] { + display: none; +} + +.frm-review-notice #frmapi-feedback input, +.frm-review-notice #frmapi-feedback textarea { + border-color: var(--grey-300); + border-radius: var(--small-radius); +} + +.frm-review-notice #frmapi-feedback input { + min-height: unset; + max-height: 36px; +} + +.frm-review-notice #frmapi-feedback textarea { + max-height: 80px; + padding-top: var(--gap-xs); +} + +.frm-review-notice #frmapi-feedback .frm_message { + color: var(--success-900); + background-color: var(--success-25); + border: 1px solid var(--success-200); + padding: var(--gap-sm) var(--gap-md); + margin: 0; +} + +.frm-review-notice #frmapi-feedback .frm_message p { + margin: 0; +} + +.frm-review-notice #frmapi-feedback .frm_button_submit { + background-color: var(--primary-500); + border-color: var(--primary-500) !important; + cursor: pointer; +} + +.frm-review-notice #frmapi-feedback .frm_button_submit:hover, +.frm-review-notice #frmapi-feedback .frm_button_submit:focus { + color: #fff; + background-color: var(--primary-700); + border-color: var(--primary-700) !important; +} + +.frm-review-notice .frm_error, +.frm-review-notice label { + color: #444; + text-align: left; +} + +.frm-review-notice label { + font-size: var(--text-sm); +} + +.frm-floating-success-message { + position: fixed; + z-index: 999; + border-radius: 4px; + right: 10px; + bottom: 10px; +} + +/** + * Utility Classes + * + * Reusable helper classes for spacing, typography, effects, etc. + */ +/** + * Utilities - Box Shadow + */ +.frm-box-shadow-xxl { + box-shadow: var(--box-shadow-xxl) !important; +} + +/** + * Utilities - Text Color + */ +.frm-text-white { + color: #fff !important; +} + +.frm-text-primary-500 { + color: var(--primary-500); +} + +.frm-text-grey-400 { + color: var(--grey-400) !important; +} + +.frm-text-grey-500 { + color: var(--grey-500) !important; +} + +.frm-text-grey-600 { + color: var(--grey-600) !important; +} + +.frm-text-grey-700 { + color: var(--grey-700); +} + +.frm-text-grey-800 { + color: var(--grey-800); +} + +.frm-text-grey-900 { + color: var(--grey-900); +} + +.frm-text-success-500 { + color: var(--success-500); +} + +.frm-text-warning-500 { + color: var(--warning-500); +} + +.frm-underline { + text-decoration: underline; +} + +/** + * Utilities - Margin + */ +.frm_no_margin, +.frm-m-0 { + margin: 0 !important; +} + +.frm-m-12 { + margin: var(--gap-2xl); +} + +.frm-m-2xs { + margin: var(--gap-2xs) !important; +} + +.frm_no_top_margin, +.frm-mt-0 { + margin-top: 0 !important; +} + +.frm-mt-2xs { + margin-top: var(--gap-2xs) !important; +} + +.-frm-mt-2xs { + margin-top: calc(-1 * var(--gap-2xs)) !important; +} + +.frm-mt-xs { + margin-top: var(--gap-xs) !important; +} + +.frm-mt-sm { + margin-top: var(--gap-sm) !important; +} + +.frm-mt-md { + margin-top: var(--gap-md) !important; +} + +.frm-mt-lg { + margin-top: var(--gap-lg) !important; +} + +.frm-mt-2xl { + margin-top: var(--gap-2xl) !important; +} + +.frm-mt-auto { + margin-top: auto !important; +} + +.frm_no_bottom_margin, +.frm-mb-0 { + margin-bottom: 0 !important; +} + +.frm-mb-2xs { + margin-bottom: var(--gap-2xs) !important; +} + +.frm-mb-6 { + margin-bottom: 6px !important; +} + +.frm-mb-sm { + margin-bottom: var(--gap-sm) !important; +} + +.frm-mb-12 { + margin-bottom: 12px !important; +} + +.frm-mb-xs { + margin-bottom: var(--gap-xs) !important; +} + +.frm-mb-md { + margin-bottom: var(--gap-md) !important; +} + +.frm-mb-lg { + margin-bottom: var(--gap-lg) !important; +} + +.frm-ml-2xs { + margin-left: var(--gap-2xs) !important; +} + +.frm-ml-xs { + margin-left: var(--gap-xs) !important; +} + +.frm-ml-auto { + margin-left: auto; +} + +.-frm-ml-2xs { + margin-left: calc(-1 * var(--gap-2xs)) !important; +} + +.frm-mr-auto { + margin-right: auto; +} + +.frm-force-mr-auto { + margin-right: auto !important; +} + +.frm-mr-2xs { + margin-right: var(--gap-2xs) !important; +} + +.frm-mr-xs { + margin-right: var(--gap-xs) !important; +} + +.frm-mr-2 { + margin-right: 2px !important; +} + +.frm-mx-0 { + margin-left: 0 !important; + margin-right: 0 !important; +} + +.frm-mx-xs { + margin-left: var(--gap-xs) !important; + margin-right: var(--gap-xs) !important; +} + +.frm-mx-sm { + margin-left: var(--gap-sm) !important; + margin-right: var(--gap-sm) !important; +} + +.frm-my-sm { + margin-top: var(--gap-sm) !important; + margin-bottom: var(--gap-sm) !important; +} + +.frm-my-xs { + margin-top: var(--gap-xs) !important; + margin-bottom: var(--gap-xs) !important; +} + +/** + * Utilities - Padding + */ +.frm-p-0 { + padding: 0 !important; +} + +.frm-p-1, +.frm-p-2xs { + padding: var(--gap-2xs); +} + +.frm-p-sm, +.frm-p-4 { + padding: var(--gap-sm) !important; +} + +.frm-p-xs { + padding: var(--gap-xs) !important; +} + +.frm-p-sm { + padding: var(--gap-sm) !important; +} + +.frm-p-6, +.frm-p-md { + padding: var(--gap-md) !important; +} + +.frm-p-xl { + padding: var(--gap-xl) !important; +} + +.frm-px-0 { + padding-left: 0 !important; + padding-right: 0 !important; +} + +.frm-py-0 { + padding-top: 0 !important; + padding-bottom: 0 !important; +} + +.frm-py-2xs { + padding-top: var(--gap-2xs) !important; + padding-bottom: var(--gap-2xs) !important; +} + +.frm-py-sm { + padding-top: var(--gap-sm) !important; + padding-bottom: var(--gap-sm) !important; +} + +.frm-pt-0 { + padding-top: 0 !important; +} + +.frm-pt-2xs { + padding-top: var(--gap-2xs) !important; +} + +.frm-pt-xs { + padding-top: var(--gap-xs) !important; +} + +.frm-pt-sm { + padding-top: var(--gap-sm) !important; +} + +.frm-pt-md { + padding-top: var(--gap-md) !important; +} + +.frm-pt-xl { + padding-top: var(--gap-xl) !important; +} + +.frm-pr-lg { + padding-right: var(--gap-lg) !important; +} + +.frm-pb-md { + padding-bottom: var(--gap-md) !important; +} + +.frm-pb-sm { + padding-bottom: var(--gap-sm) !important; +} + +.frm-pb-xs { + padding-bottom: var(--gap-xs) !important; +} + +.frm-pb-2xs { + padding-bottom: var(--gap-2xs) !important; +} + +.frm-pb-0 { + padding-bottom: 0 !important; +} + +.frm-px-sm { + padding-right: var(--gap-sm) !important; + padding-left: var(--gap-sm) !important; +} + +.frm-px-xs { + padding-right: var(--gap-xs) !important; + padding-left: var(--gap-xs) !important; +} + +.frm-px-md { + padding-right: var(--gap-md) !important; + padding-left: var(--gap-md) !important; +} + +/** + * Utilities - Font Size + */ +.frm-text-xs { + font-size: var(--text-xs) !important; +} + +.frm-text-sm { + font-size: var(--text-sm) !important; +} + +.frm-text-md { + font-size: var(--text-md) !important; +} + +.frm-text-lg { + font-size: var(--text-lg) !important; +} + +.frm-text-xl { + font-size: var(--text-xl) !important; +} + +.frm-leading-none { + line-height: 1; +} + +.frm-italic { + font-style: italic; +} + +.frm-no-italic { + font-style: normal; +} + +/** + * Utilities - Text Transform + */ +.frm-capitalize { + text-transform: capitalize; +} + +/** + * Utilities - Font Weight + */ +.frm-font-normal { + font-weight: 400 !important; +} + +.frm-font-medium { + font-weight: 500 !important; +} + +.frm-font-semibold { + font-weight: 600 !important; +} + +.frm-font-bold { + font-weight: 700 !important; +} + +/** + * Utilities - Text Overflow + */ +.frm-truncate { + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} + +[class*=frm-line-clamp-] { + overflow: hidden; + display: -webkit-box; + -webkit-box-orient: vertical; +} + +.frm-line-clamp-2 { + -webkit-line-clamp: 2; +} + +.frm-white-space-nowrap { + white-space: nowrap; +} + +/** + * Utilities - Border Radius + */ +.frm-rounded-6 { + border-radius: 6px !important; +} + +.frm-rounded-sm { + border-radius: var(--small-radius) !important; +} + +.frm-rounded-12 { + border-radius: 12px !important; +} + +.frm-rounded-md { + border-radius: var(--medium-radius) !important; +} + +/** + * Utilities - Width + */ +.frm-w-auto { + width: auto !important; +} + +.frm-w-full { + width: 100% !important; +} + +.frm-w-half { + width: 50% !important; +} + +.frm-w-fit { + width: fit-content !important; +} + +.frm-max-w-fit { + max-width: fit-content; +} + +.frm-h-auto { + height: auto !important; +} + +/** + * Utilities - Display + */ +#wpwrap .frm-force-hidden, +.frm-force-hidden { + display: none !important; +} + +.frm_block, +.frm-block { + display: block; +} + +.frm_inline { + display: inline; +} + +.frm-force-inline { + display: inline !important; +} + +.frm_inline_block { + display: inline-block !important; +} + +/** + * Utilities - Flex + */ +.frm-inline-flex, +#wpbody-content .frm-inline-flex { + display: inline-flex; +} + +.frm-flex { + display: flex; +} + +.frm-force-flex { + display: flex !important; +} + +.frm_hidden, +.js .frm-hide-js { + display: none; +} + +.frm-flex-box { + display: flex; + gap: var(--gap-sm); +} + +.frm-flex-col { + display: flex; + flex-direction: column; +} + +.frm-flex-full { + flex: 1; +} + +.frm-force-flex-center, .frm-flex-center { + justify-content: center; + align-items: center; +} + +.frm-flex-center { + display: flex; +} + +.frm-force-flex-center { + display: flex !important; +} + +.frm-shrink-0 { + flex-shrink: 0; +} + +.frm-gap-0 { + gap: 0 !important; +} + +.frm-gap-2xs { + gap: var(--gap-2xs); +} + +.frm-gap-xs { + gap: var(--gap-xs); +} + +.frm-gap-sm { + gap: var(--gap-sm); +} + +.frm-gap-md { + gap: var(--gap-md); +} + +.frm-gap-xl { + gap: var(--gap-xl); +} + +.frm-justify-start { + justify-content: start !important; +} + +.frm-justify-center { + justify-content: center !important; +} + +.frm-justify-between { + justify-content: space-between; +} + +.frm-justify-end { + justify-content: end; +} + +.frm-items-start { + align-items: flex-start; +} + +.frm-items-center { + align-items: center; +} + +.frm-items-stretch { + align-items: stretch; +} + +.frm-self-normal { + align-self: normal; +} + +#wpbody-content .frm-flex-wrap { + flex-wrap: wrap; +} + +.frm-grow { + flex-grow: 1; +} + +.frm-order-first { + order: -9999; +} + +.frm-order-last { + order: 9999; +} + +.frm-order-none { + order: 0; +} + +.frm-h-stack-sm, .frm-h-stack-xs, .frm-h-stack { + display: flex !important; + align-items: center; +} +.frm-h-stack-sm > input[type=checkbox], .frm-h-stack-xs > input[type=checkbox], .frm-h-stack > input[type=checkbox], +.frm-h-stack-sm > input[type=radio], +.frm-h-stack-xs > input[type=radio], +.frm-h-stack > input[type=radio] { + margin: 0 !important; +} + +.frm-h-stack { + gap: var(--gap-2xs); +} + +.frm-h-stack-xs { + gap: var(--gap-xs); +} + +.frm-h-stack-sm { + gap: var(--gap-sm); +} + +.frm-flex-row-reverse { + flex-direction: row-reverse; +} + +/** + * Utilities - Transition + */ +.frm-transition-ease { + transition: all 0.2s ease; +} + +/** + * Utilities - Visibility + */ +.frm_invisible { + visibility: hidden; + transition: all 0.2s ease; +} + +.frm_disabled { + opacity: 0.5; + cursor: default; + pointer-events: none; +} +.frm_disabled .frm-show-inline-modal { + pointer-events: none !important; +} + +/** + * Utilities - Float + */ +.frm_no_float { + float: none; +} + +/** + * Utilities - Text Align + */ +.frm-text-right { + text-align: right; +} + +.frm-text-left { + text-align: left; +} + +/** + * Utilities - Border + */ +.frm-border-b { + border-bottom: 1px solid var(--grey-300); +} + +.frm-no-border { + border: none !important; +} + +.frm-hr { + display: block; + height: 1px; + background-color: var(--grey-200); + margin: var(--gap-xs) 0; +} + +/** + * Utilities - Opacity + */ +.frm-opacity-100 { + opacity: 1; +} + +/** + * Utilities - Z-index Helpers + */ +.frm-on-bottom { + z-index: -1; +} + +/** + * Utilities - Transform + */ +.frm-rotate-90 { + transform: rotate(90deg); +} + +/** + * Utilities - Cursor + */ +.frm-cursor-pointer { + cursor: pointer; +} + +/** + * Utilities - Vertical Align + */ +.frm-align-baseline { + vertical-align: baseline !important; +} + +/** + * Utilities - Generic Classes + */ +.frm-fields p > label.frm_hidden, +#wpbody-content label.frm_hidden, +.frm-lookup-modal .dismiss, +.frm-right-panel .inside a.frm_hidden, +#form_global_settings .frm_hidden, +ul.frm_form_nav > li.frm_hidden, +a.frm_hidden, +.button.frm_hidden, +.wp-core-ui .button.frm_hidden { + display: none; +} + +.postbox .inside > p.frm_no_bottom_margin:last-child { + margin-bottom: 0 !important; +} + +.frm_no_section_fields.frm_block { + display: block; +} + +.actions.frm_visible_overflow { + overflow: visible !important; +} + +.frm_full_opacity, +.frm_submit .frm_full_opacity, +.frm_submit .frm-opacity-100 { + opacity: 1; +} + +.frm-dropdown-menu.frm-on-top { + z-index: 99999; +} + +/** + * Utilities - Helper Classes + */ +.frm-vertical-line { + display: inline-block; + width: 1px; + height: 12px; + background-color: var(--grey-300); +} + +.frm-admin-full-screen #adminmenumain, +.frm-admin-full-screen #wpadminbar, +.frm-admin-full-screen #adminmenuback, +.frm-admin-full-screen #adminmenuwrap, +.frm-admin-full-screen #wpfooter { + display: none; +} + +.frm-admin-full-screen #wpcontent, +.frm-admin-full-screen.auto-fold #wpcontent { + margin: 0; + padding: 0; +} + +.frm-admin-full-screen.appearance_page_starter-templates #wpbody-content { + padding: 0; +} + +/** + * Forms & UI Components + * + * Form elements, inputs, fields, modals and interactive components + */ +/** + * Components - General Form Styles + */ +.frm_forms.with_frm_style { + max-width: 100%; +} + +.post-type-frm_display .wrap > .subsubsub, +.post-type-frm_display .wrap > .icl_subsubsub, +.frm_form_settings > p { + margin: 6px var(--gap-md); + padding: 0; +} + +.frm-entry-container { + margin: 0 40px 40px; + padding: 0; +} + +#form_reports_page .frm-inner-content { + width: calc(100% - 40px); + max-width: 900px; + margin: 20px auto; + padding: 20px; +} + +.frm_inner_field_container > .frm_form_fields { + clear: both; +} + +.post-type-frm_display h2, +.frm_wrap h2 { + margin-top: 0 !important; + font-size: var(--text-lg); + line-height: var(--leading); +} + +.post-type-frm_display .wrap > h2:first-child, +.frm_wrap .wrap > h2:first-child { + padding-top: 0; + margin-top: 0 !important; + font-size: var(--text-lg); +} + +#frm_form_editor_container { + position: relative; + margin-top: 28px; +} + +/** + * Components - Form Field + */ +.form-field p { + /* for conflicts */ + background: none; + border: none; +} + +.form-field label.frm_primary_label { + display: block; + float: none; + width: auto; +} + +#frm_view_editor_left label, +#frm_view_editor_left .frm_primary_label, +.frm-dialog .frm-sub-label, +.frm-dialog label, +.dropdown .frm_primary_label, +.accordion-container label, +.frm-fields td > label, +.frm-fields td > div > label, +.frm_form_field > label:first-child, +.frm-fields p > label, +.frm_on_submit_type > label, +.post-type-frm_display .frm_form_field > label, +#new_fields .frm_primary_label, +#form_global_settings .frm_primary_label, +#frm_form_editor_container .frm_primary_label, +#permissions_settings_settings .frm_primary_label { + color: var(--grey-700); + margin: 0 0 6px; + padding: 0; + width: auto; + font-size: var(--text-sm); + display: block; + line-height: var(--leading); +} + +#frm_form_editor_container #frm-show-fields .frm_primary_label { + min-height: 21px; +} + +.frm-fields td input + label { + display: inline; +} + +#frm_form_editor_container .edit_field_type_end_divider .frm_primary_label, +#frm_form_editor_container .edit_field_type_break .frm_primary_label { + display: none; +} + +form .frm_primary_label input { + font-size: 12px; +} + +.with_frm_style form .form-field { + margin-bottom: 20px; +} + +#frm_builder_page .with_frm_style form .frm_combo_inputs_container > .form-field { + margin-bottom: 0; +} + +.frm_description, +.with_frm_style form div.description, +.frm_error, +.with_frm_style form div.description textarea { + padding: 0; + font-size: 11px; +} + +.with_frm_style .description { + color: inherit; +} + +#frm_form_editor_container .divider_section_only .frm_primary_label { + display: flex; + align-items: center; + gap: var(--gap-xs); + font-size: 20px; +} + +#frm_form_editor_container .divider_section_only .frm_primary_label .frm-sub-label { + padding: 0; +} + +#frm-show-fields ul:has(> li:nth-child(7)) .frm-sub-label.frm-field-id { + display: none; +} + +/** + * Token Input Component + * + * Displays space-separated values as selectable tokens + */ +.frm-token-container { + position: relative; + display: block; + direction: ltr; +} +.frm-token-container .frm-tokens { + position: absolute; + top: 0; + left: 0; + max-width: calc(100% - var(--gap-xl)); + display: flex; + align-items: center; + flex-wrap: wrap; + gap: var(--gap-2xs); + padding: 6px var(--gap-xs); + margin: 0; +} +.frm-token-container .frm-token { + position: relative; + display: flex; + align-items: center; + gap: var(--gap-xs); + min-height: 24px; + height: auto; + color: var(--grey-900); + background: var(--grey-100); + border-radius: 4px; + padding: 0 var(--gap-xs); + font-size: var(--text-md); + margin: 0; + z-index: 2; +} +.frm-token-container .frm-token .frm-token-value { + line-height: var(--leading); + white-space: normal; + word-break: break-word; +} +.frm-token-container .frm-token .frm-token-remove { + display: flex; + flex-shrink: 0; + cursor: pointer; +} +.frm-token-container .frm-token .frm-token-remove .frmsvg { + color: var(--grey-900); + position: static; + width: 12px; + height: 12px; + padding: 0; +} +.frm-token-container .frm-token .frm-token-remove:hover .frmsvg { + color: var(--error-500); +} +.frm-token-container .frm-show-inline-modal { + z-index: 3 !important; +} +.frm-token-container .frm-token-proxy-input { + position: relative; + z-index: 1; + padding-right: var(--gap-xl) !important; +} + +/** + * Components - Field Loading + */ +form .form-field.frm_field_loading { + margin-bottom: 0; + min-height: 0; + padding: 0; + text-align: center; +} + +.frm_sorting > .frm_field_loading .frm_visible_spinner.frm-wait { + margin-bottom: 10px; +} + +.frm_sorting > .frm_field_loading ~ .frm_field_loading .frm_visible_spinner.frm-wait { + margin-bottom: 0; + display: none; +} + +/** + * Components - Form Error + */ +.frm_description, +.with_frm_style form div.description, +.frm_error { + margin: 0; +} + +.frm_error { + color: #f04438; +} + +form .frm_blank_field input, +form .frm_blank_field textarea, +form .frm_blank_field select, +form .frm_blank_field .frm-g-recaptcha iframe, +form .frm_blank_field .g-recaptcha iframe { + border-color: #f04438; +} + +form .frm_blank_field label { + color: #f04438; +} + +.frm_required { + color: #f04438; +} + +/** + * Components - MCE Styles + */ +.with_frm_style .wp-editor-container textarea, +.postbox .wp-editor-container textarea, +.frm_remove_border { + border: none; +} + +.with_frm_style .mceIframeContainer, +.postbox .mceIframeContainer { + background-color: #fff; +} + +/** + * Components - License + */ +.frm_pro_license_msg { + clear: left; + margin-top: 10px; +} + +.frm-license-input { + position: relative; +} + +.frm-license-input span { + font-size: var(--text-sm); +} + +.frm-license-input .frmsvg { + width: 20px; + height: 20px; + margin-left: 5px; + vertical-align: text-top; +} + +.frm-license-input .frmsvg, +.frm-license-input span, +.frm-license-input i { + color: rgb(0, 131, 26); +} + +/** + * Components - Upgrade to Pro + */ +.upgrade_to_pro { + padding: 10px 25px 25px; + max-width: 700px; + margin: 20px auto !important; +} + +.upgrade_to_pro .error { + display: none; +} + +/** + * Components - Message Styles + */ +.toplevel_page_formidable #wpbody-content > .error { + margin: 1px; + padding: 5px 12px; +} + +.frm_error_style, +.frm_warning_style, +.frm_note_style2, +.frm_note_style, +.frm_message, +#post-body-content .frm_updated_message, +div.frm_updated_message { + border-radius: var(--small-radius); + background-color: #d5f2dc; + color: #1e561f; + padding: var(--gap-sm) var(--gap-md); + font-size: var(--text-sm); + margin: var(--gap-sm) 0; + text-align: left; +} + +.frm_note_style2 { + background: linear-gradient(90deg, #e9effa, #fcf6fe) padding-box, linear-gradient(90deg, #1961d5, #e8abef) border-box; + border: 1px solid transparent; +} + +#frm_top_bar + .wrap > .frm_updated_message, +#frm_top_bar + .wrap > .frm_warning_style { + display: inline-block; + width: 100%; + box-sizing: border-box; +} + +#post-body-content > .frm_updated_message { + margin: 5px 65px; +} + +#form_global_settings #post-body-content > .frm_updated_message, +#form_global_settings #post-body-content > .frm_warning_style { + margin: 5px 25px; +} + +.frm_error_style { + color: #973937; + background-color: #ebcccc; + clear: both; +} + +.frm_error_style a { + text-decoration: underline; + font-weight: 600; +} + +.frm_error_style svg { + opacity: 0.7; +} + +.frm_warning_style { + color: #7a4d05; + background-color: #fff2d2; +} + +.frm_warning_heading { + font-weight: 700; + margin-bottom: 4px; +} + +/* Warning message dismiss */ +.frm_warning_style { + position: relative; + padding-right: calc(var(--gap-md) + 15px); +} + +body.rtl .frm_warning_style { + padding-right: var(--gap-md); + padding-left: calc(var(--gap-md) + 15px); +} + +.frm-warning-dismiss { + position: absolute; + top: 10px; + right: 10px; + display: flex; + cursor: pointer; + transition: opacity 0.2s ease-out; +} + +body.rtl .frm-warning-dismiss { + left: 10px; + right: auto; +} + +.frm-warning-dismiss:hover { + opacity: 0.8; +} + +.frm-warning-dismiss.frmsvg, +.frm-warning-dismiss.frmsvg svg { + width: 15px; + height: 15px; +} + +.frm_note_style { + background: rgba(188, 224, 253, 0.23); + color: var(--grey-700); +} + +.frm-banner-alert { + text-align: left; + margin: 0; + border-radius: 0; + padding: 10px 0 10px 40px; +} + +.frm-banner-alert a { + color: var(--primary-500); + font-weight: 400; + text-decoration: none; +} + +.frm_updated_message ul, +.frm_updated_message li, +.frm_warning_style ul, +.frm_warning_style li, +.frm_error_style ul, +.frm_error_style li { + margin: 0; +} + +.frm-inline-message { + border: 1px solid var(--primary-700); + border-radius: var(--small-radius); + color: var(--primary-700); + background: #fff; + text-align: center; + padding: 20px; + font-size: var(--text-sm); + line-height: var(--leading); +} + +.frm-inline-message a { + text-decoration: underline; + font-weight: 600; + color: var(--primary-700); +} + +.frm_pro_heading span { + margin-top: 10px; +} + +.frm_pro_heading .alignright { + text-align: right; +} + +.frm-yes { + color: var(--green); + font-size: var(--text-xl); +} + +.frm-nope { + color: var(--grey-400); + font-size: var(--text-xl); +} + +/** + * Components - Upgrade Bar Elements + */ +.upgrade_to_pro a { + color: var(--orange); +} + +.upgrade_to_pro table .frmsvg { + height: var(--text-xl); + width: var(--text-xl); +} + +.upgrade_to_pro table.widefat { + background-color: #fff; + border-collapse: collapse; +} + +.frm-white-body .upgrade_to_pro table th, +.upgrade_to_pro table td { + padding: 10px 15px; + border: 1px solid var(--grey-300); + line-height: var(--leading); + font-size: var(--text-sm); +} + +.upgrade_to_pro table th.frmcenter { + text-align: center; +} + +/** + * Components - Table Styles + */ +.widefat th.frm_table_break { + background-color: var(--sidebar-color); +} + +/** + * Base - Howto + */ +h2.frm-h2 + .howto { + color: var(--medium-grey); + max-width: 850px; + margin: 5px 0 20px; +} + +/** + * Components - Card + */ +.frm-card { + width: 100%; + border-radius: 10px; + border: 1px solid var(--grey-300); + opacity: 1; + transition: opacity 1s; +} + +.frm-card-box { + max-width: 524px; + background-color: #fff; + border-radius: var(--medium-radius); + padding: var(--gap-xl); + border: 1px solid var(--grey-200); + box-shadow: var(--box-shadow-md); +} + +.frm-card-box.frm-has-progress-bar { + position: relative; + overflow: hidden; + border-radius: var(--medium-radius); +} + +.frm-card-box-progress-bar { + position: absolute; + top: 0; + left: 0; + right: 0; + height: var(--gap-xs); + background-color: var(--primary-25); +} + +.frm-card-box-progress-bar > span { + position: absolute; + top: 0; + left: 0; + bottom: 0; + width: 33%; + background-color: var(--primary-500); +} + +.frm-card-box-header { + display: flex; + justify-content: center; + margin-bottom: var(--gap-sm); +} + +.frm-card-box.frm-has-progress-bar .frm-card-box-header { + margin-top: var(--gap-xs); +} + +.frm-card-box-content > :last-child { + margin-bottom: 0; +} + +.frm-card-box-footer { + display: flex; + justify-content: end; + gap: var(--gap-sm); + margin-top: var(--gap-lg); +} + +.frm-card-box-title { + font-size: var(--text-xl) !important; + font-weight: 600 !important; + margin-bottom: var(--gap-xs); +} + +.frm-card-box-text { + font-size: var(--text-md) !important; + color: var(--grey-600) !important; + margin-top: 0 !important; +} + +/** + * Utilities - Fade + */ +.frm-fade { + opacity: 0; + transition: all 1s; +} + +/** + * Components - Add-on Tiles + */ +.frm-addons .frm-card.frm-addon-not-installed { + position: relative; +} + +.frm-addons .plugin-card-top { + min-height: 155px; + padding-top: var(--gap-lg); + overflow: hidden; +} + +.frm-addons .plugin-card-top h2 { + margin-top: 0; + font-weight: 400; +} + +.frm-template-row p, +.frm-addons .plugin-card-top p { + opacity: 0.8; +} + +.frm-addons .plugin-card-top > :not(p):not(h2) { + /* Hide notices from third party plugins */ + display: none; +} + +.frm-addons .plugin-card-bottom { + padding: 5px 20px 20px; + text-align: center; + background: transparent; + border-top: none; +} + +.frm-addons .plugin-card-bottom, +.frm-addons .plugin-card-bottom .button { + font-size: 15px; +} + +.frm-addons .button, +.frm-addons .frm-button-tertiary { + float: right; +} + +.frm-addons .addon-status { + float: left; + padding-top: 4px; +} + +.frm-addon-not-installed .frm-activate-addon, +.frm-addon-not-installed .frm-deactivate-addon, +.frm-addon-not-installed .frm-uninstall-addon, +.frm-addon-installed .frm-install-addon, +.frm-addon-installed .frm-deactivate-addon, +.frm-addon-active .frm-activate-addon, +.frm-addon-active .frm-install-addon, +.frm-addon-active .frm-uninstall-addon, +.plugin-card-pro.frm-addon-active .button, +.plugin-card-pro.frm-addon-active .frm-button-tertiary { + display: none !important; +} + +.frm-save-and-reload-options { + margin-top: 10px; + font-size: 13px; +} + +.frm-save-and-reload, +.frm-save-and-reload + .frm-button-secondary { + visibility: visible !important; +} + +.addon-status-label { + opacity: 0.7; +} + +.frm-addon-active .addon-status-label { + color: var(--green); + opacity: 1; +} + +.frm-addon-error { + position: absolute; + top: 55px; + left: 10px; + right: 10px; + font-weight: 700; + text-align: center; +} + +/** + * Components - Form Templates + */ +.frm-new-template.plugin-card-bottom { + overflow: visible; +} + +#frm-new-template p:first-child { + margin-top: 0; +} + +/** + * Layout - Admin Page + */ +.frm-admin-page-formidableedit #wpbody-content > *:not(.frm-review-notice):not(.frm_previous_install):not(.frm-banner-alert):not(#frm-svg-icons-pack), +#wpbody-content > .updated, +#wpbody-content > #update-nag, +#wpbody-content > .update-nag, +#wpbody-content > .notice, +#wpbody-content > .error:not(.frm_previous_install), +.frm-white-body .updated, +.frm-white-body .notice, +.frm_wrap > .wrap > .notice, +.frm-white-body .error:not(.frm_previous_install) { + display: none; +} + +.frm-admin-page-formidableedit #frm_builder_page { + display: block !important; +} + +.frm-white-body .updated, +.frm-white-body .error { + margin: 0; + padding: 10px 20px; +} + +/** + * Components - Modal + */ +.frm-modal:not(#frm-dismissable-cta) .postbox { + max-height: 600px; + overflow: hidden; + margin-bottom: 0; +} + +.frm-modal .postbox .frm_modal_top, +.frm-dialog .frm_common_modal .postbox > div:first-child, +.frm-error-modal .frm_modal_top { + padding: var(--gap-md) var(--gap-md) 0; + position: relative; +} + +.frm-modal h2, +.frm-modal .postbox .inside h2, +.frm-modal .postbox .frm-modal-title, +.frm-dialog .frm_common_modal .postbox > div:first-child > div:first-child, +.frm-error-modal .frm-modal-title { + display: inline-block; + font-size: var(--text-lg); + color: var(--grey-900); + font-weight: 600; + margin: 0; + padding: 0; +} + +.frm-modal h3 { + font-weight: 500; +} + +/* Dismiss icon button */ +.frm-inline-modal > a.dismiss, +.frm-modal .postbox > a.dismiss, +.frm-modal .postbox .frm-modal-title + div:last-child, +.frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { + position: absolute; + top: 19px; + right: 19px; + display: flex; + z-index: 2; +} + +body.rtl .frm-inline-modal > a.dismiss, +body.rtl .frm-modal .postbox > a.dismiss, +body.rtl .frm-modal .postbox .frm-modal-title + div:last-child, +body.rtl .frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { + right: unset; + left: 30px; +} + +.frm-info-modal .postbox > a.dismiss, +.frm-inline-modal > a.dismiss { + right: 13px; + top: 13px; +} + +.frm-modal .postbox .frm-modal-title + div:last-child a, +.frm-modal a.dismiss .frmsvg, +.frm_common_modal .frm_modal_top a .frmsvg { + color: var(--grey-500); +} + +.frm-modal .postbox .frm-modal-title + div:last-child a:hover, +.frm-modal a.dismiss .frmsvg:hover, +.frm_common_modal .frm_modal_top a .frmsvg:hover { + color: var(--grey-700); +} + +.frm-modal .frm_modal_content > div.inside, +.frm_common_modal .frm_modal_content > div.inside { + padding: var(--gap-md); + margin: 0; + font-size: var(--text-sm); + color: var(--grey-700); +} + +.frm-modal p { + color: var(--grey-900); +} + +.frm_common_modal .postbox { + display: flex; + flex-direction: column; +} + +.frm-modal .postbox > div.inside .cta-inside { + overflow-y: auto; + height: auto; +} + +.frm_modal_footer { + padding: 0 var(--gap-md) var(--gap-sm); + text-align: right; +} + +body.frm-body-with-open-modal { + overflow-y: hidden; +} + +/** + * Components - Template List + */ +/* These template list styles are still used to list the View types in the New View modal. */ +.frm-templates-list { + margin-top: 0; +} + +.frm-templates-list.frm_grid_container li { + margin-bottom: 0; +} + +.frm-templates-list li { + vertical-align: top; + position: relative; + box-sizing: border-box; + border-radius: 6px; + border: 1px solid transparent; + text-align: left; +} + +.frm-templates-list li:not(.frm_hidden) { + display: inline-block; +} + +.frm-templates-list.frm-categories-list li { + width: 100%; +} + +.frm-templates-list li.frm-selectable { + cursor: pointer; +} + +.frm-templates-list li.frm-selectable:hover { + background: var(--light-blue); + border-color: rgba(65, 153, 253, 0.5); +} + +.frm-templates-list li.frm-selectable:hover h3, +.frm-templates-list li.frm-selectable:hover p { + max-width: calc(100% - 65px); +} + +.frm-templates-list .frm-featured-form { + display: flex; + width: 100%; +} + +.frm-templates-list li .frm-featured-form { + padding: 7px 5px; +} + +.frm-templates-list li li > div { + padding-left: 0; +} + +.frm-templates-list li > div > div { + vertical-align: middle; +} + +.frm-category-icon, +.frm-icon-wrapper { + background: var(--primary-500); + border-radius: var(--small-radius); + color: #fff; + width: 32px; + height: 32px; + font-size: 18px; + box-sizing: border-box; + align-self: center; + justify-content: center; + align-items: center; + display: inline-flex; +} + +.frm-templates-list li .frm-category-icon { + overflow: hidden; +} + +.frm-templates-list li h3, +.frm-templates-list li p { + text-align: left; + margin: 0; + white-space: nowrap; + text-overflow: ellipsis; + overflow: hidden; +} + +.frm-templates-list li h3, +.frm-templates-list .frm-install-template h3 { + font-size: var(--text-sm) !important; +} + +.frm-templates-list .frm-install-template div { + text-align: left; +} + +#frm_leave_email, +#frm_code_from_email { + width: 480px; + max-width: 100%; +} + +.frm-templates-list.frm-categories-list li > div > div:last-child { + padding-left: 0; +} + +.frm-hover-icons { + position: absolute; + right: 0; + top: 17px; /* Template item height - borders - icon height */ + max-width: 91px; + height: 100%; + box-sizing: border-box; + padding: 0 10px 0 5px !important; + border-radius: var(--small-radius); + text-align: right; + display: flex; + gap: 5px; +} + +.frm-ready-made-solution .frm-hover-icons { + visibility: hidden; +} + +.frm-ready-made-solution:hover .frm-hover-icons { + visibility: visible; +} + +.frm-hover-icons a { + width: 22px; + height: 22px; + font-size: var(--text-md); + display: inline-flex; + align-items: center; + justify-content: center; + border-radius: 50%; + box-sizing: border-box; + line-height: var(--leading); + text-align: center; +} + +.frm-hover-icons > .frm-preview-form, +.frm-hover-icons > .frm-delete-form { + border: 1px solid var(--primary-500); +} + +.frm-hover-icons > .frm-create-form, +.frm-ready-made-solution .frm-hover-icons a { + background-color: var(--primary-500); +} + +.frm-hover-icons > a .frmsvg { + width: 14px; + height: 14px; + vertical-align: baseline; +} + +.frm-hover-icons > .frm-preview-form .frmsvg, +.frm-hover-icons > .frm-delete-form .frmsvg { + color: var(--primary-500); +} + +.frm-hover-icons > .frm-unlock-form { + background-color: var(--primary-500); +} + +.frm-hover-icons > .frm-unlock-form .frmsvg { + background-color: var(--primary-500); +} + +.frm-ready-made-solution .frmsvg { + width: 14px; + height: 14px; +} + +.frm-hover-icons .frm-create-form svg, +.frm-ready-made-solution .frm-hover-icons svg { + color: #fff; +} + +.frm-hover-icons .frm-create-form:hover, +.frm-ready-made-solution .frm-hover-icons a:hover, +.frm-hover-icons > .frm-unlock-form:hover, +.frm-hover-icons > .frm-unlock-form:hover .frmsvg { + background-color: var(--primary-700) !important; +} + +.frm-hover-icons .frm-preview-form:hover, +.frm-hover-icons .frm-delete-form:hover { + border: 1px solid var(--primary-700) !important; +} + +.frm-hover-icons .frm-preview-form:hover .frmsvg, +.frm-hover-icons .frm-delete-form:hover .frmsvg { + color: var(--primary-700) !important; +} + +.frm-application-card h4 .frmsvg, +.frm-locked-template h3 .frmsvg { + height: var(--text-sm); + width: var(--text-sm); + vertical-align: text-top; + color: var(--grey-500); +} + +/** + * Components - Modal Actions + */ +.frm-modal-back { + cursor: pointer; + margin-right: 4px; +} + +.frm-modal-cancel { + float: left; +} + +/** + * Components - Meta Tag + */ +.frm-meta-tag, +.frm-meta-tag:hover { + padding: var(--gap-2xs) var(--gap-xs); + border-radius: var(--small-radius); + font-weight: 600; + display: inline-flex; + background-color: #d9ebff; + gap: 2px; +} + +.frm-meta-tag.frm-grey-tag, +.frm-meta-tag.frm-grey-tag:hover { + background-color: var(--sidebar-hover); + color: var(--grey-900); +} + +.frm-meta-tag.frm-red-tag, +.frm-meta-tag.frm-red-tag:hover { + background: var(--error-100); + color: var(--error-700); +} + +.frm-meta-tag.frm-orange-tag, +.frm-meta-tag.frm-orange-tag:hover { + background-color: #fef7f4; + color: var(--orange); +} + +.frm-meta-tag.frm-green-tag, +.frm-meta-tag.frm-green-tag:hover { + background-color: var(--success-500); + color: #fff; +} + +.frm-entry-status-0, +.frm-meta-tag.frm-lt-green-tag, +.frm-meta-tag.frm-lt-green-tag:hover { + background-color: var(--success-100); + color: var(--success-800); +} + +.frm-meta-tag.frm-new-pill { + background-color: var(--success-500); + vertical-align: text-bottom; +} + +.frm_add_field span + .frm-meta-tag { + margin-left: 0; +} + +.dropdown-item .frm-meta-tag { + margin-left: 0; +} + +/** + * Components - Upgrade List + */ +/* Start entry statuses */ +.frm-entry-status { + font-weight: 500; +} + +.frm-entry-status-1 { + color: #7a4d05; + background: #fff2d2; +} + +/* End entry statuses */ +#frm-create-footer { + padding: 15px 20px; +} + +li .frm-hover-icons .frm-preview-form, +.frm-hover-icons .frm-unlock-form, +.frm-locked-template .frm-hover-icons .frm-create-form, +.frm-modal-back { + display: none; +} + +.frm-locked-template .frm-hover-icons .frm-unlock-form, +li[data-preview] .frm-hover-icons .frm-preview-form { + display: inline-flex; +} + +.frm-modal-back svg { + color: #7f7f7f; +} + +#frm-upgrade-body-list-wrapper > div { + display: inline-block; + width: 33.3333333333%; + vertical-align: top; + text-align: left; + margin-bottom: 10px; +} + +#frm-upgrade-body-list-wrapper ul { + padding-left: 40px; +} + +#frm-upgrade-body-list-wrapper ul li::before { + content: "\2022"; + color: var(--primary-500); + display: inline-block; + width: 1em; + margin-left: -1em; +} + +/** + * Components - Embed Modal + */ +.frm-embed-modal-content { + padding: var(--gap-md); +} + +.frm-embed-modal-content.frm-loading-page-options { + display: flex; + justify-content: center; +} + +#frm_embed_modal .frm_embed_example { + background: var(--sidebar-color); + border: 1px solid var(--sidebar-hover); + border-radius: var(--small-radius); + color: var(--grey-900); + font-size: var(--text-sm); + padding-right: var(--gap-lg); + width: 100%; + height: auto !important; + resize: none; +} + +#frm_embed_modal textarea.frm_embed_example { + padding-bottom: 0; +} + +.frm-embed-modal-content > div a { + position: absolute; + right: 0; + top: 0; +} + +.frm-embed-modal-content > div { + position: relative; + margin-bottom: var(--gap-sm); +} + +.frm-embed-modal-content > div:last-child { + margin-bottom: 0; +} + +.frm-embed-modal-content svg[id^=frm_copy_embed_] { + position: absolute; + bottom: 10px; /* Input height - SVG height */ + right: 10px; + cursor: pointer; + opacity: 0.5; +} + +.frm-border-info-box, +.frm-embed-modal-option { + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + padding: var(--gap-sm); + cursor: pointer; + display: flex; + gap: var(--gap-sm); + font-size: var(--text-sm); +} + +.frm-embed-modal-option + .frm-embed-modal-option { + margin-top: var(--gap-sm); +} + +.caret.rotate-270, +.frm-embed-modal-option .caret { + align-self: center; + margin-left: auto; + transform: rotate(-90deg); +} + +#frm_embed_modal .frm_modal_footer { + display: none; +} + +#frm_embed_modal.frm-on-page-2 .frm_modal_footer { + display: block; +} + +.frm-embed-modal-content ul { + max-height: 300px; + overflow-y: scroll; +} + +.frm-embed-modal-wrapper.frm-dialog { + overflow: visible; +} + +/** + * Components - Bulk Options + */ +#frm-bulk-modal .frm_grid_container { + grid-template-columns: repeat(12, 8.33%); + grid-gap: 0; +} + +#frm-bulk-modal .frm8 { + border-right: 1px solid var(--grey-300); + padding: 10px 20px 10px var(--gap-lg); +} + +#frm-bulk-modal .frm4 { + padding: 10px 0; +} + +.frm-inline-modal .howto { + margin: 5px 0 10px; + color: var(--grey); +} + +.frm-inline-modal .frm_code_list + .howto { + margin-bottom: 0; +} + +#frm_bulk_options { + height: 240px; + width: 100%; + border: none; + box-shadow: none; + padding: 0; +} + +.frm-bulk-edit-link { + display: flex; + align-items: center; + justify-content: flex-end; + gap: var(--gap-2xs); + font-size: var(--text-sm); + margin: 12px 0 12px auto; +} +.frm-bulk-edit-link .frm-bulk-edit-link { + margin: 0; +} + +/** + * Components - Small Add + */ +.frm-small-add { + font-size: var(--text-sm) !important; +} + +.frm-small-add span { + color: var(--primary-500); + font-size: 12px; + height: 12px; + width: 12px; +} + +/** + * Components - Image From URL + */ +.frm_no_captcha_text { + font-weight: 700; + color: #a00; +} + +.frm_image_from_url { + height: 50px; +} + +/** + * Components - Dropdown + */ +/*Switch form dropdown*/ +h1 .fa-caret-down { + font-size: 18px; +} + +.caret { + display: inline-block; + width: 19px; + height: 9px; + margin-right: -8px; + vertical-align: middle; +} + +.caret, +.wp-admin .frm_wrap select, +.frm_wrap .frm_form_builder select, +.frm_wrap .ui-autocomplete-input { + background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; + padding-right: var(--gap-lg) !important; +} + +.caret { + padding-right: var(--gap-xs) !important; + background-position-x: 5px; +} + +.frm-btn-group .caret { + float: right; + margin-top: calc(var(--text-md) / 2); +} + +.dropdown { + position: relative; +} + +.dropdown-toggle:focus { + outline: 0; +} + +.frm_wrap .ui-autocomplete, +#frm_adv_info.frm-dropdown-menu, +.frm-dropdown-menu { + /* Copied from .dropdown-menu rules from Bootstrap */ + position: absolute; + top: 100%; + left: 0; + z-index: 1000; + display: none; + padding-left: 4px; + padding-right: 4px; + margin: var(--gap-xs) 0 0; + text-align: left; + list-style: none; + background: none; + background-color: #fff; + background-clip: padding-box; + border: 1px solid var(--grey-100); + border-radius: 0.25rem; + box-shadow: var(--box-shadow-lg); + /* Custom rules */ + max-height: 200px; + overflow-y: auto; + overflow-x: hidden; + font-size: var(--text-md); + width: auto; + min-width: 160px; +} + +.frm6 .frm-dropdown-menu { + min-width: 100px; + max-width: 99%; +} + +#frm_bs_dropdown .frm-dropdown-menu { + max-width: 400px; +} + +.field_type_list .frm-dropdown-menu { + min-width: 150px !important; +} + +#frm_field_group_controls .frm-dropdown-menu, +.frm-field-action-icons .frm-dropdown-menu { + min-width: 180px !important; +} + +.frm-field-action-icons .frm-dropdown-toggle svg, +#frm_field_group_controls .frm-dropdown-toggle svg { + color: #9ea9b8; +} + +.multiselect-container.frm-dropdown-menu, +#search-submit .frm-dropdown-menu { + min-width: 200px !important; +} + +.preview .frm-dropdown-menu { + min-width: 230px !important; +} + +.frm-dropdown-menu.dropdown-menu-right { + right: 0; + left: auto; +} + +.frm-dropdown-menu .divider { + height: 1px; + margin: 9px 0; + overflow: hidden; + background-color: #e5e5e5; +} + +.frm-dropdown-menu > .dropdown-item { + margin: 0; +} + +.frm-select-list-item, +.frm_wrap .ui-autocomplete li > div, +.multiselect-container button.multiselect-option, +.frm-dropdown-menu > .dropdown-item > a, +.frm-dropdown-menu .frm_dropdown_li { + clear: both; + font-weight: 400; + white-space: nowrap; + text-decoration: none; + border-radius: var(--small-radius); +} + +.frm-dropdown-menu > .active > a, +.frm-dropdown-menu > .active > a:hover, +.frm-dropdown-menu > .active > a:focus { + text-decoration: none; + outline: 0; +} + +.frm-select-list-item.disabled, +.frm-dropdown-menu > .disabled > a, +.frm-dropdown-menu > .disabled > a:hover, +.frm-dropdown-menu > .disabled > a:focus { + color: #999; +} + +.frm-select-list-item.disabled:hover, +.frm-dropdown-menu > .disabled > a:hover, +.frm-dropdown-menu > .disabled > a:focus { + text-decoration: none; + background-color: transparent; + background-image: none; + cursor: not-allowed; +} + +.open > .frm-dropdown-menu { + display: block; +} + +.open > a { + outline: 0; +} + +.dropdown-header { + display: block; + padding: 3px 10px; + font-size: var(--text-xs); + color: var(--grey-400); +} + +.dropdown-backdrop { + position: fixed; + left: 0; + right: 0; + bottom: 0; + top: 0; + z-index: 990; +} + +.dropdown-menu-right > .frm-dropdown-menu, +.pull-right > .frm-dropdown-menu { + right: 0; + left: auto; +} + +.navbar-fixed-bottom .dropdown .caret { + border-top: 0 dotted; + border-bottom: 4px solid #000; + content: ""; +} + +.navbar-fixed-bottom .dropdown .frm-dropdown-menu { + top: auto; + bottom: 100%; + margin-bottom: 1px; +} + +.btn { + border: 1px solid #ddd; + background: #fff; + height: 28px; + line-height: var(--leading); +} + +a.frm_option_icon::before { + color: var(--primary-500); + font-size: 22px; + width: 22px; + height: 22px; +} + +a.frm_option_icon:focus::before, +a.frm_option_icon:hover::before { + color: var(--primary-700); +} + +.frm_top_left .frm-dropdown-toggle { + color: #999; +} + +.frm-card ol { + margin-left: 15px; +} + +.frm-dropdown-toggle { + text-decoration: none; +} + +.frm-card .frm-dropdown-toggle { + border: 1px solid var(--grey-300); + border-radius: var(--small-radius); + font-size: 13px; + color: var(--grey-700); + padding: 7px 20px; +} + +.frm-dropdown-menu .frm_icon_font { + vertical-align: middle; + color: #5f6c72; + margin-right: 3px; +} + +/* BS Multiselect */ +.multiselect-container.frm-dropdown-menu { + top: auto; + left: auto; + font-size: var(--text-sm); + padding: 4px; + margin-bottom: 3px; +} + +/** + * Accordion + */ +#post-body-content + .frm-right-panel h3.accordion-section-title { + padding: 7px 10px 8px 14px; + font-size: var(--text-md); + color: var(--grey-700); +} + +.frm-with-line, +.accordion-section-content h4 { + font-size: var(--text-md); + font-weight: 400; + margin: 20px -20px 10px; + padding: 0 20px; + color: var(--grey-700); + position: relative; + border: none !important; +} + +.frm-with-line span, +.accordion-section-content h4 span { + background: #fff; + padding: 0 var(--gap-xs); + position: relative; + display: inline-block; + z-index: 2; +} + +.accordion-section-content h4 span { + background: var(--sidebar-color); +} + +.frm-right-panel .frm-with-line span { + background: var(--sidebar-color) !important; + margin-left: -4px; +} + +.frm-right-panel .frm-inline-modal .frm-with-line span { + background: #fff !important; +} + +.frm-with-line::before, +.accordion-section-content h4::before { + content: ""; + display: block; + position: absolute; + border-bottom: 1px solid var(--grey-300); + left: 0; + width: 100%; + top: 50%; +} + +.control-section .accordion-section-title::after, +.customize-pane-child .accordion-section-title::after { + top: 15px; +} + +.accordion-container .frm-dropdown-menu { + min-width: 40px; +} + +.frm-btn-group .multiselect.dropdown-toggle { + box-sizing: border-box; + min-height: unset; + cursor: pointer; +} + +.accordion-container .frm-dropdown-menu::before, +.accordion-container .multiselect.dropdown-toggle::before { + font-family: "s11-fp" !important; +} + +/** + * Components - Multiselect + */ +.multiselect-container { + position: absolute; + list-style-type: none; + margin: 0; + padding: 0; + width: 100%; + max-width: 250px; +} + +.multiselect-container button.multiselect-option { + width: 100%; + text-align: left; + border: none; + margin-bottom: 4px; +} + +.multiselect-container button.multiselect-option label { + margin-left: 5px; +} + +.accordion-container .multiselect-container label { + padding: 3px 19px 3px 7px; +} + +.frm-btn-group.btn-group > .btn-group:nth-child(2) > .multiselect.btn { + border-top-left-radius: 4px; + border-bottom-left-radius: 4px; +} + +.frm-btn-group.btn-group, +.frm-btn-group.btn-group-vertical { + display: block; +} + +.multiselect-option label { + max-width: calc(100% - 22px); + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; +} + +/** + * Components - Fields + */ +.frm_scale { + text-align: center; + float: left; + margin-right: 10px; +} + +.frm_scale input { + display: block; + margin: 5px; +} + +.frm_multi_fields_container { + float: left; +} + +.frm_multi_fields_container, +.frm_form_builder .frm_form_fields input[type=tel] .frm_form_builder .frm_form_fields input[type=range], +.frm_form_builder .frm_form_fields input[type=text] { + width: 100%; + height: auto; +} + +.frm_form_builder .frm_time_wrap .frm_time_sep { + vertical-align: sub; + vertical-align: -webkit-baseline-middle; +} + +.frm_form_builder input[type=range]::-webkit-slider-runnable-track { + background-color: var(--blue-border); +} + +.frm_form_builder input[type=range]::-moz-range-track { + background-color: var(--blue-border); +} + +.frm_form_builder input[type=range]::-ms-fill-lower { + background-color: var(--blue-border); +} + +.frm_form_builder input[type=range]::-ms-fill-upper { + background-color: var(--blue-border); +} + +.frm-embed-field-placeholder { + text-align: center; + height: 145px; + display: flex; + align-items: center; + justify-content: center; +} + +.frm-fake-field { + display: block; + height: 25px; + background-color: var(--light-blue); + border: 1px solid var(--grey-300); + margin: 10px 0; + border-radius: var(--small-radius); +} + +.frm-embed-message { + position: absolute; + background: #fff; + border: 1px solid var(--grey-300); + color: var(--grey-700); + padding: var(--gap-md); + font-size: var(--text-lg); + max-width: 200px; + min-width: 50%; + margin: 0 var(--gap-md); + overflow: hidden; + text-overflow: ellipsis; +} + +.frm-summary-message { + top: 50%; + left: 50%; + padding: 15px 0; + font-size: var(--text-md); + transform: translate(-50%, -50%); +} + +.frm-summary-learn-more { + font-size: inherit !important; +} + +.frm-single-settings .frm-embed-message { + width: 100%; + position: static; + border-radius: var(--small-radius); +} + +#new_fields input[type=text], +#new_fields input[type=number], +.frm_field_box .frm_form_fields > textarea, +.frm_form_fields .frm_form_field > textarea, +.frm_form_fields .frm_form_field > input[type=email], +.frm_form_fields .frm_form_field > input[type=url], +.frm_form_fields .frm_form_field > input[type=number], +.frm_form_fields .frm_form_field > input[type=tel], +.frm_form_fields .frm_form_field > input[type=text], +.frm_form_fields .frm_form_field > input[type=range] { + width: 100%; +} + +.frm_form_fields textarea.wp-editor-area { + width: 100%; + border: none; +} + +.frm_form_fields input[type=file], +.frm_form_fields input[type=file]:disabled { + background: transparent; + border: none; + box-shadow: none; + width: auto; +} + +.frm_form_fields select { + width: auto; + max-width: 100%; +} + +input[type=radio], +input[type=checkbox] { + width: 16px; + padding: 0; +} + +.frm_grid_container > p, +.frm_grid_container > p.frm_form_field, +.frm_grid_container > div.frm_form_field, +#new_fields .frm_grid_container > p { + margin-top: 8px; + margin-bottom: 8px; + margin-right: 0; +} +.frm_grid_container > p > label:only-child, +.frm_grid_container > p.frm_form_field > label:only-child, +.frm_grid_container > div.frm_form_field > label:only-child, +#new_fields .frm_grid_container > p > label:only-child { + margin-bottom: 0; +} + +.frm_grid_container > .frm-has-modal > p:only-child { + margin-bottom: var(--gap-xs); +} + +#new_fields div.frm_grid_container > .frm_primary_label { + margin-top: 8px; +} + +#new_fields .frm_primary_label + p, +#new_fields .frm_primary_label + .frm6 + .frm6, +#new_fields .frm_primary_label + .frm6 + .frm-inline-modal + .frm6 { + margin-top: 0; +} + +.frm_catlevel_2, +.frm_catlevel_3, +.frm_catlevel_4, +.frm_catlevel_5 { + margin-left: 18px; +} + +.frm_wrap .frm-fields .auto_width, +.frm_form_fields input.auto_width, +.frm_form_fields select.auto_width, +.frm_form_fields textarea.auto_width { + width: auto !important; +} + +.frm_form_fields select.auto_width { + min-width: 60px; +} + +.frm_form_fields input:focus, +.frm_form_fields select:focus, +.frm_form_fields textarea:focus, +.frm_focus_field input { + background-color: #fff; + border-color: #ddd; +} + +.frm_form_builder .frm_radio, +.frm_form_builder .frm_checkbox { + display: block; + margin-bottom: 2px; +} + +.frm_form_builder .frm_radio label, +.frm_form_builder .frm_checkbox label { + font-size: var(--text-sm); +} + +/** + * Components - Copied Frontend + */ +.horizontal_radio .frm_radio, +.horizontal_radio .frm_checkbox { + margin-right: 5px; + display: inline-block; +} + +.frm_form_builder .frm_opt_container .frm_radio.frm_image_option label, +.frm_form_builder .frm_opt_container .frm_checkbox.frm_image_option label { + display: flex; + align-items: center; + gap: 9px; + white-space: normal; +} + +.frm_form_field.frm_two_col .frm_opt_container, +.frm_form_field.frm_three_col .frm_opt_container, +.frm_form_field.frm_four_col .frm_opt_container { + display: grid; + grid-template-columns: repeat(2, 1fr); + grid-auto-rows: max-content; + grid-gap: 0 2.5%; +} + +.frm_form_field.frm_three_col .frm_opt_container { + grid-template-columns: repeat(3, 1fr); +} + +.frm_form_field.frm_four_col .frm_opt_container { + grid-template-columns: repeat(4, 1fr); +} + +.frm_form_field.frm_two_col .frm_radio, +.frm_form_field.frm_two_col .frm_checkbox, +.frm_form_field.frm_three_col .frm_radio, +.frm_form_field.frm_three_col .frm_checkbox, +.frm_form_field.frm_four_col .frm_radio, +.frm_form_field.frm_four_col .frm_checkbox { + grid-column-end: span 1; +} + +/** + * Components - Fields Part 2 + */ +.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox], +.frm_wrap .with_frm_style .frm_radio input[type=radio], +.frm_wrap input[type=checkbox], +.frm-white-body input[type=checkbox], +.field-group input[type=checkbox], +.frm_scale input[type=radio], +.frm_radio input[type=radio], +.frm_checkbox input[type=checkbox] { + width: 15px; + min-width: 15px; + height: 15px; + border: 1px solid var(--grey-300); + box-shadow: var(--box-shadow-sm); + -webkit-appearance: none; +} + +.frm_wrap input[type=radio] { + border-color: var(--grey-300); + box-shadow: var(--box-shadow-sm); +} +.frm_wrap input[type=radio]:checked::before { + background-color: var(--primary-500); +} + +.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox], +.frm_wrap input[type=checkbox], +.frm-white-body input[type=checkbox], +.field-group input[type=checkbox], +.frm_checkbox input[type=checkbox] { + border-radius: 4px; +} + +.frm-white-body input[type=checkbox]:checked, +.frm_wrap input[type=checkbox]:checked { + background-color: var(--border-color-active, var(--primary-500)) !important; + border-color: var(--border-color-active, var(--primary-500)) !important; +} + +.frm-white-body input[type=checkbox]:checked:focus, +.frm_wrap input[type=checkbox]:checked:focus { + border-color: var(--border-color-active, var(--primary-500)); +} + +.frm-white-body input[type=checkbox]:checked::before, +.frm_wrap input[type=checkbox]:checked::before { + content: ""; + display: block; + width: 100% !important; + height: 100% !important; + background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.6667 1.5L4.25001 7.91667L1.33334 5' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A") !important; + background-size: 8px !important; + background-repeat: no-repeat !important; + background-position: center !important; + margin: 0; +} + +.frm_radio input[type=radio], +.frm_checkbox input[type=checkbox] { + margin-right: 5px; +} + +.frm_inner_field_container { + margin-bottom: 10px; +} + +.frm_conf_inline .frm_inner_field_container, +.frm_conf_inline .frm_inner_conf_container { + width: 49%; + float: left; +} + +.frm_conf_inline .frm_inner_field_container { + margin-right: 2%; + clear: both; +} + +.frm_inner_field_container > label { + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; +} + +.frm_field_box:not(.edit_field_type_divider):hover > .frm_inner_field_container > label, +.frm_field_box .divider_section_only:hover > .frm_inner_field_container > label, +li.ui-state-default.selected > .frm_inner_field_container > label { + max-width: calc(100% - 100px); +} + +.frm-drag-fade { + background-color: var(--lightest-grey) !important; + border-radius: 4px; +} + +.frm-drag-fade * { + opacity: 0; +} + +.frm-dragging .divider_section_only, +.frm-dragging .frm_field_box { + pointer-events: none; +} + +.frm_form_settings #op-popup, +.frm_form_settings com-1password-op-button, +.frm_conf_below .frm_conf_field_container .frm_primary_label, +.frm_conf_inline .frm_inner_field_container .frm-show-click a, +.frm_conf_below .frm_conf_field_container .frm-show-click a { + display: none !important; +} + +.frm_conf_inline .frm_inner_field_container .frm-field-action-icons { + position: absolute; + right: 5px; +} + +.frm_conf_below .frm_conf_field_container { + margin-top: 10px; +} + +.frm_calc_dec { + width: 50px; +} + +.frm_ext_sc { + display: none; +} + +.frm_long_input { + width: 100% !important; + box-sizing: border-box; +} + +/** + * Utilities - Text Align - Part 2 + */ +.frmcenter { + text-align: center; +} + +/** + * Components - Image Help + */ +img.frm_help { + margin-left: 2px; + vertical-align: middle; + padding-bottom: 2px; +} + +/** + * Components - Loading + */ +.frm_spinner.frm-wait, +.frm_spinner.spinner { + float: left; + visibility: hidden; + margin: 0 10px; +} + +.frm_visible_spinner.frm-wait, +.frm_visible_spinner.spinner { + visibility: visible; + float: none; +} + +.frm_form_action_settings .frm_spinner.frm-wait, +.frm_form_action_settings .frm_spinner.spinner { + visibility: visible; + float: none; + vertical-align: bottom; +} + +.frm_form_action_settings .frm_loading { + font-size: 15px; + text-align: center; +} + +.frm_ajax_settings_tab .frm-wait, +.frm_ajax_settings_tab .spinner { + visibility: visible; + float: none; + margin-top: 20px; +} + +.wp-core-ui .frm_loading_button.button-primary.frm-button-primary, +.frm_loading_button, +.frm_loading_form.frm_button_submit { + position: relative !important; + opacity: 0.8; + color: transparent !important; + text-shadow: none !important; +} + +.frm_loading_button:hover, +.frm_loading_button:active, +.frm_loading_button:focus, +.frm_loading_form.frm_button_submit:hover, +.frm_loading_form.frm_button_submit:active, +.frm_loading_form.frm_button_submit:focus { + cursor: not-allowed; + color: transparent !important; + outline: none !important; + box-shadow: none; +} + +.frm-wait { + margin: 20px; + width: 20px; + height: 20px; + position: relative; + display: inline-block; +} + +#frm-show-fields .frm-wait:only-child { + position: absolute; + left: 50px; + top: 30px; +} + +.frm-wait::before, +.frm_loading_button::before, +.frm_loading_form.frm_button_submit::before { + content: ""; + display: inline-block; + position: absolute; + background: transparent; + border: 1px solid #fff; + border-top-color: transparent; + border-left-color: transparent; + border-radius: 50%; + box-sizing: border-box; + top: 50%; + left: 50%; + margin-top: -10px; + margin-left: -10px; + width: 20px; + height: 20px; + animation: spin 2s linear infinite; +} + +.frm-wait::before { + border-bottom-color: var(--primary-700); + border-right-color: var(--primary-700); +} + +.frm_loading_button.frm-button-secondary::before { + border-bottom-color: var(--primary-500); + border-right-color: var(--primary-500); +} + +input[type=submit]:focus { + outline: none !important; +} + +/* Effects */ +@keyframes spin { + 0% { + transform: rotate(0deg); + } + 100% { + transform: rotate(360deg); + } +} +/** + * Components - Fields Part 3 + */ +label input[type=checkbox], +label input[type=radio] { + vertical-align: inherit; +} + +#editorcontainer #dyncontent { + margin: 0; + width: 100%; + padding: 6px; + line-height: var(--leading); + border: 0 none; + outline: none; + box-sizing: border-box; +} + +/*ICONS*/ +.frm_postbox_icon { + margin: -6px 0 0 -10px; +} + +.frm_form_builder a:hover { + text-decoration: underline; +} + +.frm_form_builder .widget-title h4 { + padding: 10px 15px; +} + +.frm_form_builder .widget-top a.widget-action::after { + margin: 7px 12px 0; +} + +.frmbutton.frm_tgateway { + display: none !important; +} + +.frm_html_legend pre { + display: inline; +} + +#ed_fullscreen { + display: none !important; +} + +.frm_posttax_opt_list { + overflow: auto; + max-height: 200px; + background-color: #fff; +} + +.frm_posttax_opt_list p.howto { + font-size: 12px; +} + +.frm_border_bottom { + border-bottom: 1px solid var(--grey-300); + margin-bottom: 10px; + padding-bottom: 10px; +} + +.frm_posttax_opt_list .frm_border_bottom span.howto { + padding-right: 10px; +} + +.frm_posttax_opt_list .frm_border_bottom input { + margin-right: 1px; +} + +.frm_add_remove div.frm_form_field { + padding-bottom: 5px; +} + +.frm_field_opts_list { + max-height: 260px; + overflow: auto; +} + +/** + * Utilities - Background + */ +.frm_white_bg, +.frm-bg-white { + background-color: #fff; +} + +.frm-bg-grey-50 { + background-color: var(--grey-50); +} + +.frm-bg-grey-200 { + background-color: var(--grey-200); +} + +.frm-bg-grey-800 { + background-color: var(--grey-800); +} + +.frm-bg-primary-500 { + background-color: var(--primary-500); +} + +/** + * Utilities - Border - Light + */ +.frm_border_light { + border: solid 1px #ddd; +} + +/** + * Components - Form Input Styles + */ +#new_fields .form-table input[type=text], +#new_fields .form-table select, +.form-table .form-field input, +.form-table .form-field .quicktags-toolbar input, +.form-field input, +.form-field .quicktags-toolbar input { + width: auto; +} + +/** + * Components - Affiliate Link + */ +.frm_aff_link { + float: right; +} + +/** + * Component: Select Box + */ +.frm_select_box { + text-align: center; + font-weight: 700; + width: 100%; + background-color: transparent !important; +} + +.wp-list-table input.frm_select_box { + text-align: left; + font-weight: 400; + font-size: inherit !important; + border: none; + padding: 0 !important; + background-color: transparent !important; +} + +.wp-list-table input.frm_select_box:focus { + outline: none; + box-shadow: none; +} + +.wp-list-table .frm_no_items.frm_select_box { + text-align: center; + font-weight: 700; + width: 500px; + max-width: 100%; + font-size: inherit; +} + +/** + * Component: Options Panel + */ +#frm-options-panel { + padding: 0 var(--gap-sm); + color: var(--grey-900); + overflow: hidden; +} + +.frm-right-panel a.frm_add_logic_link, +#frm-options-panel h3, +.frm-collapsible { + font-size: var(--text-md); + font-weight: 500; + background-color: #fff; + border-radius: var(--small-radius); + padding: 18px var(--gap-sm); + margin: 2px calc(-1 * var(--gap-sm)); + transition: background-color 200ms ease-out, box-shadow 200ms ease-out, color 200ms ease-out; +} +.frm-right-panel a.frm_add_logic_link .frmsvg, +#frm-options-panel h3 .frmsvg, +.frm-collapsible .frmsvg { + width: 13px; + height: 13px; + color: var(--grey-500); + transition: transform 300ms ease-in; +} +.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type), .frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child, +#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type), +#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child, +.frm-collapsible:not(.frm-collapsed):not(:first-of-type), +.frm-collapsible:not(.frm-collapsed):first-of-type:first-child { + color: var(--grey-700); + box-shadow: var(--box-shadow-sm); +} +.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type) .frmsvg, .frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child .frmsvg, +#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type) .frmsvg, +#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child .frmsvg, +.frm-collapsible:not(.frm-collapsed):not(:first-of-type) .frmsvg, +.frm-collapsible:not(.frm-collapsed):first-of-type:first-child .frmsvg { + transform: rotate(-180deg); +} +.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div, +#frm-options-panel h3:not(.frm-collapsed) + div, +.frm-collapsible:not(.frm-collapsed) + div { + padding-top: 6px; + padding-bottom: 6px; +} +.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div.frm_grid_container, +#frm-options-panel h3:not(.frm-collapsed) + div.frm_grid_container, +.frm-collapsible:not(.frm-collapsed) + div.frm_grid_container { + padding-bottom: 14px; +} +.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div.frm_grid_container > p:first-child, +#frm-options-panel h3:not(.frm-collapsed) + div.frm_grid_container > p:first-child, +.frm-collapsible:not(.frm-collapsed) + div.frm_grid_container > p:first-child { + margin-top: var(--gap-sm); +} +.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div.frm_grid_container > p:first-child.frm6 + .frm6, +#frm-options-panel h3:not(.frm-collapsed) + div.frm_grid_container > p:first-child.frm6 + .frm6, +.frm-collapsible:not(.frm-collapsed) + div.frm_grid_container > p:first-child.frm6 + .frm6 { + margin-top: var(--gap-sm); +} +.frm-right-panel a.frm_add_logic_link.frm-collapsed, +#frm-options-panel h3.frm-collapsed, +.frm-collapsible.frm-collapsed { + color: var(--grey-500); + background-color: transparent; +} +.frm-right-panel a.frm_add_logic_link:hover, +#frm-options-panel h3:hover, +.frm-collapsible:hover { + color: var(--grey-700); + background-color: #fff; + box-shadow: var(--box-shadow-sm); +} +.frm-right-panel a.frm_add_logic_link:focus-visible, +#frm-options-panel h3:focus-visible, +.frm-collapsible:focus-visible { + outline: 1px solid var(--primary-500) !important; + outline-offset: -1px; +} + +h4.frm-collapsible:hover { + box-shadow: none; +} + +.frm-right-panel a.frm_add_logic_link:focus { + outline: auto; +} + +/** + * Component: Field Key + */ +.frm_field_key { + background-color: #f7f7f7; +} + +/** + * Component: Form Editor + */ +#frm_form_editor_container #edit-slug-box { + padding: 0; +} + +/** + * Component: Alt Table + */ +.frm-alt-table { + position: relative; + width: 100%; + border-collapse: collapse; + margin-top: 0.5em; + font-size: 15px; +} + +/* Before `applyZebraStriping` is executed, an empty space is displayed */ +#form_show_entry_page .frm-alt-table:not(.frm-zebra-striping)::before { + content: ""; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background-color: #fff; +} + +.frm-alt-table th { + width: 200px; +} + +.frm-alt-table tr, +.frm-alt-table tr.frm-odd { + background-color: transparent; +} + +.frm-alt-table tr.frm-even { + background-color: var(--sidebar-color); +} + +.frm-alt-table th, +.frm-alt-table td { + background-color: transparent; + vertical-align: top; + text-align: left; + padding: 20px; +} + +.frm-alt-table h3 { + margin-bottom: 0; +} + +/** + * Component: Checkbox Button + */ +.form-field .frm_cb_button { + height: 22px; + line-height: 20px; + margin-bottom: 10px; + margin-right: 5px; +} + +/** + * Option Label + */ +.edit_field_type_select .frm_option_val_label { + margin-left: 12px; +} + +/** + * Components - Rich Text Editor + */ +.frm_rte { + background: url(../images/rte.png) no-repeat; +} + +.frm_rte .howto { + margin: 10px 0 46px; +} + +/** + * Component: Subform Section + */ +.subform_section { + margin: 25px; +} + +.subform_section, +.subform_section label, +.subform_section input { + opacity: 80; +} + +.subform_section .frm_sortable_field_opts { + display: none; +} + +#frm_form_editor_container .subform_section .frm_primary_label { + display: block; +} + +.subform_section.subform_break { + border-top: 1px dashed #ccc; +} + +/** + * Component: HTML Field + */ +.button-secondary.frm_html_field { + background-color: #ededed; + padding: 10px 20px; + line-height: inherit; + width: auto; + height: auto !important; + border-radius: 0; + box-sizing: content-box; +} + +.frm_html_field_placeholder { + margin-bottom: 10px; + text-align: center; +} + +.recaptcha_placeholder { + border: 1px solid #d3d3d3; + width: 300px; +} + +.turnstile_placeholder { + width: 300px; +} + +/** + * Component: RTE Textarea + */ +.frm_sorting .frm_rte textarea { + width: 653px; + background: #fff; + margin: 1px 0 0; + border: 1px solid #dfdfdf; + border-top: none; + border-radius: 0; + float: none !important; +} + +.frm_full_rte textarea { + width: 98%; + padding: 0; +} + +/** + * Component: Field Box + */ +.frm_field_box { + padding: 5px; + min-height: 20px; + margin: 10px 0; +} + +/** + * Components - Indent Options + */ +.frm_indent_opt, +td.frm_indent_opt { + padding-left: 25px; +} + +/** + * Components - Charts + */ +.frm_charts object { + background: transparent; +} + +.frm_charts h2 { + height: 34px; +} + +/** + * Component: Sortable Placeholder + */ +.frm_single_option.ui-sortable-placeholder, +li.sortable-placeholder { + border: none; + margin: 0; + visibility: visible !important; + box-shadow: 2px -10px 0 2px var(--primary-500); +} + +#frm_form_editor_container > ul > .frm_single_option.ui-sortable-placeholder, +#frm_form_editor_container > ul > li.sortable-placeholder { + width: calc(100% - 5px) !important; + height: 0 !important; +} + +#frm_form_editor_container > ul > li > ul { + position: relative; +} + +#frm_form_editor_container > ul > li > ul > li.sortable-placeholder, +#frm_form_editor_container ul.start_divider > li > ul > li.sortable-placeholder { + position: absolute; + top: 20px; + bottom: 0; +} + +.edit_field_type_divider + li.sortable-placeholder { + box-shadow: 2px 5px 0 2px var(--primary-500); +} + +.start_divider li.sortable-placeholder { + box-shadow: 2px -5px 0 2px var(--primary-500); +} + +.frm-is-collapsed + .sortable-placeholder { + box-shadow: 2px 15px 0 2px var(--primary-500); +} + +.frm_single_option.ui-sortable-placeholder { + box-shadow: 0 0 1px 1px var(--primary-500); +} + +/** + * Component: Sorting Display + */ +.frm_sorting > li.edit_field_type_end_divider:first-child, +.frm-show-click, +li.ui-state-default.edit_field_type_divider .frm-show-click { + display: none; +} + +.frm_form_field.ui-sortable-helper .frm-field-action-icons, +.frm_form_field.ui-sortable-helper .frm_form_fields, +.frm_form_field.ui-sortable-helper .frm_description, +.frm_form_field.ui-sortable-helper .description { + display: none; +} + +.frm_form_field.ui-sortable-helper .frm_primary_label, +.frm_form_field.ui-sortable-helper .frm_inner_field_container { + margin: 0 !important; +} + +.frm-single-settings .frm-show-click { + display: block !important; +} + +.frm-show-hover, +.frm_single_visible_hover, +li.ui-state-default.edit_field_type_divider .frm-show-hover { + opacity: 0; + transition: opacity 0.15s ease-in-out; +} + +#frm-show-fields .frm-field-settings-open .frm-show-hover { + opacity: 1; +} + +.frm_sortable_field_opts { + margin-top: 5px; +} + +/** + * Component: Single Option + */ +.frm_single_option { + clear: both; + margin: 0 !important; + padding-bottom: 5px; +} +.frm_single_option input[type=radio], +.frm_single_option input[type=checkbox] { + margin-top: 0; +} +.frm_single_option .frm-with-right-icon input[type=text] + .frmsvg { + position: relative; + right: 27px; + width: 14px; + height: 14px; + padding: 0; + margin: var(--gap-2xs) 0 0; +} + +.frm_product_price_wrapper, +.frm_image_preview_wrapper, +#new_fields .frm_single_option select, +#new_fields .frm_single_option input[type=text] { + width: calc(100% - 106px) !important; + flex-grow: 1; +} + +.frm-right-panel .frm_single_option a.frm_remove_tag, +.frm_single_option a { + padding-left: 7px; +} + +.frm_single_option:hover .frm_single_visible_hover { + opacity: 100; +} + +.frm_single_option .frm-drag { + font-size: 23px; + width: 24px; + height: 24px; + margin-left: -6px; + margin-right: var(--gap-xs); + color: var(--grey-500); +} + +.frm_single_option .frm-drag::before { + vertical-align: middle; +} + +.frm-drag, +.frm_single_option.ui-sortable-helper { + cursor: move; +} + +.frm_single_option .frm_option_key.frm_image_preview_wrapper, +.frm-type-ranking .frm_single_option .frm_option_key { + margin-left: 21px !important; +} + +.frm_option_key input[type=text] { + margin-top: var(--gap-xs) !important; + margin-left: 11px !important; +} +.frm_option_key input[type=checkbox] + input[type=text], +.frm_option_key input[type=radio] + input[type=text] { + margin-left: 30px !important; +} + +.frm-type-ranking .frm_option_key input[id*=field_key_] { + margin-left: 30px !important; +} + +li.ui-state-default.selected .frm-show-click, +li.ui-state-default.selected.edit_field_type_divider .frm-show-click { + display: inline; + vertical-align: top; +} + +.frm_field_box:not(.edit_field_type_divider):hover > .frm_inner_field_container > .frm-show-hover, +.frm_field_box .divider_section_only:hover > .frm_inner_field_container > .frm-show-hover, +li.ui-state-default.selected > .frm_inner_field_container > .frm-show-hover, +li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover { + opacity: 100; +} + +li.frm_field_box > ul.frm_grid_container { + position: relative; +} + +/** + * Component: UI Icon + */ +.frm_sorting span.ui-icon { + width: 16px; +} + +/** + * Component: Entry Page + */ +body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) .frm_image_options .frm_image_option_container { + --field-border-width: 1px; + --border-color: var(--grey-300); + --border-color-active: var(--primary-500); + --border-radius: var(--small-radius); +} + +#form_show_entry_page .frm_file_link, +#form_show_entry_page .frm_image_option_container { + display: inline-flex; + flex-wrap: nowrap; + flex-direction: column; + text-align: center; + align-items: center; + width: 150px; + margin-right: 10px; + margin-bottom: 10px; +} + +#form_show_entry_page .frm_image_option_container img { + width: 150px; + height: 150px; + object-fit: cover; +} + +#form_show_entry_page .frm_file_link img { + max-width: 150px; + height: auto; +} + +#form_show_entry_page .frm_file_link ~ br { + display: none; +} + +#form_show_entry_page .frm_upload_label { + padding: 10px; +} + +#form_show_entry_page.frm_wrap .postbox { + overflow: hidden; +} + +.frm_image_option_container .frm_image_placeholder_icon svg { + height: 150px; +} + +.frm_list_entry_page .frm_file_link, +.frm_list_entry_page .frm_image_option_container.frm_label_with_image { + display: block; + text-align: center; +} + +.frm_list_entry_page .frm_image_option_container img { + width: 75px; + height: 75px; + object-fit: cover; +} + +.frm_list_entry_page img { + max-width: 100%; + height: auto; +} + +.frm_image_option_container .frm_empty_url { + background-color: var(--sidebar-color); +} + +.frm_list_entry_page .frm_image_option_container .frm_text_label_for_image { + display: block; + padding: 5px 0 10px; +} + +.frm_list_entry_page .frm_upload_label, +.frm-summary-page-wrapper .frm_text_label_for_image { + display: block; +} + +/** + * Welcome and Global Settings Image Options + */ +#frm-welcome .frm_image_options .frm_image_option_container, +#form_global_settings .frm_image_options .frm_image_option_container { + background: var(--sidebar-color); +} + +#frm-welcome .frm_image_option_container svg, +#form_global_settings .frm_image_option_container svg { + max-width: calc(100% - 20px); +} + +/** + * Component: Option Templates + */ +/* Style image option container for Directory add on. */ +#frm-new-template .frm_image_option_container svg { + height: 50px; + margin: 10px auto 0; +} + +/* Show an icon on top */ +.frm_image_option_container { + position: relative; +} + +.frm_text_label_for_image > svg { + width: 30px; + position: absolute; + top: 5px; + right: calc(50% - 15px); +} + +/* End show an icon on top */ +.frm_single_option .frm_option_key { + margin-top: 17px; +} +.frm_single_option .frm_option_key.frm_image_preview_wrapper { + margin-top: var(--gap-xs); +} + +/** + * Component: Image + */ +.frm_image_data { + margin-left: var(--gap-sm); + display: flex; + flex-direction: column; + font-size: var(--text-sm); + justify-content: space-around; + min-width: 0; /* Allows flex items to shrink below content size */ +} + +.frm_image_styling_frame { + display: flex; + align-items: stretch; + margin-left: 36px; + margin-bottom: var(--gap-xs); + width: 100%; +} +.frm_image_styling_frame img { + height: 54px; + width: 54px; + min-width: auto; + min-height: auto; + border-radius: 3px; + object-fit: cover; + object-position: center; +} +.frm_image_styling_frame .frm_email_attachment_icon img { + height: auto; + width: auto; + max-width: 54px; +} + +.frm_image_preview_title { + color: var(--grey-500); + overflow: hidden; + white-space: nowrap; + text-overflow: ellipsis; + min-width: 0; /* Critical for text truncation in flex */ + flex: 1 1 auto; /* Better flex behavior */ +} + +.frm_wrap .frm_choose_image_box { + cursor: pointer; + color: var(--primary-500); + background-color: #fff; + margin-left: 32px; + text-align: center; + width: 100%; +} + +.frm-type-ranking .frm_option_key .frm_choose_image_box { + margin-left: 11px !important; +} + +.frm_wrap .frm_choose_image_box:hover { + background: #fff; +} + +a.frm_remove_image_option, +.frm_remove_image_option { + color: var(--grey-400); + cursor: pointer; +} + +a.frm_remove_image_option:hover .frmsvg, +a.frm_remove_image_option:hover, +.frm_remove_image_option:hover { + color: rgba(40, 47, 54, 0.8); +} + +/** + * Component: Settings and Panel + */ +/* Form Settings Tabs */ +.frm-form-setting-tabs { + margin-top: var(--gap-sm) !important; +} + +.frm-right-panel > .postbox { + background-color: transparent; + border: none; + box-shadow: none; + margin: 0; +} + +.frm-right-panel .postbox.frm_with_icons .inside, +.frm-right-panel .postbox .inside, +.frm-right-panel .inside { + font-size: var(--text-md); + padding: 15px 20px 20px; + color: var(--grey-700); +} + +.frm-right-panel .misc-pub-section { + padding: var(--gap-xs) 0; + position: relative; +} + +.frm-right-panel .inside a, +.frm-form-setting-tabs a { + font-size: var(--text-md); + color: var(--grey-700); + padding: var(--gap-sm); + display: block; +} + +.frm-form-setting-tabs a { + color: var(--grey-900); + padding: var(--gap-sm) var(--gap-md); +} + +.frm-right-panel .inside a { + padding: 0; + color: var(--primary-500); + display: inline-block; +} + +.frm-right-panel .inside a:hover { + color: var(--primary-700); +} + +.frm-form-setting-tabs a:hover { + background: var(--sidebar-hover); + color: var(--grey-900); +} + +.frm-right-panel .inside i, +.frm-form-setting-tabs a i, +.frm-form-setting-tabs a .frmsvg { + margin: 0 5px; + display: inline-block; + width: 20px; + height: 20px; + color: var(--grey-500); +} + +.frm-form-setting-tabs a .frmsvg { + margin: 0; +} + +.frm-right-panel .inside a:hover i, +.frm-right-panel .inside a:hover .frmsvg, +.frm-form-setting-tabs a:hover .frmsvg, +.frm-form-setting-tabs a:hover span { + color: var(--grey-700); +} + +.frm_settings_form .tabs-panel { + padding: 0 25px; +} + +#form_settings_page .tabs-panel, +.frm_settings_form .tabs-panel { + max-height: initial !important; + min-height: 50px !important; +} + +#frm_adv_info .tabs-panel { + min-height: 0 !important; + overflow-x: hidden; + padding: 0; + border: none; + background: transparent; +} + +select.frm_cancelnew, +input.frm_enternew { + width: 175px; +} + +.frm_posttax_opt_list { + border: 1px solid var(--grey-300); + padding: var(--gap-md); + border-radius: var(--small-radius); + margin: 5px 0 5px var(--gap-md); +} + +/* Color picker CSS */ +.frm_settings_form .wp-picker-open + .wp-picker-input-wrap, +.frm-right-panel .wp-picker-open + .wp-picker-input-wrap { + position: absolute; + margin-left: calc((100% - 35px) * -1); + margin-top: 1px; + width: calc(100% - 36px); +} +.frm_settings_form .wp-picker-container input[type=text].wp-color-picker, +.frm-right-panel .wp-picker-container input[type=text].wp-color-picker { + border: none; + padding: 5px 8px; + font-family: inherit; + color: var(--grey-700); + font-size: var(--text-md); + width: 100%; + line-height: var(--leading); +} +.frm_settings_form .wp-picker-input-wrap .wp-picker-clear, +.frm-right-panel .wp-picker-input-wrap .wp-picker-clear { + display: none !important; +} +.frm_settings_form .wp-picker-holder, +.frm-right-panel .wp-picker-holder { + position: absolute; + z-index: 999; +} +.frm_settings_form .wp-picker-input-wrap label, +.frm-right-panel .wp-picker-input-wrap label { + margin-bottom: 0; +} +.frm_settings_form .wp-picker-container .wp-color-result.button, +.frm-right-panel .wp-picker-container .wp-color-result.button { + width: 100%; + overflow: hidden; + margin: 0 !important; + height: var(--h-md) !important; + padding: 0 0 0 var(--gap-lg) !important; + border-radius: var(--small-radius); + border-color: var(--grey-300); +} +.frm_settings_form .wp-color-result-text, +.frm-right-panel .wp-color-result-text { + line-height: var(--leading) !important; + font-size: var(--text-md); + background: #fff !important; + color: var(--grey-900); + padding: 5px 8px; + border-color: var(--grey-300); + text-align: left; +} +.frm_settings_form .color-alpha, +.frm-right-panel .color-alpha { + width: var(--gap-lg) !important; +} + +.frm_grid_container .wp-picker-container { + width: 100%; + position: relative; +} + +.wp-picker-container button.wp-color-result { + border: 1px solid var(--grey-300) !important; +} + +.wp-picker-container .wp-picker-input-wrap input.hex.wp-color-picker { + max-width: 100%; + position: relative; +} + +.frm_end .wp-picker-holder { + margin-left: -145px; +} + +.frm_end.frm6 .wp-picker-holder { + margin-left: -86px; +} + +/* End of color picker CSS */ +/** + * Toggle Components + * + * These are the styles for the "Enable Formidable styling" toggle in the visual styler. + * To use this element, you can call the FrmHtmlHelper::toggle function. + */ +.frm_toggle_opt { + padding: 0; + white-space: normal; + display: inline; + vertical-align: middle; + font-weight: 400; +} + +.frm_on_label, +.frm_off_label { + color: var(--grey-700); +} + +.frm_toggle { + position: relative; + display: inline-block; + width: 40px; + height: var(--h-xs); + vertical-align: middle; +} + +.frm_toggle_block { + display: inline-flex !important; + gap: var(--gap-xs); + align-items: center; +} + +.frm_toggle input, +.frm_toggle_block input { + display: none !important; +} + +.frm_toggle_slider { + position: absolute; + cursor: pointer; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: var(--grey-200); + transition: 0.4s; + border-radius: 30px; +} + +.frm_toggle_slider::before { + box-sizing: border-box; + content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E"); + position: absolute; + left: 2px; + bottom: 2px; + display: flex; + align-items: center; + justify-content: center; + width: 20px; + height: 20px; + font-size: 20px; + line-height: 20px; + background-color: #fff; + border-radius: 50%; + transition: 0.4s; + box-shadow: var(--box-shadow-md); +} + +input:checked + .frm_toggle .frm_toggle_slider { + background-color: var(--primary-500); +} + +input:focus + .frm_toggle .frm_toggle_slider { + box-shadow: var(--box-shadow-md); +} + +input:checked + .frm_toggle .frm_toggle_slider::before { + transform: translateX(16px); + content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E"); +} + +input[disabled] + .frm_toggle_slider, +input[disabled] + .frm_toggle .frm_toggle_slider { + pointer-events: none; + cursor: text; + opacity: 0.5; +} + +.frm_toggle_opt ~ .frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before { + content: "" !important; /* Don't show x/check if off label included or on builder page */ +} + +.rtl .frm_toggle_opt { + padding: 0 8px; +} + +.rtl .frm_toggle_slider::before { + left: 17px; +} + +.rtl input:checked + .frm_toggle .frm_toggle_slider::before { + transform: none !important; + left: 1px; +} + +/* Deprecated admin toggle */ +.frm_toggle_off, +.frm_toggle_on { + display: none; + color: #fff; + z-index: 999; + position: absolute; + font-size: 10px; + line-height: 20px; + left: 6px; +} + +.frm_toggle_off { + display: inline; + left: auto; + right: 5px; + color: var(--dark-grey); +} + +.frm_toggle_long { + width: 80% !important; + height: 28px; + display: inline-block !important; +} + +.frm_toggle_long .frm_toggle_slider { + background: var(--primary-700); + box-shadow: 0 0 0 2px var(--primary-700); +} + +.frm_toggle_long .frm_toggle_off, +.frm_toggle_long .frm_toggle_on { + width: 50%; + text-align: center; + font-size: 13px; + line-height: 28px; +} + +.frm_toggle_long .frm_toggle_on { + left: 0; +} + +.frm_toggle_long .frm_toggle_off { + right: 0; +} + +.frm_toggle_long .frm_toggle_slider::before { + width: 50%; + left: 0; + top: 0; + border-radius: var(--border-radius) 0 0 var(--border-radius); + height: 100%; + background-color: #fff; + color: var(--primary-color); + content: "" !important; +} + +.frm_toggle_long input:checked + .frm_toggle_slider::before { + transform: translateX(101%); + border-radius: 0 var(--border-radius) var(--border-radius) 0; +} + +input:checked + .frm_toggle_slider + .frm_toggle_on { + display: inline; +} + +input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { + display: none; +} + +.frm_toggle_long .frm_toggle_on, +.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { + display: inline; + color: var(--primary-500); + font-weight: 400; +} + +.frm_toggle_long .frm_toggle_off, +.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on { + color: #fff; + font-weight: 700; +} + +/* End toggle styling */ +/** + * Global Settings + */ +.tabs-panel { + height: auto !important; + min-height: 260px; +} + +.tabs-panel.panel_secondary { + min-height: 20px; + margin-top: 10px; + margin-left: 150px; +} + +label.frm-example-icon { + margin-right: 20px !important; + display: inline-block !important; +} + +#frm_stripe_icon { + border-radius: 5px; +} + +#captcha_settings .frm_primary_label { + margin-top: var(--gap-sm); +} + +.frm-long-icon-buttons { + display: flex; + gap: var(--gap-md); +} + +.frm-long-icon-buttons > label { + border: 1px solid var(--grey-300); + color: var(--grey-700); + border-radius: var(--small-radius); + display: flex; + padding: var(--gap-sm); + gap: var(--gap-sm); + justify-content: center; + align-items: center; + width: calc(33% - var(--gap-sm)); + box-sizing: border-box; +} + +.frm-long-icon-buttons > label:hover { + color: var(--primary-500); +} + +.frm-long-icon-buttons input[type=radio] { + display: none; +} + +.frm-long-icon-buttons input[type=radio]:checked + label { + border-color: var(--primary-500); + box-shadow: 0 0 0 1px var(--primary-color); +} + +.frm-long-icon-buttons label > svg { + height: 21px; +} + +.frm-example-icon .frmsvg, +.frm-example-icon i { + height: 20px; + width: 20px; + font-size: 20px; + color: var(--grey-700); +} + +.frm_license_msg { + margin-top: 0; +} + +.frm_authorized_box .frm-show-unauthorized, +.frm_unauthorized_box .frm-show-authorized { + display: none; +} + +.edd_frm_status_icon.frmsvg { + margin: 0 5px; +} + +.edd_frm_license_row .frm_action_success .frmsvg { + color: green; +} + +.edd_frm_license_row .frm_action_error .frmsvg { + color: #d54e21; +} + +/* Hide the install steps for solutions */ +#form_global_settings .tabs-panel .num svg { + display: none; +} + +/* Empty List */ +.frm_no_items { + margin: 0 auto 50px; + text-align: center; + color: var(--grey-700); + max-width: 500px; +} + +.frm-subscribe { + margin: var(--gap-lg) 0; +} + +.frm_inbox_count { + color: #fff; + border-radius: 50%; + display: inline-block; + margin-right: 8px; + font-size: 11px; + text-align: center; + min-width: 18px; + height: 18px; + margin-left: 2px; + vertical-align: text-bottom; +} + +/** + * Global Payment Settings + */ +#payments_settings .frm_payments_section .form-table td { + padding-left: 0; + padding-right: 0; +} + +#payments_settings .frm_payments_section .form-table { + margin-top: 0; +} + +#frm_authnet_general_settings > tr:first-of-type > td:first-of-type { + padding-top: 0; +} + +#frm_authnet_general_settings h3 { + margin-bottom: 0; +} + +.frm_payment_settings_tab .frmsvg { + height: 22px; +} + +.frm_payment_settings_tab[for=frm_toggle_paypal_settings] .frmsvg { + width: 83px; +} + +.frm_payment_settings_tab[for=frm_toggle_authorize_net_settings] .frmsvg { + width: 99px; +} + +.frm_payment_settings_tab[for=frm_toggle_square_settings] .frmsvg { + width: 89px; +} + +.frm_payment_settings_tab[for=frm_toggle_stripe_settings] .frmsvg { + width: 53px; +} + +.frm-email-style { + float: left; + margin-right: var(--gap-md); +} +.frm-email-style:last-of-type { + margin-right: 0; +} +.frm-email-style__card { + position: relative; +} +.frm-email-style__name { + margin-top: var(--gap-xs); + padding-top: var(--gap-2xs); + text-align: center; +} +.frm-email-style__name .frmsvg { + vertical-align: sub; +} +.frm-email-style__click { + display: block; + border-radius: 12px; + border: 1px solid var(--grey-200); + box-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.0588235294); +} +.frm-email-style__click:focus, .frm-email-style--selected .frm-email-style__click { + border-color: var(--primary-500); + outline: 1px solid var(--primary-500); +} +.frm-email-style__click img { + width: 160px; + display: block; +} +.frm-email-style--disabled .frm-email-style__click::after { + content: ""; + display: block; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background-color: var(--grey-100); + opacity: 0.5; +} +.frm-email-style__buttons { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + z-index: 100; + display: none; + flex-direction: column; + justify-content: center; + align-items: center; + gap: 12px; +} +.frm-email-style__button { + cursor: pointer; + display: block; +} +.frm-email-style__button:disabled { + cursor: not-allowed; + display: none; + background: var(--primary-700) !important; + border-color: var(--primary-700) !important; +} +.frm-email-style--selected .frm-email-style__button:disabled { + display: block; +} +.frm-email-style--selected .frm-email-style__button[data-action=choose] { + display: none; +} +.frm-email-style--disabled .frm-email-style__button[data-action=choose] { + display: none; +} +.frm-email-style:hover .frm-email-style__buttons, .frm-email-style__click:focus + .frm-email-style__buttons, .frm-email-style:focus-within .frm-email-style__buttons { + display: flex; +} + +#frm-send-test-email, +.frm-upload-image-btn, +.frm-remove-image-btn, +.frm-reset-colors-btn { + cursor: pointer; +} + +#frm-send-test-email-modal .postbox { + padding: var(--gap-sm) var(--gap-md); +} +#frm-send-test-email-modal .postbox * { + box-sizing: border-box; +} +#frm-send-test-email-modal .inside { + margin: 0; + padding: 0; +} + +/** + * Import/Export + */ +.frm-lite .xml_opts .frm-export-xml-items { + display: none; +} + +.csv_opts #frm_csv_col_sep { + width: 45px; +} + +#frm_advanced td.frm_left_label { + width: 20%; + padding-right: 2px; +} + +/** + * Component: Where Options + */ +#frm_where_options select { + max-width: 200px; +} + +#frm_where_options select.frm_insert_where_options { + width: 30%; +} + +#frm_where_options select.frm_where_is_options { + width: 20%; +} + +#frm_where_options span.frm_where_val { + width: 32%; + display: inline-block; + position: relative; +} + +#frm_where_options span.frm_where_val .frm_tooltip_icon, +#frm_where_options span.frm_where_val .frm_help { + left: -4px; + position: absolute; +} + +#frm_where_options span.frm_where_val.frm_hidden { + display: none; +} + +#frm_where_options span.frm_where_val input, +#frm_where_options span.frm_where_val select { + width: 90%; + margin-left: 10px; +} + +#frm_where_options { + min-height: 31px; +} + +/** + * Component: Tabs Panel + */ +.tabs-panel.active .tabs-panel, +.frm_settings_form .tabs-panel .tabs-panel { + border: none; + padding: 0; +} + +/** + * Component: Feature Banner + */ +.frm-feature-banner { + background: var(--grey-700); + color: #fff; + border-radius: var(--small-radius); + padding: 20px; + margin: 10px 0; +} + +.frm-feature-banner p { + font-size: var(--text-sm); +} + +.frm-feature-banner .dismiss { + margin-top: -10px; + margin-right: -10px; +} + +.frm-feature-banner .dismiss svg { + color: #fff; +} + +.frm-feature-banner .frm-big-icon { + padding-right: 20px; + float: left; + min-height: 60px; +} + +.frm-big-icon svg { + height: 60px; + width: 60px; +} + +.frm-feature-banner p { + margin-top: 0; +} + +/** + * Add-on Backward Compatibility + */ +/*for add-on reverse compatibility */ +.frm_98_width { + width: 100% !important; +} + +/** + * Form Settings Tab styles + */ +h2.frm-h2, +.frm_form_settings h2 { + border-bottom: 1px solid var(--grey-300); + color: var(--grey-900); + font-weight: 400 !important; + padding: 9px 0 5px; + margin: 0; +} + +.frm_settings_form h3, +.frm_form_settings h3, +.frm_form_settings span.frm_add_logic_link { + font-size: var(--text-md); + border-top: 1px solid var(--grey-300); + padding-top: var(--gap-sm); + margin: var(--gap-sm) 0; + font-weight: 400; + text-transform: uppercase; + color: var(--medium-grey); + display: block; +} + +.frm_form_settings .howto { + color: var(--grey-500); + font-size: var(--text-sm); + margin-top: 8px; +} + +.frm_form_settings .advanced_settings .form-table { + margin-top: 0; +} + +.frm_form_settings td.frm_175_width { + width: 175px; +} + +.frm_form_settings #success_url { + width: 95%; +} + +.frm_wrap .ui-autocomplete { + padding: 3px 0; + max-height: 310px; +} + +.frm_wrap .ui-widget { + font-family: inherit; +} + +.frm_wrap .ui-autocomplete li { + padding: 2px 4px; + background: none; + color: var(--grey-700); + border: none; + font-weight: 400; +} + +.frm_wrap .ui-autocomplete .ui-menu-item-wrapper.ui-state-active { + border: none; + font-weight: inherit; +} + +.frm_select_with_label { + margin: 7px 0 0; +} + +/** + * Customization Panel styles + */ +/* Customization Panel */ +#frm-insert-fields-box, +#frm-conditionals { + max-height: none; +} + +#frm-conditionals, +#frm-adv-info-tab { + display: none; + max-height: 355px; +} + +#frm-insert-fields-box ul.subsubsub, +#frm-conditionals ul.subsubsub { + float: right; + margin: 0; +} + +#frm-insert-fields-box ul.alignleft, +#frm-conditionals ul.alignleft { + margin: 4px 0 0; +} + +#frm_adv_info ul.frm_code_list.frm-full-hover { + clear: both; + max-height: 215px; + overflow: auto; +} + +#frm-insert-fields-box ul.frm_code_list li.clear.frm_block { + height: 10px; +} + +#frm_adv_info .frm_noallow { + display: none; +} + +#frm_adv_info #frm-conditionals .frm_noallow { + display: block; +} + +/** + * Customize HTML Tab styles + */ +/* Customize HTML Tab */ +#frm_html_tab.frm_hidden { + display: none; +} + +#frm_html_tab.active { + display: inline; +} + +/** + * Form Actions Tab styles + */ +.frm_email_reply_container select, +.frm_email_reply_container input, +.form-table td.frm_150_width { + width: 170px; +} + +#frm_notification_settings .frm_no_top_padding { + padding-top: 0; +} + +.frm_email_settings.frm_email_settings.widgets-holder-wrap { + overflow: auto; + box-shadow: none; +} + +#frm_notification_settings .widget-top .widget-action, +#frm_form_editor_container .widget-top .widget-action { + border: 0; + margin: 0; + padding: 8px; + background: 0 0; + cursor: pointer; + outline: 0; +} + +#frm_notification_settings .widget-top .widget-action { + padding-top: 13.5px; +} + +#frm_email_addon_menu { + border: 1px solid var(--grey-300); + padding: var(--gap-sm); + border-radius: 4px; + margin: var(--gap-md) 0 var(--gap-sm); +} + +#frm_email_addon_menu .frm-search { + float: right; + margin: 0; +} + +#frm_email_addon_menu h3.frm-no-border { + clear: none; + padding-top: 7px; +} + +.frm_email_settings .widget .widget-top { + background-color: var(--sidebar-color); +} + +.frm_email_settings .widget .widget-top, +.frm_email_settings .widget .widget-top h3 { + cursor: pointer !important; +} + +.frm_email_settings .widget { + margin-bottom: var(--gap-sm); +} + +.frm_form_action_settings .widget-top { + box-shadow: none; + border-color: var(--grey-300); + border-radius: var(--small-radius); + background: var(--lightest-grey); + color: var(--grey-700); +} + +.frm_form_action_settings:hover .widget-top { + border-color: var(--grey); +} + +.frm_form_action_settings.open .widget-top { + border-bottom-left-radius: 0; + border-bottom-right-radius: 0; + border-bottom: none; +} + +.frm_form_action_settings.open:hover .widget-top { + border-color: var(--grey-300); +} + +.frm_form_action_settings > .widget-inside { + display: none; +} + +.frm_form_action_settings.open > .widget-inside { + display: block; +} + +.frm_form_action_settings .widget-inside { + min-height: 25px; + padding: 15px; + border-color: var(--grey-300); + border-bottom-left-radius: 4px; + border-bottom-right-radius: 4px; +} + +.frm_form_action_settings .widget-title h4, +.frm_form_action_settings .widget-title h3 { + display: inline-block; + border-bottom: none; + padding: 10px 10px 5px; + font-size: var(--text-md); + font-weight: 500; +} + +#frm_email_addon_menu h3 { + margin: 0 0 var(--gap-sm); + clear: both; +} + +.frm_single_api_settings p > label { + display: inline; +} + +.frm_form_action_icon { + margin-right: 5px; +} + +.frm_actions_list { + margin: 0; + display: inline; +} + +.frm_actions_list li { + float: left; + width: 15.6%; + margin: 10px 0.5% 15px; + height: 100px; + text-align: center; +} + +.frm-limited-actions .frm-group-heading, +.frm-limited-actions #frm-hide-groups, +.frm-all-actions #frm-show-groups, +.frm-limited-actions .frm-not-installed:not(.frm-search-result):not(.frm-default-show) { + display: none; +} + +label.frm_action_events { + padding-left: 15px; +} + +#frm-hide-groups, +#frm-show-groups { + font-size: var(--text-md); + float: right; +} + +.frm_actions_list a:active, +.frm_actions_list a:focus { + outline: none; +} + +.frm_actions_list a { + font-size: var(--text-sm); + color: var(--grey-700); + word-break: break-word; +} + +.frm_actions_list span.frm-outer-circle { + /* 50px total with 30px content */ + background-color: var(--grey-100); + padding: 10px; + text-align: center; + border-radius: 50%; + display: block; + width: 30px; + height: 30px; + margin: 0 auto 15px; + line-height: 1; + box-sizing: content-box; +} + +.frm_email_settings .widget-title h4 { + color: var(--grey-700); +} + +.frm_disabled_action .widget-title h4 { + color: var(--grey); +} + +.frm_actions_list a .frmsvg, +.frm_actions_list a i { + height: 18px; + width: 18px; + font-size: 18px; + padding: 2px; + color: var(--lightest-grey); + box-sizing: content-box; +} + +span.frm-inner-circle, +.frm_email_settings .widget-title .frm_form_action_icon { + background-color: var(--grey-400); + border-radius: 50%; + display: inline-block; + text-align: center; + line-height: 1; +} + +span.frm-inner-circle { + background-color: var(--primary-700); + height: 22px; + width: 22px; + padding: 4px; + color: #fff; + box-sizing: content-box; +} + +.frm-inner-circle svg { + fill: currentColor; +} + +.frm_email_settings .widget-title .frm_form_action_icon { + height: 15px; + width: 15px; + padding: 5px; + color: #fff; + vertical-align: middle; +} + +.frm_actions_list .frmsvg, +.frm_actions_list i::before, +.frm_email_settings .widget-title .frm_form_action_icon i, +.frm_email_settings .widget-title .frm_form_action_icon .frmsvg { + height: 15px; + width: 15px; + vertical-align: text-top; +} + +.frm_actions_list i::before { + vertical-align: middle; +} + +.frm_email_settings .widget-title:hover .frm_form_action_icon { + background-color: var(--grey); +} + +span.frm-inner-circle.frm-inverse { + background-color: transparent; + color: var(--primary-700); + padding: 0; + height: 30px; + width: 100%; +} + +.frm_actions_list span.frm-inverse i, +.frm_actions_list span.frm-inverse .frmsvg { + color: var(--primary-700); + height: 30px; + width: 30px; + font-size: 30px; + padding: 0; +} + +.frm_actions_list i.frm-inverse::before { + height: 30px; + width: 100%; + font-size: 30px; +} + +.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse { + background: #fff; + padding: 0; + height: 24px; + width: 24px; +} + +.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse .frmsvg, +.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse i::before { + color: var(--grey-400); + height: 24px; + width: 24px; + font-size: 24px; +} + +.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse .frmsvg, +.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse i::before { + color: var(--grey-500); +} + +.frm_email_icons { + padding: 10px 0 5px 6px; + font-size: 20px; +} + +.frm_email_icons a { + margin-left: 8px; + color: var(--grey); + opacity: 0; + transition: all 0.2s ease; +} + +.frm_email_icons a .frmsvg { + color: var(--grey); +} + +.frm_email_icons a:hover, +.widget-top:hover .frm_email_icons a { + opacity: 1; +} + +.frm_actions_list a.frm_inactive_action { + color: var(--grey); +} + +.frm_inactive_action .frm-inner-circle, +.frm_actions_list .frm_inactive_action i { + opacity: 0.4; +} + +/** + * Component: Notification Settings + */ +table td, +.form-table tr td { + vertical-align: top; +} + +#new_fields .form-table tr td { + display: block; + padding: 7px 0 0; +} + +#new_fields .form-table tr td:first-child { + margin: 0; +} + +#new_fields .form-table tr td:last-child { + margin-bottom: 9px; +} + +.form-table #list-table th { + text-align: center; +} + +#form_settings_page th, +#form_settings_page td, +.frm_settings_form td, +#frm_notification_settings .frm_form_action_settings td p { + padding: 7px 0; +} + +#permissions_settings_settings .frm_grid_container { + align-items: center; +} + +#frm_notification_settings .form-table > tbody > tr > th { + width: 150px; + font-weight: 400; + padding-right: 10px; +} + +#frm_notification_settings .frm_single_email_settings .form-table > tbody > tr > th { + width: 80px; +} + +#frm_notification_settings table tr td:first-child { + padding-left: 0; +} + +#frm_notification_settings table tr td:last-child { + padding-right: 0; +} + +#frm_notification_settings .frm_left_label { + float: none; /* For add-ons that haven't been updated for 4.0 */ + width: auto !important; +} + +.frm-fields .frm_autoresponder_rows select { + width: auto; +} + +#frm_notification_settings .frm_with_left_label, +#frm_notification_settings .frm_left_label + textarea, +#frm_notification_settings .frm_left_label + select, +#frm_notification_settings .frm_left_label + input[type=text] { + width: 100%; +} + +#frm_notification_settings .frm_email_buttons { + padding: var(--gap-2xs); + background: var(--light-blue); + color: var(--primary-700); + border-radius: var(--small-radius); + border-color: var(--blue-border); + line-height: 1; + height: auto; + min-height: 12px; + font-size: var(--text-xs); + box-shadow: none; +} + +p.frm_bcc_cc_container, +p.frm_reply_to_container { + position: relative; + float: right; + margin: -4px 0 0; + z-index: 1; +} + +.frm_email_row .frm_cancel1_icon::before { + vertical-align: bottom; +} + +.frm_cc_row.frm_email_row .frm-with-right-icon, +.frm_bcc_row.frm_email_row .frm-with-right-icon, +.frm_reply_to_row.frm_email_row .frm-with-right-icon { + width: calc(100% - 20px); + display: inline-block; +} + +.frm_email_row .frm_remove_field .frm_close_icon { + position: relative; + fill: var(--grey-500); + vertical-align: middle; +} + +/** + * Component: Logic Fields + */ +.frm-inline-select, +p.frm-inline-select, +.frm_logic_rows .frm-collapse-me { + line-height: var(--h-md) !important; +} + +.frm_logic_row { + padding: var(--gap-xs) 0 0; +} + +.frm-single-settings ul.frm_sortable_field_opts { + border-bottom: 1px solid var(--grey-200); + padding-bottom: var(--gap-xs); + margin-bottom: var(--gap-xs); +} + +.frm-single-settings .frm-add-other svg.frm_add_tag { + position: relative; + top: 5px; + margin-right: 4px; +} + +.frm-single-settings .frm_single_option .frm_remove_tag::before { + content: ""; +} + +.frm-single-settings input[type=checkbox][readonly] { + opacity: 0.5; + pointer-events: none; +} + +.advanced_settings .frm_logic_row { + margin: 14px 0; +} + +.advanced_settings .frm_logic_row select, +.advanced_settings .frm_logic_row input { + max-width: 30% !important; +} + +.frm_form_action_settings .frm_logic_row p { + margin-top: 0; + margin-bottom: 0; + padding: 0; +} + +/** + * Component: Form Settings Widget + */ +#poststuff .widgets-holder-wrap .frm_form_action_settings .widget-inside { + padding-bottom: 0; +} + +#poststuff .frm_form_settings .widgets-holder-wrap .widget-inside { + padding-left: 15px; + padding-right: 15px; +} + +#form_global_settings h3 { + font-size: var(--text-sm); + margin-top: 25px; +} + +#form_global_settings .tabs-panel + h3 { + margin-top: 0; + border: none; +} + +#poststuff .frm_form_settings .widget-inside h3, +#poststuff .frm_form_settings .advanced_settings h3, +#poststuff .frm_settings_form h3, +#frm_advanced .inside h3 { + border-top: 1px solid #eee; + border-bottom: none; + margin: 15px -15px 0; + padding: 8px 15px; + font-size: var(--text-sm); +} + +#poststuff .frm_form_settings h3.frm_first_h3, +#poststuff h3.frm_first_h3 { + border: none; + margin-top: 0; +} + +h3.frm_add_logic_link { + margin-bottom: 0 !important; +} + +a.frm_add_logic_link.frm_hidden { + display: none; +} +a.frm_add_logic_link.frm_hidden + .frm_logic_rows { + height: auto; +} + +/** + * Icon Font styles + */ +.frm_icon_font { + color: #a0a0a0; + color: var(--grey); +} + +.frm-fields label .frm_icon_font { + font-size: inherit; +} + +.misc-pub-revisions.frm_icon_font, +.misc-pub-revisions.frm_icon_font:hover { + color: inherit; +} + +.postbox.frm_with_icons .inside { + padding: 0; + margin: 0; +} + +.frm_add_tag::before { + content: "\e602"; +} + +.frm_remove_tag::before { + content: "\e600"; +} + +.frm_logic_row .frm1 > .frm_remove_tag { + padding: 0; +} + +.frm_tooltip_icon::before { + font-size: 13px; + vertical-align: top; +} + +.frm_help svg, +.frm_help .frmsvg { + height: 13px; + width: 13px; + vertical-align: top; + color: var(--grey-400); +} + +.form-field input[type=text].frm_other_input { + width: 30%; + margin-left: 10px; +} + +.frm-add-other { + text-align: right; +} + +.frm-add-other .frm_add_tag { + vertical-align: 20%; +} + +.frm_action_icon { + margin: 5px 0 0 5px; +} + +span.frm_action_icon { + margin: 0 4px 0 0; +} + +.frm_action_icon:active { + outline: none; +} + +a.frm_action_icon:hover { + text-decoration: none; +} + +.frm_action_icon.frm_error_icon::before { + content: "\e608"; +} + +.frm_inactive_icon.frm_action_icon.frm_error_icon::before { + content: "\e606"; +} + +.frm-field-action-icons { + text-align: right; + position: absolute; + top: 2px; + right: 2px; + max-width: 100%; +} + +.frm-field-action-icons .frm-field-id { + display: inline-block; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; + width: 80px; + max-width: calc(100% - 50px); + position: relative; + top: 2px; +} + +.frm-field-action-icons > a { + font-size: var(--text-md); + width: 17px; +} + +.frm-field-action-icons a:hover { + text-decoration: none; +} + +.frm-field-action-icons .dropdown { + display: inline-block; +} + +.frm-field-action-icons > a .frmsvg { + color: var(--grey-500) !important; + font-size: 17px; + width: 17px; + height: 17px; +} + +.frm-field-action-icons > a .frmsvg, +.frm-field-action-icons > div > a .frmsvg { + vertical-align: baseline; +} + +.edit_field_type_end_divider .frm-field-action-icons { + display: none !important; +} + +.frm-move { + cursor: grab; +} + +/** + * Extended Howto styles + */ +span.howto { + display: inline; +} + +.frm_import_message { + margin: 15px 0; + line-height: 2.5; +} + +/** + * Form Widget styles + */ +.frm_sorting .form-field .widget input[type=text], +.frm_sorting .form-field .widget input[type=number], +.frm_sorting .form-field .widget select, +#wpcontent .frm_sorting .form-field .widget select, +.frm_sorting .form-field .widget textarea { + width: auto; +} + +/** + * Tag Checklist styles + */ +.tagchecklist span.no_taglist { + display: inline; + float: none; + line-height: 15px; + margin-right: 0; + font-size: inherit; +} + +.tagchecklist .frm_exclude_cat_list span { + display: inline; +} + +.tagchecklist span a::before { + line-height: 23px; + text-align: start; +} + +.frm_form_action_settings .frm_email_row .frm_tooltip_icon { + position: relative; + bottom: 2px; +} + +/** + * No Entries Page styles + */ +.frm_no_entries_form { + padding: 60px 0; +} + +.frm_no_entries_form .frm_no_entries_header { + font-size: 20px; + margin-bottom: 10px; +} + +.frm_no_entries_form .frm_no_entries_text { + line-height: var(--leading); +} + +#form_entries_page #the-list .no-items { + height: 240px; /* Equals to the max height of search dropdown */ +} + +/** + * Reports Page styles + */ +#form_reports_page img.frm_no_reports { + max-width: 100%; +} + +.frm_wrap .google-visualization-table .gradient, +.frm_wrap .google-visualization-table-tr-head, +.frm_wrap .google-visualization-table-tr-odd, +.frm_wrap .google-visualization-table-tr-odd.google-visualization-table-tr-over { + background: var(--lightest-grey); +} + +.frm_wrap .google-visualization-table-tr-over { + background: #fff; +} + +.frm_wrap .google-visualization-table-table th, +.frm_wrap .google-visualization-table-table td { + border-right-width: 0; + padding: 10px !important; +} + +.frm_wrap .google-visualization-table-tr-head, +.frm_wrap .google-visualization-table-tr-head th { + white-space: pre-wrap; + font-size: var(--text-md); + font-weight: 400 !important; + text-align: left; +} + +.frm_wrap .google-visualization-table-td-number { + text-align: inherit; +} + +#form_reports_page .postbox { + text-align: center; + float: none; + display: inline-block; + margin-right: 2%; + width: 20%; + min-width: 175px; +} + +/** + * Views Page styles + */ +#form_views_page img.frm_no_views { + max-width: 100%; +} + +/** + * Component: Field Options Popup + */ +.frm_field_opts_popup { + min-width: 300px; + background-color: #fff; +} + +.frm_field_opts_popup #wpadminbar { + display: none; +} + +.frm_prepop { + width: 100%; + list-style: none; + overflow: auto; + margin: 0; + max-height: 295px; +} + +.frm_prepop li { + margin: 0; +} + +.frm_prepop li a { + display: block; + text-decoration: none; + cursor: pointer; + padding: 5px 20px; +} + +.frm_prepop li a:hover { + background: var(--sidebar-color); +} + +/** + * Form Editor Container + */ +#frm_form_editor_container #frm_form_key_box { + width: 13em; + max-width: 30%; +} + +#frm_form_editor_container #frm_form_desc { + width: 70%; +} + +#frm_form_editor_container .ui-widget-content { + display: none; + padding: 15px; +} + +#frm_form_editor_container .ui-widget-content label { + float: left; + width: 170px; + text-align: right; + padding-right: 5px; + clear: both; +} + +#frm_form_editor_container .ui-widget-content label.nofloat { + clear: none; + float: none; + margin-left: 10px; +} + +#frm_form_editor_container .ui-state-default { + color: #333 !important; +} + +.frm_green { + color: var(--green) !important; +} + +#frm_form_editor_container .ui-state-default a.frm_orange, +.frm-right-panel a.frm_orange, +#postbox-container-1 a.frm_orange { + color: #d54e21; +} + +#styling_settings input[type=checkbox], +#styling_settings input[type=radio] { + border: solid 1px #bbb; +} + +#styling_settings .widget .widget-top, +#frm_form_editor_container .widget .widget-top { + cursor: pointer; +} + +/** + * Widget Sorting + */ +.frm_sorting .widget, +.frm_settings_page .widget { + background: #fff; +} + +.frm_sorting .widget-title h4 { + font-weight: 400; +} + +.frm_sorting .widget, +#postbox-container-1 .widget, +.frm-right-panel .widget, +.frm_settings_page .widget { + margin-bottom: 0; +} + +.frm_settings_page .widget-inside { + padding: 0 5px 5px; +} + +.frm_sorting .widget, +.widget-inside, +.frm_sorting .form-field .widget { + display: none; +} + +#frm-show-fields { + min-height: 350px; + padding: 0 0 35px; + margin: 0; + position: relative; +} + +.frm-has-fields #frm-show-fields { + min-height: 50px; +} + +#frm_builder_page .frm-lite-credit-card-element, +body.frm-admin-page-styles .frm-lite-credit-card-element { + position: relative; +} + +#frm_builder_page .frm-lite-credit-card-element > div, +body.frm-admin-page-styles .frm-lite-credit-card-element > div { + position: absolute; + top: calc(50% - 1px); + transform: translateY(-50%); + right: 10px; + color: #d0d4dd; +} + +#frm_builder_page #frm_field_group_controls { + position: absolute; + padding: 5px; + border-radius: 4px 4px 0 0; + text-align: right; + box-sizing: border-box; + right: 0; + top: -28px; + height: 28px; + z-index: 3; /* section dividers use z-index: 2; position above that to avoid it taking over hover control. */ +} + +.frm-field-group-hover-target, +.frm-has-open-field-group-popup, +#frm_builder_page #frm_field_group_controls, +.frm-selected-field-group { + background: rgba(65, 153, 253, 0.04); +} + +.frm-selected-field-group { + position: relative; +} + +#frm_builder_page #frm_field_group_controls > span:first-child { + margin-right: 5px; +} + +#frm_builder_page #frm_field_group_controls svg { + pointer-events: none; +} + +#frm_field_group_controls { + visibility: hidden; +} + +.frm-field-group-hover-target #frm_field_group_controls { + visibility: visible; +} + +#frm_field_group_controls .dropdown-item a span { + color: var(--grey-700); +} + +#frm_field_group_controls .dropdown-item a:hover { + text-decoration: none; +} + +/** + * Field Sorting + */ +.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider { + display: none !important; +} + +.frm-right-panel .ui-state-default, +#postbox-container-1 .ui-state-default, +.frm_sorting > li.ui-state-default, +.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover { + border: 1px solid transparent; + font-weight: 400 !important; + background-color: transparent; + background-image: none; + padding: 5px; + margin: 0; + box-shadow: none; + display: block; + text-align: inherit !important; + overflow: visible; + position: relative; +} + +#frm-show-fields li.frm_cancel_sort { + /* If a section gets dropped into a section, hide it */ + display: none; +} + +.divider_drop { + text-align: center; +} + +.divider_drop .howto .frm_icon_font { + font-style: normal; +} + +.show_repeat_sec { + display: none; +} + +.repeat_section .show_repeat_sec { + display: inline-block; + margin: 5px 0 0; +} + +.repeat_section tr.show_repeat_sec { + display: table-row; +} + +.repeat_format .frm_repeat_label, +.repeat_formattext .frmsvg, +.repeat_formattext i { + display: none; +} + +/** + * Frm Button + */ +.frm_button { + text-decoration: none; + border: 1px solid #eee; + padding: 5px; + color: #444; + vertical-align: middle; + box-shadow: none !important; +} + +a.frm_button:hover { + text-decoration: none !important; +} + +.frm_button, +.frm_button .frm_icon_font::before { + font-size: 13px; + vertical-align: middle; +} + +.frm_button .frmsvg { + width: 13px; + height: 13px; +} + +/** + * Components - Divider + */ +.frm-right-panel .ui-state-default, +#postbox-container-1 .ui-state-default { + padding: 0; + margin: 0; +} + +ul.start_divider { + padding: 8px 13px 0 8px; + min-height: 115px; + transition: all 0.4s linear; +} + +.frm-section-collapsed .frm_no_section_fields, +.frm-section-collapsed ul.start_divider { + height: 0; + min-height: 0 !important; +} + +.frm-section-collapsed ul.start_divider { + overflow: hidden; +} + +.frm-section-collapsed .frm_no_section_fields { + overflow: hidden; + padding: 0; + opacity: 0; +} + +.frm-section-collapsed .divider_section_only .frm-collapsed-label { + display: inline; +} + +.frm-page-collapsed .frm_clone_icon, +.frm-page-collapsed .frm_delete_field, +.frm-page-collapsed .frm_clone_field, +.frm-section-collapsed .frm_clone_icon { + opacity: 0.5; + cursor: not-allowed; +} + +/* Hide the Duplicate summary option because we are missing the logic that also adds a new page */ +.edit_field_type_summary .frm_more_options_li:nth-child(2) { + display: none !important; +} + +.edit_field_type_submit .frm_more_options_li:not(:last-child) { + display: none !important; +} + +.frm_no_section_fields:not(.frm_block) + ul.start_divider { + padding: 0; + min-height: 132px; +} + +.frm_sorting li.ui-state-default .divider_section_only { + padding: 6px; + margin-top: -10px; + border: 2px solid transparent; + border-radius: var(--small-radius); + z-index: 2; + position: relative; +} + +.divider_section_only > .frm_inner_field_container { + padding: 5px 0; + margin: 0; +} + +.frm-collapsed-label, +.divider_section_only > .frm_inner_field_container .frm_form_fields { + display: none; +} + +.frm-section-collapsed .divider_section_only::after, +.divider_section_only::before { + content: ""; + display: block; + padding: 2px 0; + line-height: 1px; + border-top: 2px solid var(--grey-300); + top: -2px; + position: absolute; + width: 100%; + transition: 0.5s border-color ease-in-out; +} + +.frm-section-collapsed .divider_section_only::after { + top: auto; + bottom: -6px; +} + +.frm-section-collapsed .divider_section_only:hover::after, +li.selected.frm-section-collapsed .divider_section_only::before, +li.selected.frm-section-collapsed .divider_section_only::after, +.divider_section_only:hover::before, +li.selected .divider_section_only::before { + border-color: transparent; +} + +.frm_sorting li.ui-state-default.edit_field_type_divider { + overflow: visible; + position: relative; + padding: 0 0 0 20px; + margin: 25px 0 0 -5px; + border-left: 1px solid var(--primary-700); + transition: border 0.7s ease-out; +} + +.frm-section-collapsed { + border-left-color: transparent !important; +} + +.frm_sorting li.edit_field_type_end_divider, +.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover { + margin: 0 0 var(--gap-sm); +} + +.frm-first-page .frm_prev_page { + display: none; +} + +/** + * Components - Form Rows + */ +#frm_builder_page .frm_remove_form_row.frm_button, +#frm_builder_page .frm_add_form_row.frm_button { + border-radius: var(--small-radius); + border: 1px solid var(--blue-border); +} + +#frm_builder_page .frm_remove_form_row .frmsvg, +#frm_builder_page .frm_remove_form_row i::before, +#frm_builder_page .frm_add_form_row .frmsvg, +#frm_builder_page .frm_add_form_row i::before { + color: var(--primary-700); +} + +.frm-preview-buttons .frm_button_submit { + margin: 0 5px; +} + +.frm-page-break { + border-top: 1px dashed var(--primary-700); + margin-top: var(--gap-lg); + position: relative; +} + +.frm-page-break::before, +.frm-page-break::after { + content: ""; + position: absolute; + background-color: #fff; + border-radius: 50%; + border: 1px solid var(--primary-700); + text-rendering: auto; + -webkit-font-smoothing: antialiased; +} + +/** + * Components - Divider Icons + */ +.edit_field_type_divider .frm-divider-icon.frmsvg { + padding: 2px; + position: absolute; + left: -12px; + color: #fff; + background-color: var(--primary-700); + border-radius: 50%; +} + +.edit_field_type_divider .start_divider .frm-divider-icon.frmsvg { + height: 8px; + width: 8px; + padding: 0; + bottom: -4px; + left: -24.5px; + color: var(--primary-700); + background-color: #fff; +} + +.edit_field_type_divider.selected .frm-divider-icon.frmsvg, +.edit_field_type_divider:hover .frm-divider-icon.frmsvg { + background: var(--primary-500); +} + +.edit_field_type_divider.selected .start_divider .frm-divider-icon.frmsvg, +.edit_field_type_divider:hover .start_divider .frm-divider-icon.frmsvg { + background-color: #fff; + color: var(--primary-500); +} + +.frm-page-break::before, +.frm-page-break::after { + width: 8px; + height: 8px; + top: -6px; + border-color: var(--grey); +} + +.frm-page-break::after { + right: 0; +} + +#frm-fake-page .frm-page-break { + border-color: var(--grey); +} + +#frm-fake-page { + padding: 0 5px; +} + +.frm_sorting li.edit_field_type_divider:hover, +.frm_sorting li.edit_field_type_divider.selected { + border-left-color: var(--primary-500); +} + +/** + * Component: Page Collapsed + */ +.frm-section-collapsed::after { + border-color: transparent !important; + color: transparent; +} + +.frm-page-break .frm-collapse-page.button { + margin-left: 46%; + margin-top: -16px; + padding: 6px 12px !important; +} + +#frm-fake-page.frm-page-collapsed { + margin-bottom: 0; +} + +.frm-page-collapsed { + position: relative; + overflow: visible !important; + margin-bottom: var(--gap-lg); +} + +.frm-collapse-page .frmsvg, +.frm-collapse-page .frm_arrowdown6_icon { + width: var(--text-sm); + height: var(--text-sm); + font-size: var(--text-sm); + text-align: center; + margin-left: 2px; + color: currentColor; + transition: transform 300ms ease-in-out; +} + +.frm-page-collapsed .frm-collapse-page .frmsvg { + transform: rotate(180deg); +} + +#frm-fake-page .frm_arrowdown6_icon { + color: currentColor; +} + +.frm-collapsed i::before, +.frm-page-collapsed .frm_arrowdown6_icon::before { + content: "\e913"; +} + +.frm-collapse-section svg { + fill: var(--primary-color); + transition: transform 0.2s ease-out, fill 0.2s ease-out; +} + +.frm-collapse-section:hover svg { + fill: var(--primary-700); +} + +.frm-section-collapsed .frm-collapse-section svg { + transform: rotate(-90deg); +} + +.open .widget-top .widget-title-action button .frmsvg { + transform: rotate(90deg); +} + +.widget-top .widget-title-action button .frmsvg use { + color: var(--grey); +} + +.frm-collapsed + .frm-collapse-me { + overflow: hidden !important; +} + +.frm-collapse-me { + padding-bottom: 10px; +} + +.frm-collapse-me.frm_grid_container:has(.dropdown-toggle.multiselect) { + position: relative; + z-index: 1; +} + +.frm-collapsed + div { + height: 0; + padding: 0; +} +.frm-collapsed + div.frm-collapse-me { + display: none; +} + +.frm-collapsible { + display: flex; + justify-content: space-between; + align-items: center; + font-weight: 700; + padding: var(--gap-xs) 0; + margin: 0; + cursor: pointer; + /* prevent text selection */ + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} +.frm-collapsible.frm-collapsed { + font-weight: 400; +} +.frm-collapsible:not(.frm-collapsed) .frmsvg { + transform: rotate(-180deg); +} +h4.frm-collapsible { + font-size: var(--text-md); +} + +.frm-collapsible + .frm-collapse-me { + padding-bottom: 0; +} +.frm-collapsible:focus-visible { + outline: 1px solid var(--primary-500); +} + +/** + * Divider Labels + */ +.frm_sorting .divider_section_only > .frm_ipe_field_label { + font-size: 116%; +} + +#frm_form_editor_container .edit_field_type_break .frm_primary_label.frm_ipe_field_label.button { + width: 150px; + text-align: center; + margin-bottom: 3px; + display: block; +} + +tr.frm_options_heading td { + padding-bottom: 0; +} + +.frm_sorting .widget-inside .form-table td p, +.frm_sorting .widget-inside .form-wrap label { + padding: 10px 0; +} + +/** + * Empty Fields + */ +.frm_no_fields, +.frm_no_section_fields { + text-align: center; + position: absolute; + color: var(--medium-grey); + font-size: var(--text-md); + box-sizing: border-box; + border: 1px dashed var(--grey-300); + outline: 2px solid transparent; +} + +.frm-over-droppable + .frm_no_fields { + border-style: solid; + border-color: var(--primary-500); + outline-color: var(--primary-500); +} + +.frm_no_section_fields { + display: none; + margin: 0; + padding: 20px 0 0; + width: calc(100% - 20px); + height: 121px; + transition: all 0.4s linear; +} + +.frm-empty-fields .frm_updated_message ~ .frm_no_fields { + top: 60px; +} + +#frm_form_editor_container:not(.frm-has-fields) #frm-show-fields > .frm_field_box:last-child { + visibility: hidden; +} + +.frm-has-fields .frm_no_fields { + display: none; +} + +#frm_form_editor_container:not(.frm-has-fields) #frm_drag_placeholder { + display: none; +} + +#frm-form-button { + display: none; + margin: 0 7px 25px; +} + +.frm-has-fields #frm-form-button { + display: block; +} + +.frm-large-plus.frmsvg { + color: var(--primary-700); + height: 45px; + width: 45px; +} + +.frm_no_section_fields p { + color: var(--grey); + font-size: 15px; +} + +.frm_no_fields { + top: 0; + width: calc(100% - 24px); + min-height: 320px; + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; + gap: var(--gap-md); + padding: var(--gap-md); + border: 0; + background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Crect width='99%25' height='99%25' fill='none' stroke='%23D0D5DD' stroke-width='1' stroke-dasharray='8,8' rx='8' ry='8' x='0.5%25' y='0.5%25' stroke-linecap='square' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E"); + border-radius: var(--medium-radius); + margin: var(--gap-sm) 12px; +} +.frm_no_fields img { + margin-left: calc(-1 * var(--gap-lg)); +} +.frm_no_fields .frm_drag_inst { + font-size: 20px; + font-weight: 600; + margin: 0 0 12px; +} +.frm_no_fields p { + color: var(--grey-600); + font-size: var(--text-md); + margin: 0; +} + +/** + * Product Fields + */ +.frm_product_price_wrapper { + display: inline-block; + vertical-align: middle; +} + +.frm_prod_type_single .frm_product_price_wrapper { + width: 100%; +} + +#new_fields .frm_product_price_wrapper input:first-child { + width: 60% !important; + float: left; +} + +#new_fields .frm_product_price_wrapper input:nth-child(2) { + width: 37% !important; + float: right; +} + +/** + * Field Choices + */ +li.frm_single_option { + padding-bottom: var(--gap-sm); + border-bottom: 0; +} + +.frm_prod_type_single input[type=radio], +.frm_prod_type_single .frm_drag_icon, +.frm_prod_type_single .frm_sortable_field_opts li:nth-child(n+3), +.frm_prod_type_single .frm_sortable_field_opts .frm_remove_tag, +.frm_prod_type_single .frm_form_field:not(.frm_product_type):not(.frm_sep_val_product), +.frm_prod_type_single .frm-bulk-edit-link, +.frm_prod_type_user_def.frm_grid_container, +.frm_prod_options_heading.frm_prod_user_def { + display: none; +} + +.frm_prod_type_single .frm-ai-generate-options-modal-trigger { + display: none !important; +} + +.frm_prod_type_single .frm_option_key { + margin-left: 0 !important; +} +.frm_prod_type_single .frm_option_key input[type=checkbox] + input[type=text], +.frm_prod_type_single .frm_option_key input[type=radio] + input[type=text] { + margin-left: 0 !important; +} + +.plugin-card-bottom .frm-trash { + color: #a00; +} + +/** + * Field Labels + */ +.frm-fields p > .frm_inline_label, +.frm_inline_label { + padding-left: 3px; + margin-right: 12px; + display: inline-block; +} + +.frm_left_label { + clear: both; + float: left; + width: 32% !important; + margin-right: 2% !important; + line-height: 2em; +} + +table td.frm_left_label { + float: none; + line-height: inherit; + padding: 5px 0 5px 2%; +} + +.frm_left_label.frm_alignright { + padding-right: 10px; + text-align: right; +} + +.frm-fields .frm_left_label + textarea, +.frm-fields .frm_left_label + select, +.frm-fields .frm_left_label + input[type=text], +.frm_with_left_label { + width: 66%; +} + +td.frm_left_label + td { + width: 66%; + padding-top: 0; +} + +#html_settings label { + display: block; +} + +#html_settings .frm_field_html_box { + width: 100%; +} + +.frm-has-required .frm-required { + color: var(--error-500); +} + +/** + * Category Tabs + */ +ul.frm-category-tabs { + margin-top: 2px; +} + +.frm-category-tabs > li a, +.frm-category-tabs > li a:active { + outline: none; + box-shadow: none; + display: flex; + gap: var(--gap-xs); + align-items: center; +} + +.frm-category-tabs > li.active .frmsvg, +.frm-category-tabs > li.active i, +.frm-category-tabs > li.active span, +.frm-category-tabs > li.active a { + color: var(--primary-500); +} + +.frm_wrap .manage-menus { + margin-top: 0; + border: none; + border-bottom: 1px solid var(--grey-300); + background: var(--lightest-grey); +} + +.general_settings .postbox .manage-menus { + border-top: none; + border-left: none; + border-right: none; +} + +.frm-postbox-no-h3 { + padding-top: 10px; +} + +/** + * Components : UI State Defaults + */ +.frm-right-panel .ui-state-default, +#postbox-container-1 .ui-state-default { + color: var(--grey-900); +} + +.no_repeat_section .frm_sorting > li.ui-state-default.edit_field_type_end_divider:hover { + box-shadow: none; +} + +.frm-selected-field-group li.ui-state-default, +.start_divider.frm_sorting li.ui-state-default.frm_not_divider.selected, +.start_divider.frm_sorting li.ui-state-default.frm_not_divider:hover, +.frm_sorting li.ui-state-default.frm_not_divider:hover, +.frm_sorting li.ui-state-default.ui-sortable-helper, +.frm_sorting li.ui-state-default.edit_field_type_divider .divider_section_only:hover, +.frm_sorting .repeat_section li.ui-state-default.edit_field_type_end_divider:hover, +.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only, +.frm_update_msg, +.frm_sorting li.ui-state-default.frm_not_divider.selected, +.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only { + border-color: var(--primary-500); + transition: 0.5s border-color ease-in-out; +} + +.frm_sorting li.ui-state-default.frm_not_divider.selected { + box-shadow: 0 0 1px 0 var(--primary-500); +} + +.frm_sorting li.ui-state-default { + transition: 0.7s box-shadow ease-in-out, 0.7s height linear; +} + +.frm_sorting li.ui-state-default.frm-newly-added { + box-shadow: inset 0 0 2px 1px var(--blue-border); +} + +.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover { + visibility: visible !important; + display: inline !important; +} + +.edit_field_type_end_divider > label { + display: none !important; +} + +/** + * Update Message + */ +.frm_email_actions.feature-filter { + font-weight: 700; + border: 1px solid #dfdfdf; + background-color: #eee; + padding: 3px 5px 2px; + font-size: var(--text-md); + line-height: 20px; +} + +.frm_update_msg { + border-style: solid; + margin: 10px 0; + color: #21759b; + padding: 8px 15px; + border-radius: 4px; +} + +.frm_update_msg.wrap { + margin: 10px 20px 0 2px; +} + +#frm-insert-fields-box .frm_update_msg { + margin-right: 0.9em; +} + +.frm_update_msg a { + font-weight: 700; +} + +.widefat td { + width: auto; +} + +.widefat .column-id { + width: 3.7em; +} + +.widefat .column-show_count { + width: 5em; +} + +.widefat .column-shortcode { + width: 9em; +} + +/** + * Admin Columns + */ +.toplevel_page_formidable .column-shortcode div { + display: flex; + gap: var(--gap-xs); +} + +.widefat .column-entries, +.widefat .column-link { + width: 10%; + text-align: center; +} + +.widefat .column-form_key, +.widefat .column-created_at { + width: 10%; +} + +.frm-white-body .search-box, +.frm_wrap .frm-search { + float: right; + margin: 0; + clear: right; +} + +.frm-white-body .search-box, +.frm-search { + min-width: 32%; + position: relative; + display: flex; + gap: var(--gap-sm); + align-items: center; +} + +.frm-inline-modal .frm-search, +#frm_adv_info .frm-search { + float: none; + width: 100%; + clear: both; + margin: var(--gap-xs) 0; +} + +/** + * Button Group + */ +.frm-button-group a { + margin: 0 7px !important; +} + +/** + * Input Icons + */ +.frm_has_textarea .frm-with-right-icon { + display: block; +} + +.frm-with-left-icon, +.frm-with-right-icon { + position: relative; +} + +i.frm-show-box, +i.frm-show-inline-modal, +.frm-with-left-icon i, +.frm-with-right-icon i:not([class*=mce-]), +.frmsvg.frm-show-box, +.frmsvg.frm-show-inline-modal, +.frm-with-left-icon .frmsvg, +.frm-with-right-icon .frmsvg, +.frm-search > .frmsvg, +.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select) { + position: absolute; + padding: 0 14px; + pointer-events: none; + left: 0; + color: var(--grey-400); + font-size: var(--text-xs); +} + +.frm-search > .frmsvg, +.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select) { + padding-left: var(--gap-xs); + padding-right: var(--gap-xs); +} + +.frm-search > .frmsvg { + box-sizing: unset; +} + +.frm-with-right-icon .frmsvg, +.frm-with-right-icon i:not([class*=mce-]) { + right: 0; + top: -3px; + left: auto; + padding: 0 10px 0 5px; +} + +.frm_form_settings .frm-with-right-icon .frmsvg { + top: 0; +} + +.frm_form_settings .wp-editor-container .frm-with-right-icon .frmsvg, +#frm_builder_page .wp-editor-container .frm-with-right-icon .frmsvg { + top: auto; + bottom: var(--gap-sm); +} +.frm_form_settings .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg, +#frm_builder_page .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg { + bottom: var(--gap-lg); +} + +.frm_form_settings .frm_has_textarea .frm-with-right-icon .frmsvg { + top: auto; + bottom: 6px; +} + +.frmsvg.frm-show-box, +.frmsvg.frm-show-inline-modal, +i.frm-show-box, +i.frm-show-inline-modal { + top: auto; + background-color: var(--primary-50); + color: var(--primary-500); + border-radius: 6px; + padding: var(--gap-2xs); + margin: 5px; /* input height - svg / 2 */ + margin-bottom: 0; + z-index: 1; + cursor: pointer; + pointer-events: initial; +} +.frmsvg.frm-show-box:focus, +.frmsvg.frm-show-inline-modal:focus, +i.frm-show-box:focus, +i.frm-show-inline-modal:focus { + outline: 1px solid var(--primary-500); +} + +.frm_form_settings .frmsvg.frm-show-box, +.frm_form_settings .frmsvg.frm-show-inline-modal, +.frm_form_settings i.frm-show-box, +.frm_form_settings i.frm-show-inline-modal { + margin: 4px 4px 0; +} + +/** + * Inline Modals + */ +.frm-open + .frm-inline-modal { + top: -10px; + margin-bottom: 0; +} +.frm-open + .frm-inline-modal.frm-modal-no-dismiss .inside > .frm-search:first-child { + margin-top: var(--gap-sm); +} + +.frm_grid_container > .frm-open + .frm-inline-modal { + top: -4px; +} +.frm_grid_container > .frm-open + .frm-inline-modal.frm-modal-no-dismiss { + top: 0 !important; +} + +/** + * Input Positioning + */ +.frm-with-left-icon input { + padding-left: 37px !important; +} + +.frm_wrap .frm-with-right-icon textarea, +.frm_wrap .frm-with-right-icon input, +.frm_wrap .frm-with-right-icon input[type=text] { + padding-right: var(--gap-md); +} + +#frm-show-fields .frm-with-left-icon .frmsvg, +#frm-show-fields .frm-with-left-icon i { + padding-top: 10px; +} + +/** + * Search Inputs + */ +.frm-search input[name=s], +.frm-search .dropdown-toggle, +.frm-search input.frm-search-input { + color: var(--grey-800); + border-color: var(--grey-300); + border-radius: var(--small-radius); + box-shadow: var(--box-shadow-xs); +} +.frm-search input[type=search], +.frm-search input[type=text] { + padding-left: var(--gap-lg) !important; +} +.frm-search .dropdown-toggle { + width: 100%; + float: none; + max-width: 200px; + background: transparent; + padding: 7px; + padding-left: 33px !important; + min-height: 32px; + text-align: inherit; + overflow: hidden; + text-overflow: ellipsis; +} +.frm-search #search-submit a { + color: var(--grey-800); +} +.frm-search #search-submit .caret { + opacity: 0.7; +} + +.frm-white-body .search-box input[name=s], +#wpwrap .frm-search input[type=search] { + flex: 1; + font-size: var(--text-md); + line-height: var(--text-xl); + padding: var(--gap-xs); +} + +span.multiselect-selected-text { + white-space: nowrap; + display: inline-block; + max-width: calc(90% - var(--gap-xs)); + text-overflow: ellipsis; + overflow: hidden; +} + +/** + * Not Set Fields + */ +.frm-not-set input { + color: var(--primary-500) !important; + font-size: 13px; +} + +.frm-not-set .frmsvg, +.frm-not-set i { + color: var(--primary-700); + opacity: 1; +} + +/** + * Shortcode Select + */ +.post-type-frm_display select[name=m] + #post-query-submit, +select[name=m] { + display: none; +} + +.frm_shortcode_select optgroup option { + margin-left: 1em; +} + +.frm_shortcode_select optgroup { + padding-top: 5px; +} + +.frm_shortcode_select .frm_subopt { + margin-left: 2em; +} + +.misc-pub-section a.edit-frm_shortcode, +.misc-pub-section a.edit-form-status { + float: none; + font-size: 13px; +} + +.frm-grid { + border-collapse: collapse; + border: none; + margin-right: 10px; +} + +.frm-grid td, +.frm-grid th { + padding: 5px; + border: 1px solid black; +} + +/** + * View Page Admin + */ +.post-type-frm_display #poststuff #post-body.columns-2 { + margin-right: var(--big-sidebar); +} + +.post-type-frm_display #post-body.columns-2 #postbox-container-1 { + margin-right: calc(var(--big-sidebar) * -1); + width: calc(var(--big-sidebar) - 40px); +} + +.post-type-frm_display #poststuff #post-body.columns-2 #side-sortables { + width: 100%; +} + +#frm_dyncontent .hndle, +#frm_dyncontent .handlediv { + display: none !important; +} + +.post-type-frm_display .meta-box-sortables .frm_form_nav > li > a, +.post-type-frm_display .frm_form_nav .nav-tab-active { + padding: 0 2px 5px; + line-height: 1.4; +} + +.post-type-frm_display #advanced-sortables h2.hndle, +.post-type-frm_display #side-sortables h2.hndle, +.post-type-frm_display #normal-sortables h2.hndle { + border-bottom: 1px solid var(--grey-300); + margin: 10px 0 0 !important; + padding: 0 25px 8px; +} + +.post-type-frm_display #side-sortables h2.hndle { + margin-top: 0 !important; + padding-top: 10px; +} + +.post-type-frm_display #post-body-content { + margin-top: var(--gap-lg); +} + +.post-type-frm_display.edit-php #wpbody-content > .wrap { + margin: 0; +} + +.post-type-frm_display .postbox .hndle, +.post-type-frm_display .postbox { + border-color: var(--grey-300); +} + +.post-type-frm_display #postbox-container-1 .postbox, +.post-type-frm_display #postbox-container-2 .postbox { + border-radius: var(--small-radius); + border-color: var(--grey-300); + box-shadow: none; +} + +.post-type-frm_display #side-sortables .postbox { + border-radius: 0; + border-top-width: 0; + margin-bottom: 0; +} + +.post-type-frm_display #side-sortables .misc-pub-section { + padding: 15px 20px 10px; +} + +/** + * View Page Admin Icons + */ +.post-type-frm_display .misc-pub-section .frmsvg, +.post-type-frm_display #post-body .misc-pub-post-status::before, +.post-type-frm_display #post-body #visibility::before, +.post-type-frm_display .curtime #timestamp::before, +.post-type-frm_display #post-body .misc-pub-revisions::before, +.post-type-frm_display span.wp-media-buttons-icon::before { + color: var(--grey); +} + +.post-type-frm_display #frm_top_bar + #poststuff #submitdiv #publishing-action, +.post-type-frm_display #frm_top_bar + #poststuff #submitdiv #minor-publishing-actions, +.post-type-frm_display #frm_top_bar + #poststuff #edit-slug-box, +.post-type-frm_display .wrap h1.wp-heading-inline, +.post-type-frm_display .wrap > .page-title-action { + display: none; +} + +/** + * View Page Admin Tabs + */ +.post-type-frm_display #poststuff h2.nav-tab-wrapper { + padding-left: 10px; + margin-bottom: 0; + padding-bottom: 0; +} + +.post-type-frm_display .nav-menus-php .wrap { + margin: 10px 0 0; +} + +.post-type-frm_display .nav-menus-php .wrap p { + padding-left: 12px; + padding-right: 12px; +} + +.post-type-frm_display .nav-tab { + display: inline-block; + background-color: #f4f4f4; +} + +.post-type-frm_display .nav-tab.frm_hidden { + display: none; +} + +.post-type-frm_display .nav-tab:hover { + background-color: #e4e4e4; +} + +/** + * Order/Where Rows + */ +.frm_order_row, +.frm_where_row { + margin-bottom: 7px; + line-height: 30px; +} + +.frm-single-settings .frm_prod_field_opt_cont { + margin-top: initial; + margin-bottom: 20px; +} + +/** + * Editor Elements + */ +/*hide elements if js is avail*/ +select.texture { + display: none; +} + +.post-type-frm_display #wp-content-editor-tools, +#wp-content-editor-tools { + background-color: transparent; +} + +.post-type-frm_display #major-publishing-actions { + border-color: var(--grey-300); + background: var(--sidebar-color); +} + +/** + * Advanced Info Panel + */ +.post-type-frm_display #frm_adv_info { + width: calc(var(--big-sidebar) - 40px); + height: calc(100vh - 32px); + overflow: hidden; +} + +.post-type-frm_display #frm_adv_info:not(.frm_fixed) { + top: 0 !important; +} + +.post-type-frm_display #frm_adv_info.frm_fixed { + position: fixed; + z-index: 9999; + top: 32px; +} + +.post-type-frm_display #frm_adv_info ul.frm_code_list.frm-full-hover { + max-height: calc(100vh - 180px); +} + +/** + * Column Layout + */ +.frm_col_one { + margin-right: 4%; + clear: both; +} + +ul .frm_col_one { + float: left; +} + +ul .frm_col_two { + float: right; +} + +ul.frm_two_col { + display: grid; + grid-template-columns: repeat(2, minmax(0, 1fr)); + gap: var(--gap-sm); +} + +.frm_two_col li { + margin-bottom: 0; +} + +/** + * Component: Info Modals + */ +.frm-info-modal a, +.frm-info-modal ul, +.frm-info-modal p, +.frm-info-modal, +.settings-lite-cta a, +.settings-lite-cta ul, +.settings-lite-cta { + color: var(--grey-500); + font-size: var(--text-md); + box-shadow: none !important; +} + +.frm-info-modal h3, +.settings-lite-cta h3 { + font-size: 17px !important; +} + +.frm-green-icons .frmsvg { + color: var(--green); +} + +.frm-info-modal .postbox .inside, +.settings-lite-cta .postbox .inside { + padding: var(--gap-md); + margin: 0; +} + +.cta-inside a { + color: var(--orange); +} + +.info-modal-inside a.frm-standard-link { + color: var(--primary-500); +} + +.info-modal-inside a.frm-standard-link:hover { + color: var(--primary-700); +} + +.frm_no_p_margin > p { + margin: 0; +} + +/** + * Component: Code List + */ +.frm_code_list a.button { + display: block; + text-align: center; + font-size: 11px; + overflow: hidden; +} + +#frm-navbarDrop + .frm_code_list.frm-full-hover { + margin: var(--gap-xs) 0 0; + min-width: 300px; + max-height: 256px; +} + +.frm_code_list.frm-full-hover li { + margin: 0; +} + +.frm-select-list-item, +.frm_wrap .ui-autocomplete li > div, +.multiselect-container button.multiselect-option, +.frm-dropdown-menu > .dropdown-item > a, +.frm-dropdown-menu > .dropdown-item > a:visited, +.frm-dropdown-menu > .dropdown-item > a:link, +.frm-dropdown-menu .frm_dropdown_li, +.frm_code_list.frm-full-hover a { + display: flex; + color: var(--grey-700); + padding: 5px 10px; + font-size: var(--text-md); + gap: var(--gap-xs); + align-items: center; +} + +.multiselect-container button.multiselect-option.disabled { + opacity: 0.5; +} + +.frm_code_list.frm-full-hover a span { + max-width: 83px; + margin-right: var(--gap-xs); + margin-left: auto; +} + +.frm_code_list.frm-full-hover a { + border-radius: var(--small-radius); +} +.frm_code_list.frm-full-hover a:not(#frm-insert-condition), +.frm_code_list.frm-full-hover a span { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.frm_code_list.frm-full-hover a:focus span:last-child { + outline: 1px solid var(--primary-500); + outline-offset: var(--gap-2xs); +} + +.frm_code_list.frm-full-hover.frmcenter a { + display: block; +} + +#frm-layout-classes frm-full-hover a span { + max-width: 45%; +} + +.frm-select-list-item.active, +.frm-select-list-item:hover, +.frm_wrap .ui-autocomplete li div.ui-state-active, +.frm_wrap .ui-autocomplete li.ui-state-focus, +.multiselect-container button.multiselect-option.active, +.multiselect-container button.multiselect-option:hover, +.frm-dropdown-menu > .dropdown-item > a:hover, +.frm_code_list.frm-full-hover a:hover span, +.frm_code_list.frm-full-hover a:hover { + background: var(--primary-25); + color: var(--primary-500); +} + +.frm-select-list-item .frmsvg, +.frm-dropdown-menu > .dropdown-item > a .frmsvg { + opacity: 0.8; +} + +.frm-select-list-item:hover .frmsvg, +.frm-dropdown-menu > .dropdown-item > a:hover .frmsvg { + opacity: 1; +} + +.frm-dropdown-menu.frm_code_list > li > a { + padding: 3px 15px; + width: 300px; +} + +#frm_edit_box_content_modal .frm-with-search, +.frm-dropdown-menu .frm-with-search { + padding: var(--gap-xs) 10px 0; +} + +.frm-dropdown-menu .subsubsub { + padding: 0 10px; +} + +.frm_grid_container { + overflow: visible; +} + +.frm_code_list.frm_grid_container { + grid-gap: var(--gap-xs); +} + +.frm_code_list.frm_grid_container li { + width: auto; + margin: 0; +} + +.frm_code_list.frm_grid_container a { + display: block; + font-size: var(--text-md) !important; + font-weight: 500; + text-align: center; + color: var(--primary-500); + background-color: var(--light-blue); + border: 1px solid var(--primary-300); + border-radius: var(--small-radius); + padding: 10px 0; + box-shadow: var(--box-shadow-sm); +} +.frm_code_list.frm_grid_container a:hover { + background-color: var(--primary-500); + color: #fff; +} +.frm_code_list.frm_grid_container a:focus-visible { + outline: 2px solid var(--primary-500); + outline-offset: -1px; +} + +.frm-single-settings .frm_code_list.frm-full-hover, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { + padding: 0; + margin: var(--gap-xs) -10px 0; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a { + font-size: var(--text-md); + color: var(--grey-900); + padding: var(--gap-xs) 12px; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a span, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span { + margin: 0; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a span:first-child, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:first-child { + max-width: 130px; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a span:last-child, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:last-child { + max-width: 120px; + margin-left: auto; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover { + font-weight: 500; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover .frmsvg, +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover span, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover .frmsvg, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover span { + color: var(--primary-500); +} + +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { + margin: var(--gap-xs) 0 0; +} +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg { + width: 20px; + height: 20px; +} + +/** + * Component: Insert Fields + */ +.frm_field_list #frm-insert-fields { + max-height: none; + font-size: var(--text-sm); +} +.frm_field_list #frm-insert-fields .button a { + display: block; + max-width: 95%; + overflow: hidden; +} + +#frm-insert-fields { + padding: 0 var(--gap-xs); + overflow: hidden; +} +#frm-insert-fields .frm-search { + float: none; + margin: 0 0 var(--gap-md); + width: auto; +} +#frm-insert-fields li { + /* Prevents advanced fields from always appearing in search results */ +} +#frm-insert-fields li, +#frm-insert-fields li a { + text-decoration: none; + font-weight: 500; + font-size: var(--text-md) !important; + color: var(--grey-900); +} +#frm-insert-fields li.frm_show_upgrade { + cursor: pointer; + opacity: 0.5; +} +#frm-insert-fields li.frm_show_update { + cursor: pointer; +} +#frm-insert-fields li span:not(.frm-new-pill) { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + text-align: left; +} +#frm-insert-fields li a.disabled:hover { + cursor: not-allowed; +} +#frm-insert-fields li.ui-draggable-disabled { + opacity: 0.5; +} +#frm-insert-fields li a:not(.disabled):hover .frmsvg, +#frm-insert-fields li a:not(.disabled):hover i { + color: var(--grey-600); +} +#frm-insert-fields li.frm_show_upgrade, #frm-insert-fields li.frm_show_update, +#frm-insert-fields li a { + text-decoration: none; + display: inline-flex !important; + gap: var(--gap-xs); + align-items: center; + border-radius: var(--small-radius) !important; + padding: 11px var(--gap-md) 11px var(--gap-xs) !important; + color: var(--grey-900) !important; +} +#frm-insert-fields li a { + display: flex !important; + transition: background-color 0.2s ease-out, box-shadow 0.2s ease-out; +} +#frm-insert-fields li a:not(.disabled):hover { + background: #fff; + box-shadow: var(--box-shadow-md); +} +#frm-insert-fields li a:focus-visible { + outline: 1px solid var(--primary-500); +} +#frm-insert-fields li.frm_show_upgrade.frm_hidden, #frm-insert-fields li.frm_show_update.frm_hidden { + display: none !important; +} +#frm-insert-fields .frm-with-line { + padding: 12px var(--gap-md); + font-weight: 500; + font-size: var(--text-sm); +} +#frm-insert-fields .frm-with-line::before { + margin-left: calc(-1 * var(--gap-sm)); + width: calc(100% + var(--gap-md)); +} + +.frm_code_list { + clear: both; +} +.frm_code_list.frm-full-hover a.frm_hidden, +.frm_code_list .frmkeys { + display: none; +} + +.frmsvg { + fill: currentColor; + width: 18px; + height: 18px; + vertical-align: middle; +} +.frmsvg svg { + pointer-events: none; +} +.frmsvg.frm_svg40 { + width: 40px; + height: 40px; +} +.frmsvg.frm_svg24 { + width: 24px; + height: 24px; +} +.frmsvg.frm_svg20 { + width: 20px; + height: 20px; +} +.frmsvg.frm_svg15 { + width: 15px; + height: 15px; +} +.frmsvg.frm_svg14 { + width: 14px !important; + height: 14px !important; +} +.frmsvg.frm_svg13 { + width: 13px; + height: 13px; +} +.frmsvg.frm_svg12 { + width: 12px; + height: 12px; +} +.frmsvg.frm_svg9 { + width: 9px; + height: 9px; +} +.frmsvg.frm_svg7 { + width: 7px; + height: 7px; +} + +input[disabled] { + pointer-events: none; +} + +.frmbutton.ui-sortable-helper .frmsvg, +.field_type_list li.frmbutton .frmsvg, +.frmbutton.ui-sortable-helper i, +.field_type_list li.frmbutton i, +.frm_code_list a .frmsvg, +.frm_code_list a i { + color: var(--grey-500); + display: inline-block; + vertical-align: middle; + width: var(--text-md); + font-size: var(--text-md); +} + +.field_type_list.frm_grid_container { + gap: 10px; + margin: 13px 0; +} +.field_type_list li { + margin: 0; + padding: 0; +} +.field_type_list li.frmbutton .frmsvg { + width: 24px; + height: 24px; + font-size: 24px; +} + +.frm_code_list i::before { + font-size: inherit; +} + +/* Icon while dragging */ +.frmbutton.ui-draggable-dragging { + pointer-events: none; +} +.frmbutton.ui-draggable-dragging a { + color: var(--grey-900) !important; + background: var(--grey-100); + text-decoration: none; + display: inline-flex !important; + gap: var(--gap-xs); + align-items: center; + border-radius: var(--small-radius) !important; + padding: 11px var(--gap-md) 11px var(--gap-xs) !important; + box-shadow: var(--box-shadow-md); +} + +.frmbutton.frm_at_limit { + opacity: 0.5; +} + +/** + * Component: Field Dragging + */ +.frmbutton.ui-draggable-dragging a { + border: 1px solid var(--grey-300); + box-shadow: var(--box-shadow-md); +} + +.frmbutton.ui-draggable-dragging span { + font-size: 15px; +} + +#frm-show-fields .frmbutton.ui-sortable-helper i, +.frmbutton.ui-draggable-dragging i, +.frmbutton.ui-draggable-dragging .frmsvg { + color: #fff !important; +} + +.frmbutton.ui-draggable-dragging i, +.frmbutton.ui-draggable-dragging .frmsvg { + color: var(--grey-700) !important; +} + +.frm_sorting li.ui-state-default.ui-sortable-helper, +.frmbutton.ui-sortable-helper { + transition: opacity 0.2s; + opacity: 1; + position: fixed; + z-index: 99999; +} + +#frm-insert-fields .frmbutton.ui-sortable-helper a, +#frm-show-fields .frmbutton.ui-sortable-helper a { + min-width: 100px; +} + +.ui-draggable-dragging .frm-meta-tag.frm-new-pill { + display: none; +} + +/* End dragging */ +li.frm_noallow.button, +.frm_noallow { + opacity: 0.5; +} + +.frm_actions_list a.frm_show_upgrade.frm_inactive_action::before, +li.frm_noallow.button.frm_show_upgrade, +li.frm_noallow.button.frm_show_update { + cursor: pointer; +} + +.field_type_list li.frm_noallow.button.frm_show_upgrade:hover, +.field_type_list li.frm_noallow.button.frm_show_update:hover { + border-color: inherit; +} + +.frm_noallow a { + color: inherit; +} + +/** + * Component: Upgrade Modal + */ +#frm_upgrade_modal_image { + max-width: 200px; +} + +#frm_upgrade_modal .cta-inside { + display: flex; + flex-direction: column; + gap: var(--gap-sm); +} +#frm_upgrade_modal .frm-upgrade-message img { + width: 100%; + margin: var(--gap-sm) 0 10px; +} +#frm_upgrade_modal .frm-oneclick.frm_hidden { + display: none !important; +} +#frm_upgrade_modal .frm-oneclick-button { + margin-left: auto; +} +#frm_upgrade_modal .frm-upgrade-modal-actions { + flex-direction: row-reverse; + justify-content: flex-start; + margin: 0 !important; +} +#frm_upgrade_modal .frm-upgrade-link { + align-self: end; +} +#frm_upgrade_modal.frm-success .frm-circled-icon svg { + width: 24px; + height: 24px; +} +#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-prefix, +#frm_upgrade_modal.frm-success .frm_are_not_installed { + display: none !important; +} +#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-suffix { + display: inline !important; +} +#frm_upgrade_modal.frm-success .frm-addon-status { + margin: 0; +} +#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options { + display: flex; + gap: var(--gap-xs); + flex-direction: row-reverse; + margin: 0; +} +#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options .frm-save-and-reload { + margin: 0; +} + +.frm-dialog[aria-describedby=frm_upgrade_modal] { + position: fixed !important; + top: 50% !important; + left: 50% !important; + transform: translate(-50%, -50%) !important; +} + +/** + * Layout: Reports Info + */ +.frm-tab-message { + max-width: 600px; + margin: 20px auto; + color: rgba(63, 75, 91, 0.8); +} + +.frm-settings-screenshot-toolbar { + min-height: 39px; + display: flex; +} + +.frm-settings-screenshot-toolbar .frm-minmax-icon { + height: 8px; + width: 8px; + border-radius: 50%; + align-self: center; + margin-left: 10px; +} + +.frm-settings-screenshot-toolbar .frm-minmax-icon:first-of-type { + margin-left: 20px; +} + +.frm-settings-screenshot-toolbar img { + object-fit: contain; + align-self: flex-end; + margin-left: 25px; +} + +.frm-settings-screenshot-toolbar + div { + background: #fff; + padding-top: 25px; + border-radius: 0 0 16px 16px; +} + +.frm-settings-screenshot-toolbar + div img { + max-width: calc(100% - 40px); +} + +.frm-settings-screenshot-wrapper { + max-width: 700px; + margin: 50px auto 0; + box-shadow: 0 4px 4px rgba(189, 196, 205, 0.25), 0 12px 56px rgba(42, 57, 75, 0.25); + border-radius: 16px; + background: #ebecf1; +} + +/** + * Component: Dialog + */ +.frm-dialog { + z-index: 100; + padding: 0 !important; + border-radius: 16px; + border: none; + background-color: #fff; + max-width: 100% !important; +} + +.frm-dialog .postbox { + background: transparent; + box-shadow: none; + border: none; + line-height: var(--leading); +} + +.frm-dialog input[type=text], +.frm-dialog textarea { + font-size: var(--text-md); +} + +.frm-dialog textarea { + height: 75px; +} + +.frm-dialog button.frm-button-primary { + margin-right: 10px; +} + +.frm-dialog .frm-sub-label, +.frm-sub-label { + color: var(--grey); + text-transform: none; + padding-left: 8px; +} + +h2 .frm-sub-label { + font-size: var(--text-md); +} + +.frm-views-editor-body .ui-widget-overlay, +.frm-white-body .ui-widget-overlay, +.toplevel_page_formidable .ui-widget-overlay, +body[class*=formidable-payments] .ui-widget-overlay, +body.plugins-php .ui-widget-overlay { + position: fixed; + width: 100%; + height: 100%; + top: 0; + left: 0; + right: 0; + bottom: 0; + background: var(--grey-500); + opacity: 0.5; + z-index: 2; +} + +/** + * Component: Circled Icons + */ +.frm-circled-icon { + width: 60px; + height: 60px; + border-radius: 50%; + background-color: var(--primary-25); +} + +.frm-circled-icon-large { + width: 80px; + height: 80px; +} + +.frm-circled-icon-green { + background-color: var(--success-50); +} + +.frm-circled-icon .frmsvg { + width: 21px; + height: 24px; +} +.frm-circled-icon .frmsvg.frm_svg32 { + width: 32px !important; + height: 32px !important; +} + +.frm-circled-icon-large .frmsvg { + width: 24px; +} + +.frm-circled-icon .frmsvg use { + color: var(--primary-500); +} + +.frm-circled-icon-green .frmsvg use { + color: var(--success-500); +} + +.frm-border-icon { + display: flex; + align-items: center; + justify-content: center; + width: 40px; + height: 40px; + border: 1px solid var(--grey-300); + border-radius: var(--small-radius); +} + +.frm-upgrade-message img { + max-width: 100%; +} + +/** + * Component: Link Styles + */ +a.frm-link-secondary { + color: #c4c4c4; + font-size: var(--text-sm); + text-decoration: underline; +} + +.field_type_list li.button.frm_noallow, +.field_type_list li.button.frm_noallow:hover, +.button.frm_noallow, +.button.frm_noallow:hover { + color: inherit; + border-color: #ccc; + background: inherit; +} + +iframe#dyncontent_ifr { + min-height: 150px; +} + +/*! * Bootstrap v4.6.1 - */.tooltip{position:absolute;display:block;margin:0;font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0;z-index:9999999;pointer-events:none}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem;margin-left:0 !important}.tooltip .arrow::before{position:absolute;content:"";border-color:rgba(0,0,0,0);border-style:solid}.bs-tooltip-top,.bs-tooltip-auto[x-placement^=top]{padding:.4rem 0}.bs-tooltip-top .arrow,.bs-tooltip-auto[x-placement^=top] .arrow{bottom:0}.bs-tooltip-top .arrow::before,.bs-tooltip-auto[x-placement^=top] .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-right,.bs-tooltip-auto[x-placement^=right]{padding:0 .4rem}.bs-tooltip-right .arrow,.bs-tooltip-auto[x-placement^=right] .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-right .arrow::before,.bs-tooltip-auto[x-placement^=right] .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-bottom,.bs-tooltip-auto[x-placement^=bottom]{padding:.4rem 0}.bs-tooltip-bottom .arrow,.bs-tooltip-auto[x-placement^=bottom] .arrow{top:0}.bs-tooltip-bottom .arrow::before,.bs-tooltip-auto[x-placement^=bottom] .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-left,.bs-tooltip-auto[x-placement^=left]{padding:0 .4rem}.bs-tooltip-left .arrow,.bs-tooltip-auto[x-placement^=left] .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-left .arrow::before,.bs-tooltip-auto[x-placement^=left] .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.frm-dropdown-menu.show{display:block}.frm-single-settings .frm-dropdown-menu.show{background:#fff}.preview.dropdown .dropdown-menu{min-width:205px}.frm_clear{clear:both}.frm_clearfix::after{content:".";display:block;clear:both;visibility:hidden;line-height:0;height:0}.frm_clearfix{display:block}.frm_admin_progress{overflow:hidden;height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.frm_admin_progress_bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);transition:width .6s ease;background-color:#04a4cc}.tooltip.frm_tooltip{position:fixed;top:auto !important;bottom:0 !important;left:0 !important;max-width:none;width:100% !important;z-index:99999}.tooltip.frm_tooltip.bottom{padding:0}.frm_tooltip .tooltip-inner{max-width:none;min-height:40px !important;text-align:left;box-shadow:5px 5px 25px rgba(0,0,0,.5);padding:10px 40px;border-top-color:#ccc;background:var(--sidebar-color);color:var(--grey-700);border-radius:0;opacity:1;font-size:var(--text-sm)}#frm_custom_css_box{width:100%}.frmdates_add_blackout_date_link,.frmdates_add_exception_link,.frm_form_field.frm_scroll_box .frm_opt_container,.frm-white-body .wrap input[type=text],.frm-white-body .wrap input[type=search],.frm-white-body .wrap input[type=number],.frm-white-body .wrap select,#frm-form-templates-modal select,.frm-white-body .wrap textarea,button.frm_choose_image_box,#titlediv input[type=text],.frm-fields button.btn,.frm_wrap textarea,.frm_wrap input[type=tel],.frm_wrap input[type=text],.frm_wrap input[type=email] .frm_wrap input[type=search],.frm_wrap input[type=number],.frm_wrap input[type=date],.frm_wrap select,.wp-admin .frm_wrap select,.field-group textarea,.field-group input[type=text],.field-group select,.frm-fields .frm-input-field{outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;background-color:#fff;line-height:var(--leading)}.frm_input_with_suffix{border-radius:var(--small-radius);border:1px solid var(--grey-300);display:inline-block;padding-right:14px}.frm_input_with_suffix input{border:0 !important;padding-right:5px !important}.frm_wrap ::-webkit-datetime-edit{line-height:var(--leading)}.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus,.frm_wrap input:focus,.frm_wrap select:focus,.wp-core-ui .frm_wrap select:focus,#frm-form-templates-modal select:focus,.frm-btn-group .multiselect.dropdown-toggle:focus,.frm_wrap textarea:focus{border-color:var(--primary-500) !important;box-shadow:none !important}.wp-admin .frm_fields_container textarea:focus,.wp-admin .frm_fields_container input:focus,.wp-admin .frm_fields_container select:focus{border-color:var(--primary-500);box-shadow:none}#postbox-container-2 textarea,.frm_wrap textarea,.field-group textarea{line-height:2}.frm_wrap input[type=number]{height:auto}.frm_wrap select{padding:2px}.wp-admin .frm_wrap select,#frm-form-templates-modal select{max-width:100%}.frm_form_field.frm_scroll_box .frm_opt_container{padding:10px 12px}.frm_wrap input[disabled],.frm_wrap select[disabled],.frm_wrap textarea[disabled],.frm_wrap input[readonly],.frm_wrap select[readonly],.frm_wrap textarea[readonly],.frm_wrap input::placeholder{color:var(--grey-500)}textarea[id^=frm_calc_]::placeholder{font-size:var(--text-sm);line-height:var(--leading);font-style:italic;color:var(--grey-400);padding-top:5px}.frm_wrap .frm-button-primary.frm-disabled{opacity:.5;cursor:default}#postcustomstuff table td>div{padding-top:0 !important}.wp-admin .frm_wrap .form-table select{vertical-align:top}.frm_wrap .frm_form_builder select{line-height:var(--leading);height:var(--text-md);width:100%}#postbox-container-2 select,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,#frm-form-templates-modal select{height:auto}.frm-white-body .tablenav select,.frm-white-body .tablenav input[type=text],.wp-admin .frm_wrap .tablenav select,.frm_wrap .tablenav input[type=date],.frm_wrap .tablenav input[type=text]{padding-top:0;padding-bottom:0;line-height:1}.frm_wrap .tablenav ::-webkit-datetime-edit{line-height:1}.frm-fields button.btn,.frm-fields textarea,.frm-fields input[type=text],.frm-fields select,.field-group textarea,.field-group input[type=text],.field-group select,.accordion-container input.hex,.frm-fields .frm-input-field{width:100%;outline:0}.frm-fields button.btn{height:var(--h-md);text-align:inherit}.global-font .field-group input[type=text]{width:auto}.wp-core-ui .frm_grey.frm-button-primary.disabled,.wp-core-ui .frm_grey.frm-button-primary,#frm-welcome .frm_grey{opacity:.5;background:#f6f6f6 !important;border-color:#ddd !important;color:#9fa5aa !important}.windows::-webkit-scrollbar,.windows ::-webkit-scrollbar{width:7px;background:rgba(0,0,0,0)}.windows::-webkit-scrollbar-thumb,.windows ::-webkit-scrollbar-thumb{background:var(--grey-300);-webkit-border-radius:var(--border-radius);-webkit-box-shadow:none}.windows::-webkit-scrollbar-corner,.windows ::-webkit-scrollbar-corner{background:rgba(0,0,0,0)}.frm-scrollbar-wrapper,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list,#frm_builder_page #frm_adv_info .frm_code_list,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div,.frm-single-settings .frm_field_opts_list{overflow-x:hidden;overflow-y:auto !important;-ms-overflow-style:none;scrollbar-color:rgba(0,0,0,0) rgba(0,0,0,0);scrollbar-width:thin}.frm-scrollbar-wrapper:hover,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover,#frm_builder_page #frm_adv_info .frm_code_list:hover,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div:hover,.frm-single-settings .frm_field_opts_list:hover{scrollbar-color:var(--grey-300) rgba(0,0,0,0)}.frm-scrollbar-wrapper:hover::-webkit-scrollbar-thumb,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info .frm_code_list:hover::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div:hover::-webkit-scrollbar-thumb,.frm-single-settings .frm_field_opts_list:hover::-webkit-scrollbar-thumb{background:var(--grey-300)}.frm-scrollbar-wrapper::-webkit-scrollbar,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar{width:3px}.frm-scrollbar-wrapper::-webkit-scrollbar-track,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-track,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-track,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar-track,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-track{background:rgba(0,0,0,0);border-radius:100vw}.frm-scrollbar-wrapper::-webkit-scrollbar-thumb,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar-thumb,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb{background:rgba(0,0,0,0);border-radius:100vw}.frm-scrollbar-wrapper::-webkit-scrollbar-thumb:hover,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb:hover,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb:hover,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar-thumb:hover,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb:hover{background:var(--grey-300)}.rtl h3{font-weight:inherit !important}.rtl.js .accordion-section-title::after{left:10px;right:auto}.rtl #frm_top_bar #frm_bs_dropdown{padding-left:15px}.rtl .frm-full-close,.rtl .frm_wrap .columns-2 .frm-right-panel+div,.rtl .frm-right-panel{border-left-width:0;border-right:1px solid var(--grey-300)}.rtl .frm-full-close{padding-left:0;padding-right:var(--gap-md)}.rtl .frm-text-right{text-align:left}.rtl .frm_wrap #frm_adv_info ul.category-tabs li:first-child{border-left-width:1px}.rtl .frm-dropdown-menu{text-align:right}.rtl #frm-insert-fields-box,.rtl #frm-conditionals{padding-right:.9em}.rtl #html_settings .frm_field_html_box{margin-right:0}.rtl .frm_list_entry_page h2{float:right}.rtl .frm_scale{float:right;margin-left:10px;margin-right:0}.rtl .frm-page-break .frm-collapse-page.button{margin-left:0;margin-right:46%}.rtl .frm-field-action-icons{right:unset;left:2px}.rtl .frm_has_shortcodes>i{right:auto;left:5px}.rtl p.frm_reply_to_container,.rtl p.frm_bcc_cc_container{float:left}.rtl .frm-with-right-icon:not(.frm-token-container) .frmsvg{right:auto;left:0}.rtl .frm-inline-modal>a.dismiss{left:13px;right:auto}.rtl.wp-admin .frm_wrap select{padding-left:var(--gap-lg) !important;padding-right:5px !important;background-position:left 11px top 55%}.rtl .frm_code_list.frm-full-hover a span{margin-left:var(--gap-xs)}.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child{margin-left:unset;margin-right:var(--gap-xs)}.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child{margin-right:unset;margin-left:var(--gap-xs)}.rtl .frm-style-tabs-wrapper .frm-tabs-active-underline{left:unset !important;right:0}.rtl .frm-unit-input .frm-input-group-suffix{right:unset;left:1px;padding-right:unset;padding-left:var(--gap-xs)}.rtl .frm-unit-input .frm-input-group-suffix select{text-align:left;background-position:left 0 top 50%;padding-left:21px !important}span.clear{display:block}.clearfix::after{content:".";display:block;height:0;clear:both;visibility:hidden}.clearfix{display:inline-block}.frm_form_fields .clear{height:auto}* html .clearfix{height:1%}.clearfix{display:block}#frm_small_device_message_container{display:none}@media only screen and (max-width: 1200px){.frm-addons{grid-template-columns:1fr 1fr}#frm_top_bar h1{min-width:0}}@media only screen and (max-width: 1050px){.frm-white-body,.frm_wrap{--biggest-sidebar: 390px}#form_settings_page .columns-2{margin:0}.frm_actions_list{margin-left:0}#frm_bs_dropdown .frm_bstooltip{display:none !important}}@media only screen and (max-width: 960px){.frm-white-body,.frm_wrap{--gap-sm: 8px;--gap-md: 16px;--gap-2xl: 24px}.frm-settings-panel{--gap-sm: 16px;--gap-md: 24px;--gap-2xl: 32px}.auto-fold #adminmenuwrap{width:36px}.frm_wrap #postbox-container-1 #frm_adv_info{min-width:220px}p.howto{display:inline-block}.auto-fold.frm-admin-page-styles:not(.frm-full-screen) .frm_page_container,.auto-fold:not(.frm-full-screen) .frm_wrap .frm_page_container{left:36px}}@media only screen and (max-width: 850px){.frm-white-body,.frm_wrap{--biggest-sidebar: 350px;--big-sidebar: 350px}.frm_col_one{clear:none}.frm-fields p>.frm_inline_label,.frm_inline_label{display:block;margin:5px 0}#frm_top_bar h1{width:auto;max-width:200px}#frm-publishing{width:auto}#frm_form_editor_container,.frm-entry-container{margin:0 20px}.frm_wrap .frm-search{float:none !important;width:auto;clear:both}.post-type-frm_display #frm_adv_info{top:auto !important;position:static;width:auto}.frm_wrap .frm-right-panel #frm_adv_info,.frm_wrap #postbox-container-1 #frm_adv_info{min-width:275px}.frm_wrap #frm_adv_info ul.category-tabs li,.frm_wrap #frm_adv_info ul.category-tabs li.tabs{border:none}.frm_wrap #frm_adv_info ul.category-tabs li:first-child{margin-left:12px}.frm_wrap #frm_adv_info ul.category-tabs li.tabs{border-bottom:2px solid #5b9dd9;padding-bottom:8px}.post-type-frm_display #poststuff{padding:10px 25px}.post-type-frm_display #side-sortables .postbox{margin-bottom:20px;border-radius:var(--small-radius);border-top-width:1px}#frm_top_bar .frm_form_nav{box-shadow:0 -0.47px 10px 0 rgba(16,24,40,.0588235294)}#frm_top_bar ul.frm_form_nav{padding:1em 0;position:fixed;bottom:0;width:100%;background:#fff;z-index:99;transform:translate(-50%, 0);left:50%}.frm_page_container>.columns-2,#frm_styler_wrapper{padding-bottom:64px}#frm_style_preview .frm_floating_style_button:not(.frm_hidden){position:static;display:inline-block}.frm_wrap .columns-2 .frm-right-panel{padding-bottom:0}#frm-publishing{margin-left:auto}#frm_top_bar>.frm-full-close:last-child{margin-left:0}#frm_bs_dropdown{display:block}#frm_bs_dropdown .frm_bstooltip{display:block !important}}@media only screen and (max-width: 782px){.frm-white-body,.frm_wrap{--small-sidebar: 20%;--medium-sidebar: 35%}#form_settings_page .advanced_settings .form-table td,.form-table th{display:table-cell;width:auto !important}.frm-white-body #publishing-action,.frm_wrap #publishing-action{line-height:normal}.frm-white-body #screen-meta-links{display:none}.frm_wrap .misc-pub-section{padding:6px 0}.frm_wrap .misc-pub-section>a{float:none;white-space:nowrap}.frm-form-setting-tabs a{position:relative;padding:10px 5px 10px 40px}.frm-form-setting-tabs a .frmsvg,.frm-form-setting-tabs a i{position:absolute;left:13px;top:calc(50% - 10px);margin:0}#frm-insert-fields .button,#frm-insert-fields .button a,.frmbutton.ui-sortable-helper a{line-height:26px;max-height:28px}a.frm_add_logic_link{margin-left:0;margin-right:0;width:100%;box-sizing:border-box}a.frm_add_logic_link:not([id^=logic_]) .frmsvg,a.frm_add_logic_link i{display:none}#new_fields .frm_single_option select,#new_fields .frm_single_option input[type=text]{width:calc(100% - 83px)}.frm_single_entry_page .frm_form_fields input[type=text],.frm_single_entry_page .frm_form_fields select,.frm_single_entry_page .frm_form_fields textarea{width:100%}.with_frm_style .frm_radio input[type=radio],.with_frm_style .frm_checkbox input[type=checkbox]{width:25px !important}.frm_single_entry_page .with_frm_style .frm_radio input[type=radio],.frm_single_entry_page .with_frm_style .frm_checkbox input[type=checkbox]{width:18px !important}.wp-list-table.toplevel_page_formidable .column-entries,.wp-list-table.toplevel_page_formidable .column-form_key,.wp-list-table.toplevel_page_formidable .column-shortcode,.wp-list-table.toplevel_page_formidable .column-created_at{display:none !important}.wp-list-table.toplevel_page_formidable td.column-entries,.wp-list-table.toplevel_page_formidable td.column-form_key,.wp-list-table.toplevel_page_formidable td.column-shortcode,.wp-list-table.toplevel_page_formidable td.column-created_at{padding:3px 8px 3px 35%;text-align:left}#form_entries_page .wp-list-table th.frm_hidden,#form_entries_page .wp-list-table td.frm_hidden{display:none !important}.frm-white-body.auto-fold #wpcontent{padding-left:0}.frm_right_addon .frm_remove_field{bottom:11px}.frm-addons{grid-template-columns:1fr}.frm-admin-page-styles .frm_page_container,.frm_wrap .frm_page_container{left:0 !important}.frm_single_entry_page.frm_wrap .columns-2{display:block;border-bottom:none}.frm_single_entry_page .wrap.frm-with-margin{margin:10px 20px}.frm_single_entry_page #post-body-content+.frm-right-panel{width:auto;margin:0 20px;border:1px solid var(--sidebar-hover);border-radius:6px}#wp-content-media-buttons a.frm_insert_form{padding:0 var(--gap-sm)}.frm-white-body input[type=checkbox]:checked::before,.frm_wrap input[type=checkbox]:checked::before{width:1.2rem;height:1.2rem}}@media only screen and (max-width: 700px){.frm-white-body,.frm_wrap{--biggest-sidebar: 50%;--big-sidebar: 50%}}@media only screen and (max-width: 600px){.frm-white-body,.frm_wrap{--small-sidebar: 45px}.frm-form-setting-tabs a{visibility:collapse;font-size:0;padding:0 var(--gap-sm)}.frm-form-setting-tabs a .frmsvg,.frm-form-setting-tabs a i{visibility:visible;position:initial;font-size:18px}#frm_builder_page #frm-insert-fields{padding:0}.frm_wrap #frm_adv_info ul.category-tabs li{display:inline-block;padding:0;margin:2px 0;border-bottom:2px solid rgba(0,0,0,0)}.frm_wrap #frm_adv_info ul.category-tabs li.tabs,.frm_wrap #frm_adv_info ul.category-tabs li:first-child{margin-left:0;padding:0}.field_type_list li{text-align:center}#frm-insert-fields li a{padding:5px}#frm_form_editor_container .frm_primary_label{clear:both}#frm_builder_page .frm_code_list a.button{padding:2px}.frm-right-panel h3.accordion-section-title{padding-right:10px;padding-left:10px;font-size:20px;white-space:nowrap;overflow:hidden}.frm-right-panel .accordion-section-title::before{margin-left:0;margin-right:3px}.frm_on_submit_type svg{display:none}}@media only screen and (max-width: 475px){#frm_bs_dropdown{float:none}#frm-nav-tabs{padding:0;white-space:nowrap}#frm-nav-tabs a{margin-right:0}#frm_small_device_message_container{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;top:0;width:100%;height:100%;z-index:999999;background:var(--primary-500)}#frm_small_device_message{text-align:center;display:flex;flex-direction:column;align-items:center;width:80%;padding:1rem;background:#fff;border:solid 1px #fff;border-radius:var(--medium-radius)}#frm_small_device_message::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-78%, -65%);width:900px;height:900px;background-color:#0d7dfc;border-radius:50%;z-index:-1;opacity:.3}#frm_small_device_message>svg{padding-bottom:1rem}.toplevel_page_formidable:has(#frm_small_device_message_container) #posts-filter,.post-type-frm_display:has(#frm_small_device_message_container) #posts-filter{display:none}}@media print{a,.misc-pub-section a{color:#000 !important}.add-new-h2,#frm_top_bar,.dashicons,#adminmenuwrap,#adminmenuback,#wphead,#button_bar,#submitdiv,.button-secondary,#screen-metas,#screen-meta-links,#footer,#wpfooter,.inner-sidebar,.frm_form_nav,.frm_flash_graph,.frm_no_print,object,.error{visibility:hidden;display:none !important}.widget,.postbox,.stuffbox,.postbox h3{border-width:0 !important;border-color:#fff}.postbox{background:#fff !important;border:none;position:static}.postbox h3,.postbox h4{background:#fff !important}#wpbody-content{float:none}#wpcontent,#post-body-content,.has-right-sidebar #post-body,#poststuff .columns-2{margin:0 !important}.frm_wrap #poststuff .columns-2{display:block}#post-body-content+.frm-right-panel,.frm_wrap .columns-2 .frm-right-panel,.frm-right-panel{border:none;width:auto;display:block;padding:20px}.frm_wrap .columns-2,.frm_wrap .frm_page_container{height:auto;display:block}.misc-pub-section>span{padding:0}.frm-right-panel .postbox .inside{padding-left:12px;padding-right:12px}.curtime #timestamp::before{display:none;content:none !important}.frm_charts .alignleft{float:none}.pg_odd,.pg_even{page-break-inside:avoid;max-width:600px}.form-table td,.form-table th{padding:0}.frm_file_container a{display:block;width:100%}}.frm-admin-page-styles #frm-publishing #save_menu_header,.frm-admin-page-styles2 #frm-publishing #save_menu_header{display:inline-block}.edit_form_item .frm_combo_inputs_container[data-name-layout=last_first] .frm_form_subfield-first{order:2}.frm-video-wrapper iframe{width:100%;max-width:843px;border-radius:var(--border-radius)}#frm_field_group_popup{position:absolute;top:0;right:0;width:366px;max-height:231px;border-radius:8px;background:#fff;box-shadow:0 20px 48px rgba(40,47,54,.15);z-index:3;box-sizing:border-box;padding:24px 0;text-align:left}.rtl #frm_field_group_popup{text-align:right}.frm-merge-fields-into-row #frm_field_group_popup{top:unset;bottom:50px;height:196px}#frm_field_group_popup>hr{margin:12px 0}#frm_field_group_popup .frm-cancel-custom-field-group-layout,#frm_field_group_popup .frm-save-custom-field-group-layout{padding:4px 18px}#frm_field_group_popup .frm-cancel-custom-field-group-layout:hover{border-color:var(--primary-500) !important;color:var(--primary-500);background-color:rgba(0,0,0,0) !important}.frm-merge-fields-into-row #frm_field_group_popup .frm-break-field-group{display:none}.frm-merge-fields-into-row>a{color:rgba(40,47,54,.85);position:relative;top:2px}.frm-row-layout-title{font-weight:600;font-size:11px;line-height:15px;text-transform:uppercase;color:rgba(40,47,54,.45);margin-bottom:27px}.frm-row-layout-option{background:#f6f7fb;box-sizing:border-box;border-radius:2px;padding:15px 10px}#frm_field_group_popup .frm-row-layout-option .frm_grid_container{grid-gap:0 5%;grid-template-columns:repeat(12, auto)}#frm_field_group_popup .frm-row-layout-option{cursor:pointer;border:2px solid rgba(0,0,0,0)}#frm_field_group_popup .frm-row-layout-option.frm-active-row-layout,#frm_field_group_popup .frm-row-layout-option:hover{border-color:var(--primary-500)}.frm-custom-field-group-layout,.frm-break-field-group{padding:4px 24px;cursor:pointer;font-size:var(--text-sm);line-height:19px;color:#484e54}.frm-custom-field-group-layout:hover,.frm-break-field-group:hover{background-color:rgba(245,245,245,.9607843137)}.frm-custom-field-group-layout svg,.frm-break-field-group svg{margin-right:5px}#frm_field_multiselect_popup{background:#fff;height:48px;position:fixed;border-radius:4px;box-shadow:0 8px 24px rgba(40,47,54,.15);color:rgba(40,47,54,.85);font-size:13px;right:30px;bottom:10px;z-index:2}#frm_field_multiselect_popup>div{display:inline-block;line-height:48px;vertical-align:top}#frm_field_multiselect_popup.frm-unmergable>.frm-merge-fields-into-row,#frm_field_multiselect_popup.frm-unmergable>.frm-multiselect-popup-separator{display:none}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator){padding:0 20px;cursor:pointer}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator):hover{background:rgba(245,245,245,.9607843137)}.frm-builder-popup-heading{font-weight:600;font-size:11px;line-height:15px;text-transform:uppercase;color:rgba(40,47,54,.45);margin-bottom:7px}.frm-builder-popup-subheading{font-size:12px;line-height:16px;color:rgba(40,47,54,.45)}#frm_field_group_popup input[type=text]{height:30px;border-radius:3px;font-size:14px;padding:8px;color:#545f6e;border-color:rgba(40,47,54,.2)}.frm-multiselect-popup-separator{height:36px;width:1px;position:relative;top:6px;background:#c4c4c4}.frm-sortable-helper,.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider){pointer-events:none}.frm-sortable-helper{z-index:99}#frm_banner{width:100%;color:#fff;background:var(--primary-500);height:40px;line-height:40px;text-align:center;position:relative}.frm-banner-emoji{font-size:19px}.frm-banner-emoji,.frm-banner-title{margin-right:5px;vertical-align:top}.frm-banner-cta a{text-decoration:underline !important}#frm_banner .frm-banner-cta a.frm_inbox_dismiss{display:none}.frm-banner-dismiss{cursor:pointer;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.frm-banner-dismiss .frmsvg{vertical-align:top}.frm-ready-made-solution:not(.frm-search-result){display:none !important}#frm_leave_email_wrapper .frmsvg{top:0}#frm-add-my-email-address{margin-top:30px}.frm-ready-made-solution h3~a{color:var(--primary-500)}.frm-ready-made-solution img{max-width:100%;display:block;box-shadow:var(--box-shadow-lg)}.frm_single_on_submit_settings .frm_form_field{margin:22px 0}.frm_on_submit_type_setting{padding:8px 0}.frm_on_submit_type label{display:flex;border:1px solid var(--grey-border);border-radius:var(--small-radius);gap:16px;padding:16px;align-items:center;justify-content:center}.frm_on_submit_type input{opacity:0 !important;position:absolute;z-index:-1}.frm_on_submit_type input[type=radio]:checked+label{border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-color)}#form_settings_page .frm_on_submit_type label:hover,.frm_on_submit_type input[type=radio]:checked+label svg{color:var(--primary-color)}.frm_pro_tip,.frm-cta{justify-content:space-between;align-items:center;gap:var(--gap-2xl);padding:var(--gap-xs) var(--gap-sm);border-radius:var(--small-radius);background:var(--primary-25)}.frm-cta.frm-cta-border{border:1px solid var(--primary-200)}.frm-cta.frm-cta-border .frm-cta-footer{background-color:#fff;padding:12px var(--gap-sm);border-top:1px solid var(--primary-200);border-bottom-left-radius:var(--small-radius);border-bottom-right-radius:var(--small-radius);margin-top:12px;margin-bottom:calc(-1*var(--gap-sm));margin-left:calc(-1*var(--gap-sm));margin-right:calc(-1*var(--gap-sm))}.frm-cta h4{font-weight:600;margin-top:0;margin-bottom:var(--gap-2xs)}.frm-cta-green{background-color:var(--success-25)}.frm-cta-green .frm-banner-title{gap:calc(var(--gap-2xs) + 1px);color:var(--grey-700)}.frm-cta-green.frm-cta-border{border-color:var(--success-100)}.frm-cta-green.frm-cta-border .frm-cta-footer{border-color:var(--success-100)}.frm-cta-red{background-color:var(--error-25)}.frm-cta-red.frm-cta-border{border-color:var(--error-100)}.frm-cta-icon{padding:3px 15px 3px 0;border-right:1px solid currentColor}#frm-upgrade-banner{gap:0}#frm-upgrade-banner .frm-cta-icon+.frm-cta-content{margin-right:auto;padding-left:15px}#frm-upgrade-banner.frm-gradient h4,#frm-upgrade-banner.frm-gradient p{color:currentColor}#frm-upgrade-banner.frm-gradient h4{font-size:16px;font-weight:600}#frm-upgrade-banner.frm-gradient p{font-size:14px}.frm-right-panel .inside .frm_pro_tip,.frm_pro_tip{color:var(--grey-700);background:#ffe7de;margin:0 auto;display:flex;gap:var(--gap-xs)}.frm_field_list .frm_pro_tip{margin:10px 15px;position:relative;width:calc(100% - 30px);box-sizing:border-box;font-size:14px}.frm_pro_tip .frmsvg,.frm_pro_tip i{color:var(--orange)}.frm-tip-info{flex:1;text-align:left}.frm-tip-cta{color:var(--orange)}.frm-gradient .frm-tip-cta,.frm-light-tip .frm-gradient .frm-tip-cta{color:currentColor;font-weight:700}.frm-tip-badge{font-size:9px;font-weight:700;text-transform:uppercase;color:#1e63d5;background-color:#fff;line-height:1;border-radius:4px;padding:3px 4px}.frm-light-tip .frm_pro_tip{background:var(--primary-25)}.frm-light-tip .frm_pro_tip .frmsvg,.frm-light-tip .frm_pro_tip i,.frm-light-tip .frm-tip-cta{color:var(--primary-500)}.nav-tab-wrapper .frm_pro_tip{float:right}#frm-form-templates-modal textarea{height:108px}#frm-form-templates-modal .frm-fields button.btn{border-color:var(--grey-300);color:var(--grey-900);cursor:pointer}#frm-form-templates-modal .frm-fields button.btn .frmsvg{color:var(--grey-400);width:14px;height:14px}#frm-form-templates-modal .frm-form-templates-modal-fieldset{position:relative}#frm-form-templates-modal .frm-form-templates-modal-fieldset .frm-with-left-icon .frmsvg{padding:0;top:0;left:13px}#frm-form-templates-modal .postbox{display:block !important}#frm_empty_inbox #frm-leave-email-modal{margin-top:var(--gap-2xl)}#frm-name-your-form-modal .frm_modal_top{padding-top:var(--gap-sm)}#frm-field-group-message{position:absolute;bottom:32px;right:calc(50% - var(--biggest-sidebar));padding:var(--gap-xs) var(--gap-sm);border-radius:100px;background-color:var(--primary-25)}#frm-field-group-message .frm-field-group-message-text{gap:10px;color:var(--grey-800)}#frm-field-group-message-dismiss{margin-left:var(--gap-xs)}#frm-field-group-message-dismiss .frmsvg{color:var(--grey-800);width:15px;height:15px;cursor:pointer;transition:color 300ms ease-in-out}#frm-field-group-message-dismiss .frmsvg:hover{color:var(--grey-500)}.frm-card-item{display:flex;border:1px solid var(--grey-200);border-radius:var(--small-radius);padding:var(--gap-sm);box-shadow:var(--box-shadow-xs);background:#fff}.frm-card-item:not(.frm-counter-card){gap:10px}.frm-compact-card-item{padding:var(--gap-sm) 35px 10px 35px}.frm-card-bottom{background-color:var(--grey-50);margin-left:calc(var(--gap-sm)*-1);margin-bottom:calc(var(--gap-sm)*-1);margin-right:calc(var(--gap-sm)*-1);padding:var(--gap-sm);border-radius:0 0 var(--small-radius) var(--small-radius)}#welcome-panel:has(#frm_form_pf_importer){background-color:#fff;margin:var(--gap-sm) var(--gap-md) var(--gap-md);line-height:2}#welcome-panel:has(#frm_form_pf_importer) .welcome-panel-content{text-align:start !important;min-height:unset;display:block}#frm_form_pf_importer div{margin:10px 0 !important}#frm_form_pf_importer button{border:1px solid var(--primary-500);padding:7px 16px;min-height:28px;line-height:var(--leading);margin-bottom:0;background:var(--primary-500);color:#fff !important}#frm_form_pf_importer button:hover{background:#135e96;border-color:#135e96}.frm-option-box{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:500;background-color:#fff;padding:12px var(--gap-sm);border:1px solid var(--grey-200);border-radius:var(--small-radius);margin-bottom:var(--gap-xs);transition:background-color 100ms ease-out;cursor:pointer}.frm-option-box:hover{background-color:var(--grey-25)}.frm-option-box.frm-checked{background-color:var(--primary-25);border-color:var(--primary-200)}.frm-option-box.frm-disabled{cursor:default}.frm-option-box input[type=checkbox]{margin:0}.frm-option-box.frm-disabled input[type=checkbox]{opacity:.5}.frm-option-box .frm_help .frmsvg{width:12px;height:12px}.frm-validation-error:not(.frm_hidden){display:flex}.frm-validation-error{gap:calc(var(--gap-xs) + var(--gap-2xs))}.frm-validation-error span{color:var(--error-500)}.frm-validation-error span[frm-error]{display:none}.frm-validation-error[frm-error=empty] span[frm-error=empty],.frm-validation-error[frm-error=invalid] span[frm-error=invalid],.frm-validation-error[frm-error=custom] span[frm-error=custom]{display:inline-block}.frm-box{padding:var(--gap-sm);border:1px solid var(--grey-200);border-radius:var(--small-radius)}.frm-link-with-external-icon{display:flex;align-items:center;gap:var(--gap-2xs);font-size:var(--text-xs)}.frm-link-with-external-icon .frmsvg{width:16px;height:16px;transform:rotate(45deg)}#wpbody-content .frm-page-skeleton ul,#wpbody-content .frm-page-skeleton li{margin:0}#wpbody-content .frm-page-skeleton .frm-right-panel{padding:2px;overflow-y:initial}#wpbody-content .frm-page-skeleton .frm-scrollbar-wrapper{padding:var(--gap-md) var(--gap-sm)}#wpbody-content .frm-page-skeleton .frm-search{float:none;padding:0 var(--gap-2xs)}#wpbody-content .frm-page-skeleton .frm-search>svg{left:var(--gap-2xs)}#wpbody-content .frm-page-skeleton .frm-search>input{width:100%}.frm-page-skeleton-cat{cursor:pointer;padding:var(--gap-xs);border-radius:var(--small-radius);background-color:rgba(0,0,0,0);transition:background-color 250ms ease-out}.frm-page-skeleton-cat:hover{background-color:var(--grey-100)}.frm-page-skeleton-cat>*{z-index:2}.frm-page-skeleton-cat-text{color:var(--grey-900);text-transform:capitalize}.frm-page-skeleton-cat-count{color:var(--grey-400)}.frm-current .frm-page-skeleton-cat-text,.frm-current .frm-page-skeleton-cat-count{color:var(--primary-500)}.frm-list-grid-layout{display:grid;grid-template-columns:repeat(auto-fill, minmax(303px, 1fr));grid-auto-rows:max-content;gap:var(--gap-sm)}.frm-list-grid-layout>*{grid-column:span 1}#frm-page-skeleton-empty-state{height:100%;margin-top:calc(-1*var(--gap-md))}#frm-page-skeleton-empty-state .frm-page-skeleton-text{max-width:420px}.frm-page-skeleton-divider{border-top:1px solid var(--grey-200);margin:0}.field_type_list .frm_tsubmit{display:none !important}#frm_style_sidebar .accordion-section-title::after,#frm_view_editor_left .accordion-section-title::after{content:""}a[href="#square_settings"] svg.frmsvg{width:23px !important;height:22px !important}#frm_square_test_setup_modal a:focus{box-shadow:none !important}@media only screen and (max-width: 900px){#square_settings .frm_grid_container:has(.frm-card-item){grid-template-columns:repeat(1, 1fr)}#square_settings .frm-card-item+.frm-card-item{margin-top:var(--gap-sm)}}.frm-coupons-upsell-wrapper{display:flex;flex-direction:column;align-items:center}.frm-coupons-upsell-wrapper p{margin-top:var(--gap-xs);max-width:364px;text-align:center}.frm-coupons-upsell-wrapper img{max-width:100%;max-height:300px}.frm-coupons-upsell-wrapper h2{margin-bottom:0}.frm-coupons-upsell{background-color:#f5f5f7;border-radius:16px;border:6px solid #fff;box-shadow:0 .471px 1.412px 0 rgba(16,24,40,.1),0 .471px .941px 0 rgba(16,24,40,.06);text-align:center;width:100%;box-sizing:border-box}.frm-main-coupons-upsell{margin-top:var(--gap-lg)}.frm-main-coupons-upsell img{vertical-align:bottom}.frm-secondary-coupons-upsells{margin-top:var(--gap-md);width:100%}#frm_sale_banner{display:flex;height:90px;flex-direction:row;align-items:center;gap:var(--gap-sm);cursor:pointer;position:relative}#frm_sale_banner>div:first-child{align-self:flex-end;width:150px;height:100%;display:flex;justify-content:center}#frm_sale_banner>div:first-child img{align-self:center}#frm_sale_banner>div:nth-child(3){margin-left:auto;margin-right:50px}#frm_sale_banner>div:nth-child(2)>div:last-child{opacity:.8}#frm_sale_banner a:not(.dismiss){text-shadow:none;border-radius:30px;border:1px rgba(0,0,0,0);font-size:var(--text-sm);padding:7px 16px;height:auto;min-height:28px;outline:none;line-height:var(--leading);box-sizing:border-box;margin-bottom:0;display:inline-block;font-weight:700;background-color:#fff;color:#000}#frm_sale_banner .dismiss{position:absolute;color:#fff;opacity:.6;right:15px;top:10px}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: #fff"]{background-color:#f0f0f0 !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(241, 90, 36, 1)"]{background-color:#e6470f !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(239, 58, 78, 1)"]{background-color:#ed1d34 !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(33, 2, 14, 1)"]{background-color:#3e041a !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(72, 51, 64, 1)"]{background-color:#362630 !important}.frm-get-free-templates-banner{flex-grow:1}.frm-get-free-templates-banner .frm-banner-image-wrapper{display:flex;justify-content:center;align-items:flex-end;background-color:var(--primary-25);padding:19px 14px 0;border-radius:var(--small-radius)}.frm-get-free-templates-banner[data-direction=vertical]{flex-direction:column;align-items:stretch;gap:12px}.frm-get-free-templates-banner[data-direction=vertical] .frm-banner-content{align-items:center;text-align:center}.frm-lookup-box-label{display:none}.frm-inline-modal[id^=frm-lookup-box]{background-color:rgba(0,0,0,0);border:0;box-shadow:none}.frm-inline-modal[id^=frm-lookup-box] .frm-nav-tabs,.frm-inline-modal[id^=frm-lookup-box] .dismiss{display:none}.frm_single_option a.frm_remove_tag svg,.frm_single_option a.frm_add_opt svg{width:15px;height:15px}#frm_builder_page #frm-options-panel .frm-single-settings.frm-type-ranking .frm_image_styling_frame{margin-left:12px} + */ +.tooltip { + /* Copied from Bootstrap */ + position: absolute; + display: block; + margin: 0; + font-style: normal; + font-weight: 400; + line-height: 1.5; + text-align: left; + text-align: start; + text-decoration: none; + text-shadow: none; + text-transform: none; + letter-spacing: normal; + word-break: normal; + word-spacing: normal; + white-space: normal; + line-break: auto; + font-size: 0.875rem; + word-wrap: break-word; + opacity: 0; + /* Custom rules */ + z-index: 9999999; + pointer-events: none; +} + +.tooltip.show { + opacity: 0.9; +} + +.tooltip .arrow { + position: absolute; + display: block; + width: 0.8rem; + height: 0.4rem; + margin-left: 0 !important; +} + +.tooltip .arrow::before { + position: absolute; + content: ""; + border-color: transparent; + border-style: solid; +} + +.bs-tooltip-top, +.bs-tooltip-auto[x-placement^=top] { + padding: 0.4rem 0; +} + +.bs-tooltip-top .arrow, +.bs-tooltip-auto[x-placement^=top] .arrow { + bottom: 0; +} + +.bs-tooltip-top .arrow::before, +.bs-tooltip-auto[x-placement^=top] .arrow::before { + top: 0; + border-width: 0.4rem 0.4rem 0; + border-top-color: #000; +} + +.bs-tooltip-right, +.bs-tooltip-auto[x-placement^=right] { + padding: 0 0.4rem; +} + +.bs-tooltip-right .arrow, +.bs-tooltip-auto[x-placement^=right] .arrow { + left: 0; + width: 0.4rem; + height: 0.8rem; +} + +.bs-tooltip-right .arrow::before, +.bs-tooltip-auto[x-placement^=right] .arrow::before { + right: 0; + border-width: 0.4rem 0.4rem 0.4rem 0; + border-right-color: #000; +} + +.bs-tooltip-bottom, +.bs-tooltip-auto[x-placement^=bottom] { + padding: 0.4rem 0; +} + +.bs-tooltip-bottom .arrow, +.bs-tooltip-auto[x-placement^=bottom] .arrow { + top: 0; +} + +.bs-tooltip-bottom .arrow::before, +.bs-tooltip-auto[x-placement^=bottom] .arrow::before { + bottom: 0; + border-width: 0 0.4rem 0.4rem; + border-bottom-color: #000; +} + +.bs-tooltip-left, +.bs-tooltip-auto[x-placement^=left] { + padding: 0 0.4rem; +} + +.bs-tooltip-left .arrow, +.bs-tooltip-auto[x-placement^=left] .arrow { + right: 0; + width: 0.4rem; + height: 0.8rem; +} + +.bs-tooltip-left .arrow::before, +.bs-tooltip-auto[x-placement^=left] .arrow::before { + left: 0; + border-width: 0.4rem 0 0.4rem 0.4rem; + border-left-color: #000; +} + +.tooltip-inner { + max-width: 200px; + padding: 0.25rem 0.5rem; + color: #fff; + text-align: center; + background-color: #000; + border-radius: 0.25rem; +} + +.frm-dropdown-menu.show { + display: block; +} + +.frm-single-settings .frm-dropdown-menu.show { + background: #fff; +} + +/* End Bootstrap */ +.preview.dropdown .dropdown-menu { + min-width: 205px; +} + +.frm_clear { + clear: both; +} + +.frm_clearfix::after { + content: "."; + display: block; + clear: both; + visibility: hidden; + line-height: 0; + height: 0; +} + +.frm_clearfix { + display: block; +} + +.frm_admin_progress { + overflow: hidden; + height: 20px; + margin-bottom: 20px; + background-color: #f5f5f5; + border-radius: 4px; + box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1); +} + +.frm_admin_progress_bar { + float: left; + width: 0; + height: 100%; + font-size: 12px; + line-height: 20px; + color: #fff; + text-align: center; + box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15); + transition: width 0.6s ease; + background-color: #04a4cc; +} + +.tooltip.frm_tooltip { + position: fixed; + top: auto !important; + bottom: 0 !important; + left: 0 !important; + max-width: none; + width: 100% !important; + z-index: 99999; +} + +.tooltip.frm_tooltip.bottom { + padding: 0; +} + +.frm_tooltip .tooltip-inner { + max-width: none; + min-height: 40px !important; + text-align: left; + box-shadow: 5px 5px 25px rgba(0, 0, 0, 0.5); + padding: 10px 40px; + border-top-color: #ccc; + background: var(--sidebar-color); + color: var(--grey-700); + border-radius: 0; + opacity: 1; + font-size: var(--text-sm); +} + +#frm_custom_css_box { + width: 100%; +} + +/** + * Component: Admin Inputs + */ +.frmdates_add_blackout_date_link, +.frmdates_add_exception_link, +.frm_form_field.frm_scroll_box .frm_opt_container, +.frm-white-body .wrap input[type=text], +.frm-white-body .wrap input[type=search], +.frm-white-body .wrap input[type=number], +.frm-white-body .wrap select, +#frm-form-templates-modal select, +.frm-white-body .wrap textarea, +button.frm_choose_image_box, +#titlediv input[type=text], +.frm-fields button.btn, +.frm_wrap textarea, +.frm_wrap input[type=tel], +.frm_wrap input[type=text], +.frm_wrap input[type=email] .frm_wrap input[type=search], +.frm_wrap input[type=number], +.frm_wrap input[type=date], +.frm_wrap select, +.wp-admin .frm_wrap select, +.field-group textarea, +.field-group input[type=text], +.field-group select, +.frm-fields .frm-input-field { + outline: 0; + box-shadow: var(--box-shadow-xs); + border-radius: var(--small-radius); + padding: 5px 14px; + border-color: var(--grey-300); + color: var(--grey-800); + font-size: var(--text-md); + margin: 0; + background-color: #fff; + line-height: var(--leading); +} + +.frm_input_with_suffix { + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + display: inline-block; + padding-right: 14px; +} + +.frm_input_with_suffix input { + border: 0 !important; + padding-right: 5px !important; +} + +.frm_wrap ::-webkit-datetime-edit { + line-height: var(--leading); +} + +.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus, +.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus, +.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus, +.frm_wrap input:focus, +.frm_wrap select:focus, +.wp-core-ui .frm_wrap select:focus, +#frm-form-templates-modal select:focus, +.frm-btn-group .multiselect.dropdown-toggle:focus, +.frm_wrap textarea:focus { + border-color: var(--primary-500) !important; + box-shadow: none !important; +} + +/* +Pages like Entries and Styles need the border-color and box-shadow properties without the !important flag. +To achieve this, we exclude them above and duplicate these rules specifically for those pages without using !important. +*/ +.wp-admin .frm_fields_container textarea:focus, +.wp-admin .frm_fields_container input:focus, +.wp-admin .frm_fields_container select:focus { + border-color: var(--primary-500); + box-shadow: none; +} + +#postbox-container-2 textarea, +.frm_wrap textarea, +.field-group textarea { + line-height: 2; +} + +.frm_wrap input[type=number] { + height: auto; +} + +.frm_wrap select { + padding: 2px; +} + +.wp-admin .frm_wrap select, +#frm-form-templates-modal select { + max-width: 100%; +} + +.frm_form_field.frm_scroll_box .frm_opt_container { + padding: 10px 12px; +} + +.frm_wrap input[disabled], +.frm_wrap select[disabled], +.frm_wrap textarea[disabled], +.frm_wrap input[readonly], +.frm_wrap select[readonly], +.frm_wrap textarea[readonly], +.frm_wrap input::placeholder { + color: var(--grey-500); +} + +textarea[id^=frm_calc_]::placeholder { + font-size: var(--text-sm); + line-height: var(--leading); + font-style: italic; + color: var(--grey-400); + padding-top: 5px; +} + +.frm_wrap .frm-button-primary.frm-disabled { + opacity: 0.5; + cursor: default; +} + +#postcustomstuff table td > div { + /* To override some inline css in add-on */ + padding-top: 0 !important; +} + +.wp-admin .frm_wrap .form-table select { + vertical-align: top; +} + +.frm_wrap .frm_form_builder select { + line-height: var(--leading); + height: var(--text-md); + width: 100%; +} + +#postbox-container-2 select, +.wp-admin .frm_wrap select, +.frm_wrap .frm_form_builder select, +#frm-form-templates-modal select { + height: auto; +} + +.frm-white-body .tablenav select, +.frm-white-body .tablenav input[type=text], +.wp-admin .frm_wrap .tablenav select, +.frm_wrap .tablenav input[type=date], +.frm_wrap .tablenav input[type=text] { + padding-top: 0; + padding-bottom: 0; + line-height: 1; +} + +.frm_wrap .tablenav ::-webkit-datetime-edit { + line-height: 1; +} + +.frm-fields button.btn, +.frm-fields textarea, +.frm-fields input[type=text], +.frm-fields select, +.field-group textarea, +.field-group input[type=text], +.field-group select, +.accordion-container input.hex, +.frm-fields .frm-input-field { + width: 100%; + outline: 0; +} + +.frm-fields button.btn { + height: var(--h-md); + text-align: inherit; +} + +.global-font .field-group input[type=text] { + width: auto; +} + +/** + * Component: Button Grey + */ +.wp-core-ui .frm_grey.frm-button-primary.disabled, +.wp-core-ui .frm_grey.frm-button-primary, +#frm-welcome .frm_grey { + opacity: 0.5; + background: #f6f6f6 !important; + border-color: #ddd !important; + color: #9fa5aa !important; +} + +/** + * Component: Scrollbars + */ +.windows::-webkit-scrollbar, +.windows ::-webkit-scrollbar { + width: 7px; + background: transparent; +} +.windows::-webkit-scrollbar-thumb, +.windows ::-webkit-scrollbar-thumb { + background: var(--grey-300); + -webkit-border-radius: var(--border-radius); + -webkit-box-shadow: none; +} +.windows::-webkit-scrollbar-corner, +.windows ::-webkit-scrollbar-corner { + background: transparent; +} + +.frm-scrollbar-wrapper, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list, +#frm_builder_page #frm_adv_info .frm_code_list, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div, +.frm-single-settings .frm_field_opts_list { + overflow-x: hidden; + overflow-y: auto !important; /* Enable scrolling */ + -ms-overflow-style: none; /* For IE and Edge */ + scrollbar-color: transparent transparent; /* Firefox Scrollbar - transparent by default and show on hover */ + scrollbar-width: thin; +} +.frm-scrollbar-wrapper:hover, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover, +#frm_builder_page #frm_adv_info .frm_code_list:hover, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div:hover, +.frm-single-settings .frm_field_opts_list:hover { + scrollbar-color: var(--grey-300) transparent; /* Firefox Scrollbar - Show on hover with transparent background */ +} +.frm-scrollbar-wrapper:hover::-webkit-scrollbar-thumb, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover::-webkit-scrollbar-thumb, +#frm_builder_page #frm_adv_info .frm_code_list:hover::-webkit-scrollbar-thumb, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div:hover::-webkit-scrollbar-thumb, +.frm-single-settings .frm_field_opts_list:hover::-webkit-scrollbar-thumb { + background: var(--grey-300); /* Show scrollbar on hover */ +} +.frm-scrollbar-wrapper::-webkit-scrollbar, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar, +#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar, +.frm-single-settings .frm_field_opts_list::-webkit-scrollbar { + width: 3px; +} +.frm-scrollbar-wrapper::-webkit-scrollbar-track, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-track, +#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-track, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar-track, +.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-track { + background: transparent; /* Transparent background */ + border-radius: 100vw; /* Consistent radius with thumb */ +} +.frm-scrollbar-wrapper::-webkit-scrollbar-thumb, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb, +#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar-thumb, +.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb { + background: transparent; + border-radius: 100vw; +} +.frm-scrollbar-wrapper::-webkit-scrollbar-thumb:hover, +.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb:hover, +#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb:hover, +#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar-thumb:hover, +.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb:hover { + background: var(--grey-300); /* Show scrollbar on hover */ +} + +/** + * Component: RTL + */ +.rtl h3 { + font-weight: inherit !important; +} + +.rtl.js .accordion-section-title::after { + left: 10px; + right: auto; +} + +.rtl #frm_top_bar #frm_bs_dropdown { + padding-left: 15px; +} + +.rtl .frm-full-close, +.rtl .frm_wrap .columns-2 .frm-right-panel + div, +.rtl .frm-right-panel { + border-left-width: 0; + border-right: 1px solid var(--grey-300); +} + +.rtl .frm-full-close { + padding-left: 0; + padding-right: var(--gap-md); +} + +.rtl .frm-text-right { + text-align: left; +} + +.rtl .frm_wrap #frm_adv_info ul.category-tabs li:first-child { + border-left-width: 1px; +} + +.rtl .frm-dropdown-menu { + text-align: right; +} + +.rtl #frm-insert-fields-box, +.rtl #frm-conditionals { + padding-right: 0.9em; +} + +.rtl #html_settings .frm_field_html_box { + margin-right: 0; +} + +.rtl .frm_list_entry_page h2 { + float: right; +} + +.rtl .frm_scale { + float: right; + margin-left: 10px; + margin-right: 0; +} + +.rtl .frm-page-break .frm-collapse-page.button { + margin-left: 0; + margin-right: 46%; +} + +.rtl .frm-field-action-icons { + right: unset; + left: 2px; +} + +.rtl .frm_has_shortcodes > i { + right: auto; + left: 5px; +} + +.rtl p.frm_reply_to_container, +.rtl p.frm_bcc_cc_container { + float: left; +} + +.rtl .frm-with-right-icon:not(.frm-token-container) .frmsvg { + right: auto; + left: 0; +} + +.rtl .frm-inline-modal > a.dismiss { + left: 13px; + right: auto; +} + +.rtl.wp-admin .frm_wrap select { + padding-left: var(--gap-lg) !important; + padding-right: 5px !important; + background-position: left 11px top 55%; +} + +.rtl .frm_code_list.frm-full-hover a span { + margin-left: var(--gap-xs); +} + +.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child { + margin-left: unset; + margin-right: var(--gap-xs); +} +.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child { + margin-right: unset; + margin-left: var(--gap-xs); +} +.rtl .frm-style-tabs-wrapper .frm-tabs-active-underline { + left: unset !important; + right: 0; +} + +.rtl .frm-unit-input .frm-input-group-suffix { + right: unset; + left: 1px; + padding-right: unset; + padding-left: var(--gap-xs); +} +.rtl .frm-unit-input .frm-input-group-suffix select { + text-align: left; + background-position: left 0 top 50%; + padding-left: 21px !important; +} + +/** + * Component: Clearfix + */ +span.clear { + display: block; +} + +.clearfix::after { + content: "."; + display: block; + height: 0; + clear: both; + visibility: hidden; +} + +.clearfix { + display: inline-block; +} + +/*Override styling from other plugins*/ +.frm_form_fields .clear { + height: auto; +} + +/* Hides from IE-mac \*/ +* html .clearfix { + height: 1%; +} + +.clearfix { + display: block; +} + +#frm_small_device_message_container { + display: none; +} + +/* End hide from IE-mac */ +/** + * Responsive Styles + * + * Media queries for desktop, tablet, and mobile devices + */ +@media only screen and (max-width: 1200px) { + .frm-addons { + grid-template-columns: 1fr 1fr; + } + #frm_top_bar h1 { + min-width: 0; /* Reset the min-width to prevent menu items from stacking vertically */ + } +} +@media only screen and (max-width: 1050px) { + .frm-white-body, +.frm_wrap { + --biggest-sidebar: 390px; + } + #form_settings_page .columns-2 { + margin: 0; + } + .frm_actions_list { + margin-left: 0; + } + #frm_bs_dropdown .frm_bstooltip { + /* There isn't enough room for the title on a screen this size so just hide it. */ + display: none !important; + } +} +@media only screen and (max-width: 960px) { + .frm-white-body, +.frm_wrap { + --gap-sm: 8px; + --gap-md: 16px; + --gap-2xl: 24px; + } + /* Revert settings panel gap variables to default */ + .frm-settings-panel { + --gap-sm: 16px; + --gap-md: 24px; + --gap-2xl: 32px; + } + .auto-fold #adminmenuwrap { + width: 36px; + } + .frm_wrap #postbox-container-1 #frm_adv_info { + min-width: 220px; + } + p.howto { + display: inline-block; + } + /* Fix: Issue where the admin page content had extra white space to the left on small screens */ + .auto-fold.frm-admin-page-styles:not(.frm-full-screen) .frm_page_container, +.auto-fold:not(.frm-full-screen) .frm_wrap .frm_page_container { + left: 36px; + } +} +@media only screen and (max-width: 850px) { + .frm-white-body, +.frm_wrap { + --biggest-sidebar: 350px; + --big-sidebar: 350px; + } + .frm_col_one { + clear: none; + } + .frm-fields p > .frm_inline_label, +.frm_inline_label { + display: block; + margin: 5px 0; + } + #frm_top_bar h1 { + width: auto; + max-width: 200px; + } + #frm-publishing { + width: auto; + } + #frm_form_editor_container, +.frm-entry-container { + margin: 0 20px; + } + .frm_wrap .frm-search { + float: none !important; + width: auto; + clear: both; + } + .post-type-frm_display #frm_adv_info { + top: auto !important; + position: static; + width: auto; + } + .frm_wrap .frm-right-panel #frm_adv_info, +.frm_wrap #postbox-container-1 #frm_adv_info { + min-width: 275px; + } + .frm_wrap #frm_adv_info ul.category-tabs li, +.frm_wrap #frm_adv_info ul.category-tabs li.tabs { + border: none; + } + .frm_wrap #frm_adv_info ul.category-tabs li:first-child { + margin-left: 12px; + } + .frm_wrap #frm_adv_info ul.category-tabs li.tabs { + border-bottom: 2px solid #5b9dd9; + padding-bottom: 8px; + } + .post-type-frm_display #poststuff { + padding: 10px 25px; + } + .post-type-frm_display #side-sortables .postbox { + margin-bottom: 20px; + border-radius: var(--small-radius); + border-top-width: 1px; + } + #frm_top_bar .frm_form_nav { + box-shadow: 0 -0.47px 10px 0 rgba(16, 24, 40, 0.0588235294); + } + #frm_top_bar ul.frm_form_nav { + padding: 1em 0; + position: fixed; + bottom: 0; + width: 100%; + background: white; + z-index: 99; + transform: translate(-50%, 0); + left: 50%; + } + .frm_page_container > .columns-2, +#frm_styler_wrapper { + padding-bottom: 64px; + } + #frm_style_preview .frm_floating_style_button:not(.frm_hidden) { + position: static; + display: inline-block; + } + .frm_wrap .columns-2 .frm-right-panel { + padding-bottom: 0; + } + #frm-publishing { + margin-left: auto; + } + #frm_top_bar > .frm-full-close:last-child { + margin-left: 0; + } + #frm_bs_dropdown { + display: block; + } + #frm_bs_dropdown .frm_bstooltip { + display: block !important; + } +} +@media only screen and (max-width: 782px) { + .frm-white-body, +.frm_wrap { + --small-sidebar: 20%; + --medium-sidebar: 35%; + } + #form_settings_page .advanced_settings .form-table td, +.form-table th { + display: table-cell; + width: auto !important; + } + .frm-white-body #publishing-action, +.frm_wrap #publishing-action { + line-height: normal; + } + .frm-white-body #screen-meta-links { + display: none; + } + .frm_wrap .misc-pub-section { + padding: 6px 0; + } + .frm_wrap .misc-pub-section > a { + float: none; + white-space: nowrap; + } + .frm-form-setting-tabs a { + position: relative; + padding: 10px 5px 10px 40px; + } + .frm-form-setting-tabs a .frmsvg, +.frm-form-setting-tabs a i { + position: absolute; + left: 13px; + top: calc(50% - 10px); + margin: 0; + } + #frm-insert-fields .button, +#frm-insert-fields .button a, +.frmbutton.ui-sortable-helper a { + line-height: 26px; + max-height: 28px; + } + a.frm_add_logic_link { + margin-left: 0; + margin-right: 0; + width: 100%; + box-sizing: border-box; + } + a.frm_add_logic_link:not([id^=logic_]) .frmsvg, +a.frm_add_logic_link i { + display: none; + } + #new_fields .frm_single_option select, +#new_fields .frm_single_option input[type=text] { + width: calc(100% - 83px); + } + .frm_single_entry_page .frm_form_fields input[type=text], +.frm_single_entry_page .frm_form_fields select, +.frm_single_entry_page .frm_form_fields textarea { + width: 100%; + } + .with_frm_style .frm_radio input[type=radio], +.with_frm_style .frm_checkbox input[type=checkbox] { + width: 25px !important; + } + .frm_single_entry_page .with_frm_style .frm_radio input[type=radio], +.frm_single_entry_page .with_frm_style .frm_checkbox input[type=checkbox] { + width: 18px !important; + } + .wp-list-table.toplevel_page_formidable .column-entries, +.wp-list-table.toplevel_page_formidable .column-form_key, +.wp-list-table.toplevel_page_formidable .column-shortcode, +.wp-list-table.toplevel_page_formidable .column-created_at { + display: none !important; + } + .wp-list-table.toplevel_page_formidable td.column-entries, +.wp-list-table.toplevel_page_formidable td.column-form_key, +.wp-list-table.toplevel_page_formidable td.column-shortcode, +.wp-list-table.toplevel_page_formidable td.column-created_at { + padding: 3px 8px 3px 35%; + text-align: left; + } + #form_entries_page .wp-list-table th.frm_hidden, +#form_entries_page .wp-list-table td.frm_hidden { + display: none !important; + } + .frm-white-body.auto-fold #wpcontent { + padding-left: 0; + } + .frm_right_addon .frm_remove_field { + bottom: 11px; + } + .frm-addons { + grid-template-columns: 1fr; + } + .frm-admin-page-styles .frm_page_container, +.frm_wrap .frm_page_container { + left: 0 !important; + } + .frm_single_entry_page.frm_wrap .columns-2 { + display: block; + border-bottom: none; + } + .frm_single_entry_page .wrap.frm-with-margin { + margin: 10px 20px; + } + .frm_single_entry_page #post-body-content + .frm-right-panel { + width: auto; + margin: 0 20px; + border: 1px solid var(--sidebar-hover); + border-radius: 6px; + } + #wp-content-media-buttons a.frm_insert_form { + padding: 0 var(--gap-sm); + } + .frm-white-body input[type=checkbox]:checked::before, +.frm_wrap input[type=checkbox]:checked::before { + width: 1.2rem; + height: 1.2rem; + } +} +@media only screen and (max-width: 700px) { + .frm-white-body, +.frm_wrap { + --biggest-sidebar: 50%; + --big-sidebar: 50%; + } +} +@media only screen and (max-width: 600px) { + .frm-white-body, +.frm_wrap { + --small-sidebar: 45px; + } + .frm-form-setting-tabs a { + visibility: collapse; + font-size: 0; + padding: 0 var(--gap-sm); + } + .frm-form-setting-tabs a .frmsvg, +.frm-form-setting-tabs a i { + visibility: visible; + position: initial; + font-size: 18px; + } + #frm_builder_page #frm-insert-fields { + padding: 0; + } + .frm_wrap #frm_adv_info ul.category-tabs li { + display: inline-block; + padding: 0; + margin: 2px 0; + border-bottom: 2px solid transparent; + } + .frm_wrap #frm_adv_info ul.category-tabs li.tabs, +.frm_wrap #frm_adv_info ul.category-tabs li:first-child { + margin-left: 0; + padding: 0; + } + .field_type_list li { + text-align: center; + } + #frm-insert-fields li a { + padding: 5px; + } + #frm_form_editor_container .frm_primary_label { + clear: both; + } + #frm_builder_page .frm_code_list a.button { + padding: 2px; + } + .frm-right-panel h3.accordion-section-title { + padding-right: 10px; + padding-left: 10px; + font-size: 20px; + white-space: nowrap; + overflow: hidden; + } + .frm-right-panel .accordion-section-title::before { + margin-left: 0; + margin-right: 3px; + } + .frm_on_submit_type svg { + display: none; + } +} +@media only screen and (max-width: 475px) { + #frm_bs_dropdown { + float: none; + } + #frm-nav-tabs { + padding: 0; + white-space: nowrap; + } + #frm-nav-tabs a { + margin-right: 0; + } + #frm_small_device_message_container { + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + position: fixed; + top: 0; + width: 100%; + height: 100%; + z-index: 999999; + background: var(--primary-500); + } + #frm_small_device_message { + text-align: center; + display: flex; + flex-direction: column; + align-items: center; + width: 80%; + padding: 1rem; + background: #fff; + border: solid 1px #fff; + border-radius: var(--medium-radius); + } + #frm_small_device_message::before { + content: ""; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-78%, -65%); + width: 900px; + height: 900px; + background-color: #0d7dfc; + border-radius: 50%; + z-index: -1; + opacity: 0.3; + } + #frm_small_device_message > svg { + padding-bottom: 1rem; + } + .toplevel_page_formidable:has(#frm_small_device_message_container) #posts-filter, +.post-type-frm_display:has(#frm_small_device_message_container) #posts-filter { + display: none; + } +} +@media print { + a, +.misc-pub-section a { + color: #000 !important; + } + .add-new-h2, +#frm_top_bar, +.dashicons, +#adminmenuwrap, +#adminmenuback, +#wphead, +#button_bar, +#submitdiv, +.button-secondary, +#screen-metas, +#screen-meta-links, +#footer, +#wpfooter, +.inner-sidebar, +.frm_form_nav, +.frm_flash_graph, +.frm_no_print, +object, +.error { + visibility: hidden; + display: none !important; + } + .widget, +.postbox, +.stuffbox, +.postbox h3 { + border-width: 0 !important; + border-color: #fff; + } + .postbox { + background: #fff !important; + border: none; + position: static; + } + .postbox h3, +.postbox h4 { + background: #fff !important; + } + #wpbody-content { + float: none; + } + #wpcontent, +#post-body-content, +.has-right-sidebar #post-body, +#poststuff .columns-2 { + margin: 0 !important; + } + .frm_wrap #poststuff .columns-2 { + display: block; + } + #post-body-content + .frm-right-panel, +.frm_wrap .columns-2 .frm-right-panel, +.frm-right-panel { + border: none; + width: auto; + display: block; + padding: 20px; + } + .frm_wrap .columns-2, +.frm_wrap .frm_page_container { + height: auto; + display: block; + } + .misc-pub-section > span { + padding: 0; + } + .frm-right-panel .postbox .inside { + padding-left: 12px; + padding-right: 12px; + } + .curtime #timestamp::before { + display: none; + content: none !important; + } + .frm_charts .alignleft { + float: none; + } + .pg_odd, +.pg_even { + page-break-inside: avoid; + max-width: 600px; + } + .form-table td, +.form-table th { + padding: 0; + } + .frm_file_container a { + display: block; + width: 100%; + } +} +/** + * Extended Components + * + * Additional components loaded after the main layout + */ +/** + * Layout: Publishing + */ +.frm-admin-page-styles #frm-publishing #save_menu_header, +.frm-admin-page-styles2 #frm-publishing #save_menu_header { + display: inline-block; +} + +/* Change the order of subfields of the Name field in the backend */ +.edit_form_item .frm_combo_inputs_container[data-name-layout=last_first] .frm_form_subfield-first { + order: 2; +} + +.frm-video-wrapper iframe { + width: 100%; + max-width: 843px; + border-radius: var(--border-radius); +} + +/** + * Field group popup and related functionality + */ +#frm_field_group_popup { + position: absolute; + top: 0; + right: 0; + width: 366px; + max-height: 231px; + border-radius: 8px; + background: #fff; + box-shadow: 0 20px 48px rgba(40, 47, 54, 0.15); + z-index: 3; + box-sizing: border-box; + padding: 24px 0; + text-align: left; +} + +.rtl #frm_field_group_popup { + text-align: right; +} + +.frm-merge-fields-into-row #frm_field_group_popup { + top: unset; + bottom: 50px; + height: 196px; +} + +#frm_field_group_popup > hr { + margin: 12px 0; +} + +#frm_field_group_popup .frm-cancel-custom-field-group-layout, +#frm_field_group_popup .frm-save-custom-field-group-layout { + padding: 4px 18px; +} + +#frm_field_group_popup .frm-cancel-custom-field-group-layout:hover { + border-color: var(--primary-500) !important; + color: var(--primary-500); + background-color: transparent !important; +} + +.frm-merge-fields-into-row #frm_field_group_popup .frm-break-field-group { + display: none; +} + +.frm-merge-fields-into-row > a { + color: rgba(40, 47, 54, 0.85); + position: relative; + top: 2px; +} + +.frm-row-layout-title { + font-weight: 600; + font-size: 11px; + line-height: 15px; + text-transform: uppercase; + color: rgba(40, 47, 54, 0.45); + margin-bottom: 27px; +} + +.frm-row-layout-option { + background: #f6f7fb; + box-sizing: border-box; + border-radius: 2px; + padding: 15px 10px; +} + +#frm_field_group_popup .frm-row-layout-option .frm_grid_container { + grid-gap: 0 5%; + grid-template-columns: repeat(12, auto); +} + +#frm_field_group_popup .frm-row-layout-option { + cursor: pointer; + border: 2px solid transparent; +} + +#frm_field_group_popup .frm-row-layout-option.frm-active-row-layout, +#frm_field_group_popup .frm-row-layout-option:hover { + border-color: var(--primary-500); +} + +.frm-custom-field-group-layout, +.frm-break-field-group { + padding: 4px 24px; + cursor: pointer; + font-size: var(--text-sm); + line-height: 19px; + color: rgb(72, 78, 84); +} + +.frm-custom-field-group-layout:hover, +.frm-break-field-group:hover { + background-color: rgba(245, 245, 245, 0.9607843137); +} + +.frm-custom-field-group-layout svg, +.frm-break-field-group svg { + margin-right: 5px; +} + +/** + * Field multiselect popup + */ +#frm_field_multiselect_popup { + background: white; + height: 48px; + position: fixed; + border-radius: 4px; + box-shadow: 0 8px 24px rgba(40, 47, 54, 0.15); + color: rgba(40, 47, 54, 0.85); + font-size: 13px; + right: 30px; + bottom: 10px; + z-index: 2; +} + +#frm_field_multiselect_popup > div { + display: inline-block; + line-height: 48px; + vertical-align: top; +} + +#frm_field_multiselect_popup.frm-unmergable > .frm-merge-fields-into-row, +#frm_field_multiselect_popup.frm-unmergable > .frm-multiselect-popup-separator { + display: none; +} + +#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator) { + padding: 0 20px; + cursor: pointer; +} + +#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator):hover { + background: rgba(245, 245, 245, 0.9607843137); +} + +.frm-builder-popup-heading { + font-weight: 600; + font-size: 11px; + line-height: 15px; + text-transform: uppercase; + color: rgba(40, 47, 54, 0.45); + margin-bottom: 7px; +} + +.frm-builder-popup-subheading { + font-size: 12px; + line-height: 16px; + color: rgba(40, 47, 54, 0.45); +} + +#frm_field_group_popup input[type=text] { + height: 30px; + border-radius: 3px; + font-size: 14px; + padding: 8px; + color: rgb(84, 95, 110); + border-color: rgba(40, 47, 54, 0.2); +} + +.frm-multiselect-popup-separator { + height: 36px; + width: 1px; + position: relative; + top: 6px; + background: #c4c4c4; +} + +.frm-sortable-helper, +.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider) { + pointer-events: none; +} + +.frm-sortable-helper { + /* Make sure the item being dragged appears above other form builder fields */ + z-index: 99; +} + +/** + * Component: Banner Notification + */ +#frm_banner { + width: 100%; + color: #fff; + background: var(--primary-500); + height: 40px; + line-height: 40px; + text-align: center; + position: relative; +} + +.frm-banner-emoji { + font-size: 19px; +} + +.frm-banner-emoji, +.frm-banner-title { + margin-right: 5px; + vertical-align: top; +} + +.frm-banner-cta a { + text-decoration: underline !important; +} + +#frm_banner .frm-banner-cta a.frm_inbox_dismiss { + display: none; +} + +.frm-banner-dismiss { + cursor: pointer; + position: absolute; + right: 10px; + top: 50%; + transform: translateY(-50%); +} + +.frm-banner-dismiss .frmsvg { + vertical-align: top; +} + +/** + * Ready-made solution styles + */ +.frm-ready-made-solution:not(.frm-search-result) { + display: none !important; +} + +#frm_leave_email_wrapper .frmsvg { + top: 0; +} + +#frm-add-my-email-address { + margin-top: 30px; +} + +.frm-ready-made-solution h3 ~ a { + color: var(--primary-500); +} + +.frm-ready-made-solution img { + max-width: 100%; + display: block; + box-shadow: var(--box-shadow-lg); +} + +/** + * Component: On Submit Action + */ +.frm_single_on_submit_settings .frm_form_field { + margin: 22px 0; +} + +.frm_on_submit_type_setting { + padding: 8px 0; +} + +.frm_on_submit_type label { + display: flex; + border: 1px solid var(--grey-border); + border-radius: var(--small-radius); + gap: 16px; + padding: 16px; + align-items: center; + justify-content: center; +} + +.frm_on_submit_type input { + opacity: 0 !important; + position: absolute; + z-index: -1; +} + +.frm_on_submit_type input[type=radio]:checked + label { + border-color: var(--primary-color); + box-shadow: 0 0 0 1px var(--primary-color); +} + +#form_settings_page .frm_on_submit_type label:hover, +.frm_on_submit_type input[type=radio]:checked + label svg { + color: var(--primary-color); +} + +/** + * Component: Call-to-Action + */ +.frm_pro_tip, +.frm-cta { + justify-content: space-between; + align-items: center; + gap: var(--gap-2xl); + padding: var(--gap-xs) var(--gap-sm); + border-radius: var(--small-radius); + background: var(--primary-25); +} + +.frm-cta.frm-cta-border { + border: 1px solid var(--primary-200); +} + +.frm-cta.frm-cta-border .frm-cta-footer { + background-color: #fff; + padding: 12px var(--gap-sm); + border-top: 1px solid var(--primary-200); + border-bottom-left-radius: var(--small-radius); + border-bottom-right-radius: var(--small-radius); + margin-top: 12px; + margin-bottom: calc(-1 * var(--gap-sm)); + margin-left: calc(-1 * var(--gap-sm)); + margin-right: calc(-1 * var(--gap-sm)); +} + +.frm-cta h4 { + font-weight: 600; + margin-top: 0; + margin-bottom: var(--gap-2xs); +} + +.frm-cta-green { + background-color: var(--success-25); +} + +.frm-cta-green .frm-banner-title { + gap: calc(var(--gap-2xs) + 1px); + color: var(--grey-700); +} + +.frm-cta-green.frm-cta-border { + border-color: var(--success-100); +} + +.frm-cta-green.frm-cta-border .frm-cta-footer { + border-color: var(--success-100); +} + +.frm-cta-red { + background-color: var(--error-25); +} + +.frm-cta-red.frm-cta-border { + border-color: var(--error-100); +} + +.frm-cta-icon { + padding: 3px 15px 3px 0; + border-right: 1px solid currentColor; +} + +#frm-upgrade-banner { + gap: 0; +} + +#frm-upgrade-banner .frm-cta-icon + .frm-cta-content { + margin-right: auto; + padding-left: 15px; +} + +#frm-upgrade-banner.frm-gradient h4, +#frm-upgrade-banner.frm-gradient p { + color: currentColor; +} + +#frm-upgrade-banner.frm-gradient h4 { + font-size: 16px; + font-weight: 600; +} + +#frm-upgrade-banner.frm-gradient p { + font-size: 14px; +} + +.frm-right-panel .inside .frm_pro_tip, +.frm_pro_tip { + color: var(--grey-700); + background: #ffe7de; + margin: 0 auto; + display: flex; + gap: var(--gap-xs); +} + +.frm_field_list .frm_pro_tip { + margin: 10px 15px; + position: relative; + width: calc(100% - 30px); + box-sizing: border-box; + font-size: 14px; +} + +.frm_pro_tip .frmsvg, +.frm_pro_tip i { + color: var(--orange); +} + +.frm-tip-info { + flex: 1; + text-align: left; +} + +.frm-tip-cta { + color: var(--orange); +} + +.frm-gradient .frm-tip-cta, +.frm-light-tip .frm-gradient .frm-tip-cta { + color: currentColor; + font-weight: 700; +} + +.frm-tip-badge { + font-size: 9px; + font-weight: 700; + text-transform: uppercase; + color: #1e63d5; + background-color: #fff; + line-height: 1; + border-radius: 4px; + padding: 3px 4px; +} + +.frm-light-tip .frm_pro_tip { + background: var(--primary-25); +} + +.frm-light-tip .frm_pro_tip .frmsvg, +.frm-light-tip .frm_pro_tip i, +.frm-light-tip .frm-tip-cta { + color: var(--primary-500); +} + +.nav-tab-wrapper .frm_pro_tip { + float: right; +} + +/** + * Component: Form Templates Modal + */ +/* Start confirm and form templates modals */ +#frm-form-templates-modal textarea { + height: 108px; +} + +#frm-form-templates-modal .frm-fields button.btn { + border-color: var(--grey-300); + color: var(--grey-900); + cursor: pointer; +} + +#frm-form-templates-modal .frm-fields button.btn .frmsvg { + color: var(--grey-400); + width: 14px; + height: 14px; +} + +#frm-form-templates-modal .frm-form-templates-modal-fieldset { + position: relative; +} + +#frm-form-templates-modal .frm-form-templates-modal-fieldset .frm-with-left-icon .frmsvg { + padding: 0; + top: 0; + left: 13px; +} + +/* Fixes pro issue #3508, prevent a conflict that hides the postbox in modal */ +#frm-form-templates-modal .postbox { + display: block !important; +} + +/* Leave email modal */ +#frm_empty_inbox #frm-leave-email-modal { + margin-top: var(--gap-2xl); +} + +/* Name your form modal */ +#frm-name-your-form-modal .frm_modal_top { + padding-top: var(--gap-sm); +} + +/* End confirm and form templates modals */ +/** + * Component: Field Group Message + */ +#frm-field-group-message { + position: absolute; + bottom: 32px; + right: calc(50% - var(--biggest-sidebar)); + padding: var(--gap-xs) var(--gap-sm); + border-radius: 100px; + background-color: var(--primary-25); +} + +#frm-field-group-message .frm-field-group-message-text { + gap: 10px; + color: var(--grey-800); +} + +#frm-field-group-message-dismiss { + margin-left: var(--gap-xs); +} + +#frm-field-group-message-dismiss .frmsvg { + color: var(--grey-800); + width: 15px; + height: 15px; + cursor: pointer; + transition: color 300ms ease-in-out; +} + +#frm-field-group-message-dismiss .frmsvg:hover { + color: var(--grey-500); +} + +/** + * Component - Card Item + */ +.frm-card-item { + display: flex; + border: 1px solid var(--grey-200); + border-radius: var(--small-radius); + padding: var(--gap-sm); + box-shadow: var(--box-shadow-xs); + background: #fff; +} + +.frm-card-item:not(.frm-counter-card) { + gap: 10px; +} + +.frm-compact-card-item { + padding: var(--gap-sm) 35px 10px 35px; +} + +.frm-card-bottom { + background-color: var(--grey-50); + margin-left: calc(var(--gap-sm) * -1); + margin-bottom: calc(var(--gap-sm) * -1); + margin-right: calc(var(--gap-sm) * -1); + padding: var(--gap-sm); + border-radius: 0 0 var(--small-radius) var(--small-radius); +} + +/** + * Component: Pirate Forms Importer + */ +#welcome-panel:has(#frm_form_pf_importer) { + background-color: #fff; + margin: var(--gap-sm) var(--gap-md) var(--gap-md); + line-height: 2; +} + +#welcome-panel:has(#frm_form_pf_importer) .welcome-panel-content { + text-align: start !important; + min-height: unset; + display: block; +} + +#frm_form_pf_importer div { + margin: 10px 0 !important; +} + +#frm_form_pf_importer button { + border: 1px solid var(--primary-500); + padding: 7px 16px; + min-height: 28px; + line-height: var(--leading); + margin-bottom: 0; + background: var(--primary-500); + color: #fff !important; +} + +#frm_form_pf_importer button:hover { + background: #135e96; + border-color: #135e96; +} + +/** + * Component: Option Box + */ +.frm-option-box { + display: flex; + justify-content: space-between; + align-items: center; + font-size: 14px; + font-weight: 500; + background-color: #fff; + padding: 12px var(--gap-sm); + border: 1px solid var(--grey-200); + border-radius: var(--small-radius); + margin-bottom: var(--gap-xs); + transition: background-color 100ms ease-out; + cursor: pointer; +} + +.frm-option-box:hover { + background-color: var(--grey-25); +} + +.frm-option-box.frm-checked { + background-color: var(--primary-25); + border-color: var(--primary-200); +} + +.frm-option-box.frm-disabled { + cursor: default; +} + +.frm-option-box input[type=checkbox] { + margin: 0; +} + +.frm-option-box.frm-disabled input[type=checkbox] { + opacity: 0.5; +} + +.frm-option-box .frm_help .frmsvg { + width: 12px; + height: 12px; +} + +/** + * Component: Validation Error + */ +.frm-validation-error:not(.frm_hidden) { + display: flex; +} + +.frm-validation-error { + gap: calc(var(--gap-xs) + var(--gap-2xs)); +} + +.frm-validation-error span { + color: var(--error-500); +} + +.frm-validation-error span[frm-error] { + display: none; +} + +.frm-validation-error[frm-error=empty] span[frm-error=empty], +.frm-validation-error[frm-error=invalid] span[frm-error=invalid], +.frm-validation-error[frm-error=custom] span[frm-error=custom] { + display: inline-block; +} + +/** + * Utility: Box + */ +.frm-box { + padding: var(--gap-sm); + border: 1px solid var(--grey-200); + border-radius: var(--small-radius); +} + +/** + * External Link styles + */ +.frm-link-with-external-icon { + display: flex; + align-items: center; + gap: var(--gap-2xs); + font-size: var(--text-xs); +} + +.frm-link-with-external-icon .frmsvg { + width: 16px; + height: 16px; + transform: rotate(45deg); +} + +/** + * Page Skeleton + * + * Manages the layout and appearance of the page's content area. + */ +/* Core Styles for the Page */ +#wpbody-content .frm-page-skeleton { + /* Sidebar Styles */ + /* Scrollbar */ + /* Search */ +} +#wpbody-content .frm-page-skeleton ul, +#wpbody-content .frm-page-skeleton li { + margin: 0; +} +#wpbody-content .frm-page-skeleton .frm-right-panel { + padding: 2px; + overflow-y: initial; +} +#wpbody-content .frm-page-skeleton .frm-scrollbar-wrapper { + padding: var(--gap-md) var(--gap-sm); +} +#wpbody-content .frm-page-skeleton .frm-search { + float: none; + padding: 0 var(--gap-2xs); +} +#wpbody-content .frm-page-skeleton .frm-search > svg { + left: var(--gap-2xs); +} +#wpbody-content .frm-page-skeleton .frm-search > input { + width: 100%; +} + +/* Categories */ +.frm-page-skeleton-cat { + cursor: pointer; + padding: var(--gap-xs); + border-radius: var(--small-radius); + background-color: transparent; + transition: background-color 250ms ease-out; +} +.frm-page-skeleton-cat:hover { + background-color: var(--grey-100); +} +.frm-page-skeleton-cat > * { + z-index: 2; +} + +.frm-page-skeleton-cat-text { + color: var(--grey-900); + text-transform: capitalize; +} + +.frm-page-skeleton-cat-count { + color: var(--grey-400); +} + +.frm-current .frm-page-skeleton-cat-text, +.frm-current .frm-page-skeleton-cat-count { + color: var(--primary-500); +} + +/* Page Content Styles */ +.frm-list-grid-layout { + display: grid; + grid-template-columns: repeat(auto-fill, minmax(303px, 1fr)); + grid-auto-rows: max-content; + gap: var(--gap-sm); +} +.frm-list-grid-layout > * { + grid-column: span 1; +} + +/* Empty State Styles */ +#frm-page-skeleton-empty-state { + height: 100%; + margin-top: calc(-1 * var(--gap-md)); +} +#frm-page-skeleton-empty-state .frm-page-skeleton-text { + max-width: 420px; +} + +/* Helper Classes */ +.frm-page-skeleton-divider { + border-top: 1px solid var(--grey-200); + margin: 0; +} + +/** + * Submit field styles + */ +.field_type_list .frm_tsubmit { + display: none !important; +} + +/** + * Component: Accordion Title + */ +#frm_style_sidebar .accordion-section-title::after, +#frm_view_editor_left .accordion-section-title::after { + content: ""; +} + +a[href="#square_settings"] svg.frmsvg { + width: 23px !important; + height: 22px !important; +} + +#frm_square_test_setup_modal a:focus { + box-shadow: none !important; +} + +@media only screen and (max-width: 900px) { + #square_settings .frm_grid_container:has(.frm-card-item) { + grid-template-columns: repeat(1, 1fr); + } + #square_settings .frm-card-item + .frm-card-item { + margin-top: var(--gap-sm); + } +} +.frm-coupons-upsell-wrapper { + display: flex; + flex-direction: column; + align-items: center; +} +.frm-coupons-upsell-wrapper p { + margin-top: var(--gap-xs); + max-width: 364px; + text-align: center; +} +.frm-coupons-upsell-wrapper img { + max-width: 100%; + max-height: 300px; +} +.frm-coupons-upsell-wrapper h2 { + margin-bottom: 0; +} + +.frm-coupons-upsell { + background-color: #f5f5f7; + border-radius: 16px; + border: 6px solid #fff; + box-shadow: 0 0.471px 1.412px 0 rgba(16, 24, 40, 0.1), 0 0.471px 0.941px 0 rgba(16, 24, 40, 0.06); + text-align: center; + width: 100%; + box-sizing: border-box; +} + +.frm-main-coupons-upsell { + margin-top: var(--gap-lg); +} +.frm-main-coupons-upsell img { + vertical-align: bottom; +} + +.frm-secondary-coupons-upsells { + margin-top: var(--gap-md); + width: 100%; +} + +#frm_sale_banner { + display: flex; + height: 90px; + flex-direction: row; + align-items: center; + gap: var(--gap-sm); + cursor: pointer; + position: relative; +} +#frm_sale_banner > div:first-child { + align-self: flex-end; + width: 150px; + height: 100%; + display: flex; + justify-content: center; +} +#frm_sale_banner > div:first-child img { + align-self: center; +} +#frm_sale_banner > div:nth-child(3) { + margin-left: auto; + margin-right: 50px; +} +#frm_sale_banner > div:nth-child(2) > div:last-child { + opacity: 0.8; +} +#frm_sale_banner a:not(.dismiss) { + text-shadow: none; + border-radius: 30px; + border: 1px transparent; + font-size: var(--text-sm); + padding: 7px 16px; + height: auto; + min-height: 28px; + outline: none; + line-height: var(--leading); + box-sizing: border-box; + margin-bottom: 0; + display: inline-block; + font-weight: 700; + background-color: #fff; + color: #000; +} +#frm_sale_banner .dismiss { + position: absolute; + color: #fff; + opacity: 0.6; + right: 15px; + top: 10px; +} +#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: #fff"] { + background-color: #f0f0f0 !important; +} +#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(241, 90, 36, 1)"] { + background-color: #e6470f !important; +} +#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(239, 58, 78, 1)"] { + background-color: #ed1d34 !important; +} +#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(33, 2, 14, 1)"] { + background-color: #3e041a !important; +} +#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(72, 51, 64, 1)"] { + background-color: #362630 !important; +} + +.frm-get-free-templates-banner { + flex-grow: 1; +} +.frm-get-free-templates-banner .frm-banner-image-wrapper { + display: flex; + justify-content: center; + align-items: flex-end; + background-color: var(--primary-25); + padding: 19px 14px 0; + border-radius: var(--small-radius); +} +.frm-get-free-templates-banner[data-direction=vertical] { + flex-direction: column; + align-items: stretch; + gap: 12px; +} +.frm-get-free-templates-banner[data-direction=vertical] .frm-banner-content { + align-items: center; + text-align: center; +} + +/** + * Backwards Compatibility + */ +.frm-lookup-box-label { + display: none; +} + +.frm-inline-modal[id^=frm-lookup-box] { + background-color: transparent; + border: 0; + box-shadow: none; +} +.frm-inline-modal[id^=frm-lookup-box] .frm-nav-tabs, +.frm-inline-modal[id^=frm-lookup-box] .dismiss { + display: none; +} + +.frm_single_option a.frm_remove_tag svg, +.frm_single_option a.frm_add_opt svg { + width: 15px; + height: 15px; +} + +#frm_builder_page #frm-options-panel .frm-single-settings.frm-type-ranking .frm_image_styling_frame { + margin-left: 12px; +} + +/*# sourceMappingURL=frm_admin.css.map*/ \ No newline at end of file diff --git a/css/frm_testing_mode.css b/css/frm_testing_mode.css index 56c3c82dc3..bde5cf0c9e 100644 --- a/css/frm_testing_mode.css +++ b/css/frm_testing_mode.css @@ -1,3 +1,2859 @@ -:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_toggle_opt{padding:0;white-space:normal;display:inline;vertical-align:middle;font-weight:400}.frm_on_label,.frm_off_label{color:var(--grey-700)}.frm_toggle{position:relative;display:inline-block;width:40px;height:var(--h-xs);vertical-align:middle}.frm_toggle_block{display:inline-flex !important;gap:var(--gap-xs);align-items:center}.frm_toggle input,.frm_toggle_block input{display:none !important}.frm_toggle_slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--grey-200);transition:.4s;border-radius:30px}.frm_toggle_slider::before{box-sizing:border-box;content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E");position:absolute;left:2px;bottom:2px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:20px;line-height:20px;background-color:#fff;border-radius:50%;transition:.4s;box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider{background-color:var(--primary-500)}input:focus+.frm_toggle .frm_toggle_slider{box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider::before{transform:translateX(16px);content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E")}input[disabled]+.frm_toggle_slider,input[disabled]+.frm_toggle .frm_toggle_slider{pointer-events:none;cursor:text;opacity:.5}.frm_toggle_opt~.frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before{content:"" !important}.rtl .frm_toggle_opt{padding:0 8px}.rtl .frm_toggle_slider::before{left:17px}.rtl input:checked+.frm_toggle .frm_toggle_slider::before{transform:none !important;left:1px}.frm_toggle_off,.frm_toggle_on{display:none;color:#fff;z-index:999;position:absolute;font-size:10px;line-height:20px;left:6px}.frm_toggle_off{display:inline;left:auto;right:5px;color:var(--dark-grey)}.frm_toggle_long{width:80% !important;height:28px;display:inline-block !important}.frm_toggle_long .frm_toggle_slider{background:var(--primary-700);box-shadow:0 0 0 2px var(--primary-700)}.frm_toggle_long .frm_toggle_off,.frm_toggle_long .frm_toggle_on{width:50%;text-align:center;font-size:13px;line-height:28px}.frm_toggle_long .frm_toggle_on{left:0}.frm_toggle_long .frm_toggle_off{right:0}.frm_toggle_long .frm_toggle_slider::before{width:50%;left:0;top:0;border-radius:var(--border-radius) 0 0 var(--border-radius);height:100%;background-color:#fff;color:var(--primary-color);content:"" !important}.frm_toggle_long input:checked+.frm_toggle_slider::before{transform:translateX(101%);border-radius:0 var(--border-radius) var(--border-radius) 0}input:checked+.frm_toggle_slider+.frm_toggle_on{display:inline}input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:none}.frm_toggle_long .frm_toggle_on,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:inline;color:var(--primary-500);font-weight:400}.frm_toggle_long .frm_toggle_off,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on{color:#fff;font-weight:700}.frmdates_add_blackout_date_link,.frmdates_add_exception_link,.frm_form_field.frm_scroll_box .frm_opt_container,.frm-white-body .wrap input[type=text],.frm-white-body .wrap input[type=search],.frm-white-body .wrap input[type=number],.frm-white-body .wrap select,#frm-form-templates-modal select,.frm-white-body .wrap textarea,button.frm_choose_image_box,#titlediv input[type=text],.frm-fields button.btn,.frm_wrap textarea,.frm_wrap input[type=tel],.frm_wrap input[type=text],.frm_wrap input[type=email] .frm_wrap input[type=search],.frm_wrap input[type=number],.frm_wrap input[type=date],.frm_wrap select,.wp-admin .frm_wrap select,.field-group textarea,.field-group input[type=text],.field-group select,.frm-fields .frm-input-field{outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;background-color:#fff;line-height:var(--leading)}.frm_input_with_suffix{border-radius:var(--small-radius);border:1px solid var(--grey-300);display:inline-block;padding-right:14px}.frm_input_with_suffix input{border:0 !important;padding-right:5px !important}.frm_wrap ::-webkit-datetime-edit{line-height:var(--leading)}.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus,.frm_wrap input:focus,.frm_wrap select:focus,.wp-core-ui .frm_wrap select:focus,#frm-form-templates-modal select:focus,.frm-btn-group .multiselect.dropdown-toggle:focus,.frm_wrap textarea:focus{border-color:var(--primary-500) !important;box-shadow:none !important}.wp-admin .frm_fields_container textarea:focus,.wp-admin .frm_fields_container input:focus,.wp-admin .frm_fields_container select:focus{border-color:var(--primary-500);box-shadow:none}#postbox-container-2 textarea,.frm_wrap textarea,.field-group textarea{line-height:2}.frm_wrap input[type=number]{height:auto}.frm_wrap select{padding:2px}.wp-admin .frm_wrap select,#frm-form-templates-modal select{max-width:100%}.frm_form_field.frm_scroll_box .frm_opt_container{padding:10px 12px}.frm_wrap input[disabled],.frm_wrap select[disabled],.frm_wrap textarea[disabled],.frm_wrap input[readonly],.frm_wrap select[readonly],.frm_wrap textarea[readonly],.frm_wrap input::placeholder{color:var(--grey-500)}textarea[id^=frm_calc_]::placeholder{font-size:var(--text-sm);line-height:var(--leading);font-style:italic;color:var(--grey-400);padding-top:5px}.frm_wrap .frm-button-primary.frm-disabled{opacity:.5;cursor:default}#postcustomstuff table td>div{padding-top:0 !important}.wp-admin .frm_wrap .form-table select{vertical-align:top}.frm_wrap .frm_form_builder select{line-height:var(--leading);height:var(--text-md);width:100%}#postbox-container-2 select,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,#frm-form-templates-modal select{height:auto}.frm-white-body .tablenav select,.frm-white-body .tablenav input[type=text],.wp-admin .frm_wrap .tablenav select,.frm_wrap .tablenav input[type=date],.frm_wrap .tablenav input[type=text]{padding-top:0;padding-bottom:0;line-height:1}.frm_wrap .tablenav ::-webkit-datetime-edit{line-height:1}.frm-fields button.btn,.frm-fields textarea,.frm-fields input[type=text],.frm-fields select,.field-group textarea,.field-group input[type=text],.field-group select,.accordion-container input.hex,.frm-fields .frm-input-field{width:100%;outline:0}.frm-fields button.btn{height:var(--h-md);text-align:inherit}.global-font .field-group input[type=text]{width:auto}.frm_orange_button,.frm_reverse_button{font-size:12px;border:1px solid var(--orange);color:var(--orange);font-weight:600;padding:1px 4px;border-radius:4px;background:rgba(0,0,0,0)}.frm_reverse_button:hover,.frm_reverse_button:active,.frm_reverse_button:focus{color:#fff;background:var(--orange);border:1px solid var(--orange)}.frm_reverse_button{font-size:1em;transition:all .2s ease}.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.wp-core-ui .button.frm-button-primary,.frm-button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-search .button,.frm-white-body .search-box .button,.frm-white-body .tablenav .button,.frm_orange_button,.toplevel_page_formidable #frm_upgrade_modal .button-primary,.wp-core-ui.frm-white-body .button-primary,.wp-core-ui.frm-white-body .button-secondary,.frm-white-body .button-primary,.frm-white-body .button-secondary,#frm-form-button button,.frm-form-button button,.frm-preview-buttons button,.frm-button-red,.frm-button-tertiary{text-shadow:none;box-shadow:none;border-radius:30px;border:1px solid var(--primary-500);font-size:var(--text-sm);transition:all .2s ease;padding:7px 16px;height:auto;min-height:28px;outline:none;line-height:var(--leading);box-sizing:border-box;font-weight:500;margin-bottom:0;display:inline-block}.frm-button-primary.frm-sharp,.frm-button-secondary.frm-sharp{border-radius:12px !important}#wpcontent .frm-button-secondary.frm-button-gradient{position:relative;border-color:rgba(0,0,0,0) !important;background-clip:padding-box !important}#wpcontent .frm-button-secondary.frm-button-gradient::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;margin:-1px;border-radius:inherit;background:linear-gradient(90deg, #129efd 0%, #a334fd 100%);transition:opacity 150ms ease-out}#wpcontent .frm-button-secondary:hover::before{opacity:.5}.no-js.wp-core-ui .frm-search .button.hide-if-no-js,.js.wp-core-ui .frm-search .button.hide-if-js{display:none}.frm-button-tertiary{border-color:rgba(0,0,0,0);color:var(--primary-500)}.frm-button-tertiary:focus{outline:none}.frm-button-tertiary.frm_loading_button::before{border-right-color:var(--grey);border-bottom-color:var(--grey)}.frm-button-red,.frm-button-red:focus{--primary-color: var(--error-500);--primary-500: var(--error-500);--primary-700: var(--error-700)}.frm-button-red:not(.frm-button-tertiary),.frm-button-red:not(.frm-button-tertiary):focus{color:#fff !important}.frm-white-body h2 .button,.post-type-frm_display h2 .frm-button-primary,.frm-white-body .tablenav .button,.frm-button-primary.frm-button-sm,.frm-button-secondary.frm-button-sm,.frm-button-tertiary.frm-button-sm,.frm-button-red.frm-button-sm{padding:4px 12px !important;font-size:var(--text-xs) !important}.frm_no_style_button{background:rgba(0,0,0,0)}.frm-with-icon{display:flex;gap:var(--gap-xs);align-items:center}.frm-with-icon svg{opacity:.65}.frm-with-icon.button svg{height:var(--text-sm);width:var(--text-sm)}.frm-with-icon.frm-button-sm svg{height:var(--text-xs);width:var(--text-xs)}.frm-white-body .button.add_media{padding-left:12px !important;padding-right:12px !important;font-size:var(--text-xs);border-radius:var(--border-radius)}.wp-core-ui.frm-white-body #post-query-submit.button,.wp-core-ui.frm-white-body .button.tablenav-pages-navspan,.wp-core-ui.frm-white-body .button.first-page,.wp-core-ui.frm-white-body .button.prev-page,.wp-core-ui.frm-white-body .button.next-page,.wp-core-ui.frm-white-body .button.last-page,.wp-core-ui.frm-white-body .button.action{background-color:rgba(0,0,0,0);border-color:var(--grey-300);color:var(--grey-700);border-radius:var(--border-radius)}.post-type-frm_display.wp-core-ui .button-primary,.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.frm_single_entry_page #frm-publishing .button-primary{background-color:var(--primary-500) !important;color:#fff !important}.frm-button-primary.frm_large,.frm-button-secondary.frm_large{height:auto !important;padding:12px 16px !important}.frm-button-secondary.frm-small,.frm-button-primary.frm-small{font-size:var(--text-xs) !important;height:auto !important;padding:var(--gap-2xs) 12px !important}.frm-button-primary i::before{color:#fff}.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover,.frm-button-primary:not([disabled]):hover{background:var(--primary-700) !important;border-color:var(--primary-700) !important}.wp-core-ui .button-primary.frm-button-primary:active{vertical-align:inherit}.frm-white-body #search-submit,#frm-form-button .frm_button_submit,.frm-form-button .frm_button_submit,.frm-white-body .frm-preview-buttons button,.frm-white-body .button:not(.frm-button-primary),.wp-core-ui.frm-white-body .button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-button-secondary,.frm-button-secondary{color:var(--grey-800);border-color:var(--grey-300);background-color:#fff}#wp-content-media-buttons button,#wp-content-media-buttons a.button{border-color:var(--grey-300)}.frm_orange_button{border-color:#da791d !important;background:var(--orange);color:#fff}.frm-white-body .button:not(.frm-button-primary):focus,.frm-white-body .button:not(.frm-button-primary):active,.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:focus,.wp-core-ui.frm-white-body .tablenav .button:hover,.frm_wrap .preview>.button:hover,.frm-white-body #search-submit:hover{border-color:var(--grey-300) !important;color:var(--grey-800);background:var(--grey-50) !important;box-shadow:none !important;outline:none !important}.frm-button-primary .frmsvg{color:#fff}.frm_wrap .preview i{font-size:inherit}.frm-white-body .frm-button-primary:focus,.frm-white-body .frm-button-primary:active,#frm-addons-page .button-primary:focus,#form_global_settings .button-primary:focus,#frm_upgrade_modal .button-primary:focus{border-color:var(--primary-700) !important;background-color:var(--primary-700) !important;box-shadow:none !important;outline:none !important}.frm_wrap .preview>.button:focus,.frm_orange_button:hover,.frm_orange_button:focus,.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover,.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus,.toplevel_page_formidable .frm_wrap button.button-primary:hover,.toplevel_page_formidable .frm_wrap button.button-primary:focus{outline:none}.frm_orange_button:hover,.frm_orange_button:focus{border-color:var(--orange) !important;background:rgba(0,0,0,0);color:var(--orange);opacity:1}.major-publishing-actions.frm_create_form_header{padding:8px 0}.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner{font-size:15px;background:rgba(0,0,0,0)}.frm-menu-boxes .frm_blank_form_text{padding-bottom:26px}input.frm_insert_in_template{font-size:10px;width:98%;font-weight:400}.frm-dismissible a.dismiss:focus{box-shadow:none}.frm-dismissible a.dismiss{top:10px;right:10px;position:absolute}.frm-dismissible a.dismiss svg{color:var(--grey-800)}.frm-btn-unstyled{font:inherit;background:none;border:none;padding:0;cursor:pointer;outline:inherit}.frm-btn-unstyled:hover,.frm-btn-unstyled:focus,.frm-btn-unstyled:active{text-decoration:none;background:none;border:none;box-shadow:none}.frm-btn-unstyled:disabled,.frm-btn-unstyled[disabled]{pointer-events:none;opacity:.65}/*! +/*!********************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/test-mode/frm_testing_mode.scss ***! + \********************************************************************************************************************************************************************************************************************************************/ +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +/** + * Toggle Components + * + * These are the styles for the "Enable Formidable styling" toggle in the visual styler. + * To use this element, you can call the FrmHtmlHelper::toggle function. + */ +.frm_toggle_opt { + padding: 0; + white-space: normal; + display: inline; + vertical-align: middle; + font-weight: 400; +} + +.frm_on_label, +.frm_off_label { + color: var(--grey-700); +} + +.frm_toggle { + position: relative; + display: inline-block; + width: 40px; + height: var(--h-xs); + vertical-align: middle; +} + +.frm_toggle_block { + display: inline-flex !important; + gap: var(--gap-xs); + align-items: center; +} + +.frm_toggle input, +.frm_toggle_block input { + display: none !important; +} + +.frm_toggle_slider { + position: absolute; + cursor: pointer; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: var(--grey-200); + transition: 0.4s; + border-radius: 30px; +} + +.frm_toggle_slider::before { + box-sizing: border-box; + content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E"); + position: absolute; + left: 2px; + bottom: 2px; + display: flex; + align-items: center; + justify-content: center; + width: 20px; + height: 20px; + font-size: 20px; + line-height: 20px; + background-color: #fff; + border-radius: 50%; + transition: 0.4s; + box-shadow: var(--box-shadow-md); +} + +input:checked + .frm_toggle .frm_toggle_slider { + background-color: var(--primary-500); +} + +input:focus + .frm_toggle .frm_toggle_slider { + box-shadow: var(--box-shadow-md); +} + +input:checked + .frm_toggle .frm_toggle_slider::before { + transform: translateX(16px); + content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E"); +} + +input[disabled] + .frm_toggle_slider, +input[disabled] + .frm_toggle .frm_toggle_slider { + pointer-events: none; + cursor: text; + opacity: 0.5; +} + +.frm_toggle_opt ~ .frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before { + content: "" !important; /* Don't show x/check if off label included or on builder page */ +} + +.rtl .frm_toggle_opt { + padding: 0 8px; +} + +.rtl .frm_toggle_slider::before { + left: 17px; +} + +.rtl input:checked + .frm_toggle .frm_toggle_slider::before { + transform: none !important; + left: 1px; +} + +/* Deprecated admin toggle */ +.frm_toggle_off, +.frm_toggle_on { + display: none; + color: #fff; + z-index: 999; + position: absolute; + font-size: 10px; + line-height: 20px; + left: 6px; +} + +.frm_toggle_off { + display: inline; + left: auto; + right: 5px; + color: var(--dark-grey); +} + +.frm_toggle_long { + width: 80% !important; + height: 28px; + display: inline-block !important; +} + +.frm_toggle_long .frm_toggle_slider { + background: var(--primary-700); + box-shadow: 0 0 0 2px var(--primary-700); +} + +.frm_toggle_long .frm_toggle_off, +.frm_toggle_long .frm_toggle_on { + width: 50%; + text-align: center; + font-size: 13px; + line-height: 28px; +} + +.frm_toggle_long .frm_toggle_on { + left: 0; +} + +.frm_toggle_long .frm_toggle_off { + right: 0; +} + +.frm_toggle_long .frm_toggle_slider::before { + width: 50%; + left: 0; + top: 0; + border-radius: var(--border-radius) 0 0 var(--border-radius); + height: 100%; + background-color: #fff; + color: var(--primary-color); + content: "" !important; +} + +.frm_toggle_long input:checked + .frm_toggle_slider::before { + transform: translateX(101%); + border-radius: 0 var(--border-radius) var(--border-radius) 0; +} + +input:checked + .frm_toggle_slider + .frm_toggle_on { + display: inline; +} + +input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { + display: none; +} + +.frm_toggle_long .frm_toggle_on, +.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { + display: inline; + color: var(--primary-500); + font-weight: 400; +} + +.frm_toggle_long .frm_toggle_off, +.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on { + color: #fff; + font-weight: 700; +} + +/* End toggle styling */ +/** + * Component: Admin Inputs + */ +.frmdates_add_blackout_date_link, +.frmdates_add_exception_link, +.frm_form_field.frm_scroll_box .frm_opt_container, +.frm-white-body .wrap input[type=text], +.frm-white-body .wrap input[type=search], +.frm-white-body .wrap input[type=number], +.frm-white-body .wrap select, +#frm-form-templates-modal select, +.frm-white-body .wrap textarea, +button.frm_choose_image_box, +#titlediv input[type=text], +.frm-fields button.btn, +.frm_wrap textarea, +.frm_wrap input[type=tel], +.frm_wrap input[type=text], +.frm_wrap input[type=email] .frm_wrap input[type=search], +.frm_wrap input[type=number], +.frm_wrap input[type=date], +.frm_wrap select, +.wp-admin .frm_wrap select, +.field-group textarea, +.field-group input[type=text], +.field-group select, +.frm-fields .frm-input-field { + outline: 0; + box-shadow: var(--box-shadow-xs); + border-radius: var(--small-radius); + padding: 5px 14px; + border-color: var(--grey-300); + color: var(--grey-800); + font-size: var(--text-md); + margin: 0; + background-color: #fff; + line-height: var(--leading); +} + +.frm_input_with_suffix { + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + display: inline-block; + padding-right: 14px; +} + +.frm_input_with_suffix input { + border: 0 !important; + padding-right: 5px !important; +} + +.frm_wrap ::-webkit-datetime-edit { + line-height: var(--leading); +} + +.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus, +.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus, +.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus, +.frm_wrap input:focus, +.frm_wrap select:focus, +.wp-core-ui .frm_wrap select:focus, +#frm-form-templates-modal select:focus, +.frm-btn-group .multiselect.dropdown-toggle:focus, +.frm_wrap textarea:focus { + border-color: var(--primary-500) !important; + box-shadow: none !important; +} + +/* +Pages like Entries and Styles need the border-color and box-shadow properties without the !important flag. +To achieve this, we exclude them above and duplicate these rules specifically for those pages without using !important. +*/ +.wp-admin .frm_fields_container textarea:focus, +.wp-admin .frm_fields_container input:focus, +.wp-admin .frm_fields_container select:focus { + border-color: var(--primary-500); + box-shadow: none; +} + +#postbox-container-2 textarea, +.frm_wrap textarea, +.field-group textarea { + line-height: 2; +} + +.frm_wrap input[type=number] { + height: auto; +} + +.frm_wrap select { + padding: 2px; +} + +.wp-admin .frm_wrap select, +#frm-form-templates-modal select { + max-width: 100%; +} + +.frm_form_field.frm_scroll_box .frm_opt_container { + padding: 10px 12px; +} + +.frm_wrap input[disabled], +.frm_wrap select[disabled], +.frm_wrap textarea[disabled], +.frm_wrap input[readonly], +.frm_wrap select[readonly], +.frm_wrap textarea[readonly], +.frm_wrap input::placeholder { + color: var(--grey-500); +} + +textarea[id^=frm_calc_]::placeholder { + font-size: var(--text-sm); + line-height: var(--leading); + font-style: italic; + color: var(--grey-400); + padding-top: 5px; +} + +.frm_wrap .frm-button-primary.frm-disabled { + opacity: 0.5; + cursor: default; +} + +#postcustomstuff table td > div { + /* To override some inline css in add-on */ + padding-top: 0 !important; +} + +.wp-admin .frm_wrap .form-table select { + vertical-align: top; +} + +.frm_wrap .frm_form_builder select { + line-height: var(--leading); + height: var(--text-md); + width: 100%; +} + +#postbox-container-2 select, +.wp-admin .frm_wrap select, +.frm_wrap .frm_form_builder select, +#frm-form-templates-modal select { + height: auto; +} + +.frm-white-body .tablenav select, +.frm-white-body .tablenav input[type=text], +.wp-admin .frm_wrap .tablenav select, +.frm_wrap .tablenav input[type=date], +.frm_wrap .tablenav input[type=text] { + padding-top: 0; + padding-bottom: 0; + line-height: 1; +} + +.frm_wrap .tablenav ::-webkit-datetime-edit { + line-height: 1; +} + +.frm-fields button.btn, +.frm-fields textarea, +.frm-fields input[type=text], +.frm-fields select, +.field-group textarea, +.field-group input[type=text], +.field-group select, +.accordion-container input.hex, +.frm-fields .frm-input-field { + width: 100%; + outline: 0; +} + +.frm-fields button.btn { + height: var(--h-md); + text-align: inherit; +} + +.global-font .field-group input[type=text] { + width: auto; +} + +/** + * Components - Button + */ +.frm_orange_button, +.frm_reverse_button { + font-size: 12px; + border: 1px solid var(--orange); + color: var(--orange); + font-weight: 600; + padding: 1px 4px; + border-radius: 4px; + background: transparent; +} + +.frm_reverse_button:hover, +.frm_reverse_button:active, +.frm_reverse_button:focus { + color: #fff; + background: var(--orange); + border: 1px solid var(--orange); +} + +.frm_reverse_button { + font-size: 1em; + transition: all 0.2s ease; +} + +.frm-button-primary, +.wp-core-ui .button-primary.frm-button-primary, +.wp-core-ui .button.frm-button-primary, +.frm-button-secondary, +.wp-core-ui .button-secondary.frm-button-secondary, +.wp-core-ui .button.frm-button-secondary, +.frm-white-body .frm-search .button, +.frm-white-body .search-box .button, +.frm-white-body .tablenav .button, +.frm_orange_button, +.toplevel_page_formidable #frm_upgrade_modal .button-primary, +.wp-core-ui.frm-white-body .button-primary, +.wp-core-ui.frm-white-body .button-secondary, +.frm-white-body .button-primary, +.frm-white-body .button-secondary, +#frm-form-button button, +.frm-form-button button, +.frm-preview-buttons button, +.frm-button-red, +.frm-button-tertiary { + text-shadow: none; + box-shadow: none; + border-radius: 30px; + border: 1px solid var(--primary-500); + font-size: var(--text-sm); + transition: all 0.2s ease; + padding: 7px 16px; + height: auto; + min-height: 28px; + outline: none; + line-height: var(--leading); + box-sizing: border-box; + font-weight: 500; + margin-bottom: 0; + display: inline-block; +} + +.frm-button-primary.frm-sharp, +.frm-button-secondary.frm-sharp { + border-radius: 12px !important; +} + +#wpcontent .frm-button-secondary.frm-button-gradient { + position: relative; + border-color: transparent !important; + background-clip: padding-box !important; +} +#wpcontent .frm-button-secondary.frm-button-gradient::before { + content: ""; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + z-index: -1; + margin: -1px; + border-radius: inherit; + background: linear-gradient(90deg, #129efd 0%, #a334fd 100%); + transition: opacity 150ms ease-out; +} +#wpcontent .frm-button-secondary:hover::before { + opacity: 0.5; +} + +.no-js.wp-core-ui .frm-search .button.hide-if-no-js, +.js.wp-core-ui .frm-search .button.hide-if-js { + display: none; +} + +.frm-button-tertiary { + border-color: transparent; + color: var(--primary-500); +} + +.frm-button-tertiary:focus { + outline: none; +} + +.frm-button-tertiary.frm_loading_button::before { + border-right-color: var(--grey); + border-bottom-color: var(--grey); +} + +.frm-button-red, +.frm-button-red:focus { + --primary-color: var(--error-500); + --primary-500: var(--error-500); + --primary-700: var(--error-700); +} + +.frm-button-red:not(.frm-button-tertiary), +.frm-button-red:not(.frm-button-tertiary):focus { + color: #fff !important; +} + +.frm-white-body h2 .button, +.post-type-frm_display h2 .frm-button-primary, +.frm-white-body .tablenav .button, +.frm-button-primary.frm-button-sm, +.frm-button-secondary.frm-button-sm, +.frm-button-tertiary.frm-button-sm, +.frm-button-red.frm-button-sm { + padding: 4px 12px !important; + font-size: var(--text-xs) !important; +} + +.frm_no_style_button { + background: transparent; +} + +.frm-with-icon { + display: flex; + gap: var(--gap-xs); + align-items: center; +} + +.frm-with-icon svg { + opacity: 0.65; /* Get close to grey-500 without overriding hover colors */ +} + +.frm-with-icon.button svg { + height: var(--text-sm); + width: var(--text-sm); +} + +.frm-with-icon.frm-button-sm svg { + height: var(--text-xs); + width: var(--text-xs); +} + +.frm-white-body .button.add_media { + /* Media buttons above RTE */ + padding-left: 12px !important; + padding-right: 12px !important; + font-size: var(--text-xs); + border-radius: var(--border-radius); +} + +.wp-core-ui.frm-white-body #post-query-submit.button, +.wp-core-ui.frm-white-body .button.tablenav-pages-navspan, +.wp-core-ui.frm-white-body .button.first-page, +.wp-core-ui.frm-white-body .button.prev-page, +.wp-core-ui.frm-white-body .button.next-page, +.wp-core-ui.frm-white-body .button.last-page, +.wp-core-ui.frm-white-body .button.action { + background-color: transparent; + border-color: var(--grey-300); + color: var(--grey-700); + border-radius: var(--border-radius); +} + +.post-type-frm_display.wp-core-ui .button-primary, +.frm-button-primary, +.wp-core-ui .button-primary.frm-button-primary, +.frm_single_entry_page #frm-publishing .button-primary { + background-color: var(--primary-500) !important; + color: #fff !important; +} + +.frm-button-primary.frm_large, +.frm-button-secondary.frm_large { + height: auto !important; + padding: 12px 16px !important; +} + +.frm-button-secondary.frm-small, +.frm-button-primary.frm-small { + font-size: var(--text-xs) !important; + height: auto !important; + padding: var(--gap-2xs) 12px !important; +} + +.frm-button-primary i::before { + color: #fff; +} + +.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover, +.frm-button-primary:not([disabled]):hover { + background: var(--primary-700) !important; + border-color: var(--primary-700) !important; +} + +.wp-core-ui .button-primary.frm-button-primary:active { + vertical-align: inherit; +} + +.frm-white-body #search-submit, +#frm-form-button .frm_button_submit, +.frm-form-button .frm_button_submit, +.frm-white-body .frm-preview-buttons button, +.frm-white-body .button:not(.frm-button-primary), +.wp-core-ui.frm-white-body .button-secondary, +.wp-core-ui .button-secondary.frm-button-secondary, +.wp-core-ui .button.frm-button-secondary, +.frm-white-body .frm-button-secondary, +.frm-button-secondary { + color: var(--grey-800); + border-color: var(--grey-300); + background-color: #fff; +} + +#wp-content-media-buttons button, +#wp-content-media-buttons a.button { + border-color: var(--grey-300); +} + +.frm_orange_button { + border-color: #da791d !important; + background: var(--orange); + color: #fff; +} + +.frm-white-body .button:not(.frm-button-primary):focus, +.frm-white-body .button:not(.frm-button-primary):active, +.frm-white-body .frm-button-secondary:hover, +.wp-core-ui.frm-white-body .frm-button-secondary:hover, +.wp-core-ui.frm-white-body .button-secondary:hover, +.wp-core-ui.frm-white-body .button-secondary:focus, +.wp-core-ui.frm-white-body .tablenav .button:hover, +.frm_wrap .preview > .button:hover, +.frm-white-body #search-submit:hover { + border-color: var(--grey-300) !important; + color: var(--grey-800); + background: var(--grey-50) !important; + box-shadow: none !important; + outline: none !important; +} + +.frm-button-primary .frmsvg { + color: #fff; +} + +.frm_wrap .preview i { + font-size: inherit; +} + +.frm-white-body .frm-button-primary:focus, +.frm-white-body .frm-button-primary:active, +#frm-addons-page .button-primary:focus, +#form_global_settings .button-primary:focus, +#frm_upgrade_modal .button-primary:focus { + border-color: var(--primary-700) !important; + background-color: var(--primary-700) !important; + box-shadow: none !important; + outline: none !important; +} + +.frm_wrap .preview > .button:focus, +.frm_orange_button:hover, +.frm_orange_button:focus, +.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover, +.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus, +.toplevel_page_formidable .frm_wrap button.button-primary:hover, +.toplevel_page_formidable .frm_wrap button.button-primary:focus { + outline: none; +} + +.frm_orange_button:hover, +.frm_orange_button:focus { + border-color: var(--orange) !important; + background: transparent; + color: var(--orange); + opacity: 1; +} + +.major-publishing-actions.frm_create_form_header { + padding: 8px 0; +} + +.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner { + font-size: 15px; + background: transparent; +} + +.frm-menu-boxes .frm_blank_form_text { + padding-bottom: 26px; +} + +input.frm_insert_in_template { + font-size: 10px; + width: 98%; + font-weight: 400; +} + +.frm-dismissible a.dismiss:focus { + box-shadow: none; +} + +.frm-dismissible a.dismiss { + top: 10px; + right: 10px; + position: absolute; +} + +.frm-dismissible a.dismiss svg { + color: var(--grey-800); +} + +.frm-btn-unstyled { + font: inherit; + background: none; + border: none; + padding: 0; + cursor: pointer; + outline: inherit; +} +.frm-btn-unstyled:hover, .frm-btn-unstyled:focus, .frm-btn-unstyled:active { + text-decoration: none; + background: none; + border: none; + box-shadow: none; +} +.frm-btn-unstyled:disabled, .frm-btn-unstyled[disabled] { + pointer-events: none; + opacity: 0.65; +} + +/*! * Bootstrap v4.6.1 - */.tooltip{position:absolute;display:block;margin:0;font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0;z-index:9999999;pointer-events:none}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem;margin-left:0 !important}.tooltip .arrow::before{position:absolute;content:"";border-color:rgba(0,0,0,0);border-style:solid}.bs-tooltip-top,.bs-tooltip-auto[x-placement^=top]{padding:.4rem 0}.bs-tooltip-top .arrow,.bs-tooltip-auto[x-placement^=top] .arrow{bottom:0}.bs-tooltip-top .arrow::before,.bs-tooltip-auto[x-placement^=top] .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-right,.bs-tooltip-auto[x-placement^=right]{padding:0 .4rem}.bs-tooltip-right .arrow,.bs-tooltip-auto[x-placement^=right] .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-right .arrow::before,.bs-tooltip-auto[x-placement^=right] .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-bottom,.bs-tooltip-auto[x-placement^=bottom]{padding:.4rem 0}.bs-tooltip-bottom .arrow,.bs-tooltip-auto[x-placement^=bottom] .arrow{top:0}.bs-tooltip-bottom .arrow::before,.bs-tooltip-auto[x-placement^=bottom] .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-left,.bs-tooltip-auto[x-placement^=left]{padding:0 .4rem}.bs-tooltip-left .arrow,.bs-tooltip-auto[x-placement^=left] .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-left .arrow::before,.bs-tooltip-auto[x-placement^=left] .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.frm-dropdown-menu.show{display:block}.frm-single-settings .frm-dropdown-menu.show{background:#fff}.preview.dropdown .dropdown-menu{min-width:205px}.frm_clear{clear:both}.frm_clearfix::after{content:".";display:block;clear:both;visibility:hidden;line-height:0;height:0}.frm_clearfix{display:block}.frm_admin_progress{overflow:hidden;height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.frm_admin_progress_bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);transition:width .6s ease;background-color:#04a4cc}.tooltip.frm_tooltip{position:fixed;top:auto !important;bottom:0 !important;left:0 !important;max-width:none;width:100% !important;z-index:99999}.tooltip.frm_tooltip.bottom{padding:0}.frm_tooltip .tooltip-inner{max-width:none;min-height:40px !important;text-align:left;box-shadow:5px 5px 25px rgba(0,0,0,.5);padding:10px 40px;border-top-color:#ccc;background:var(--sidebar-color);color:var(--grey-700);border-radius:0;opacity:1;font-size:var(--text-sm)}#frm_custom_css_box{width:100%}h1 .fa-caret-down{font-size:18px}.caret{display:inline-block;width:19px;height:9px;margin-right:-8px;vertical-align:middle}.caret,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,.frm_wrap .ui-autocomplete-input{background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;padding-right:var(--gap-lg) !important}.caret{padding-right:var(--gap-xs) !important;background-position-x:5px}.frm-btn-group .caret{float:right;margin-top:calc(var(--text-md)/2)}.dropdown{position:relative}.dropdown-toggle:focus{outline:0}.frm_wrap .ui-autocomplete,#frm_adv_info.frm-dropdown-menu,.frm-dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;padding-left:4px;padding-right:4px;margin:var(--gap-xs) 0 0;text-align:left;list-style:none;background:none;background-color:#fff;background-clip:padding-box;border:1px solid var(--grey-100);border-radius:.25rem;box-shadow:var(--box-shadow-lg);max-height:200px;overflow-y:auto;overflow-x:hidden;font-size:var(--text-md);width:auto;min-width:160px}.frm6 .frm-dropdown-menu{min-width:100px;max-width:99%}#frm_bs_dropdown .frm-dropdown-menu{max-width:400px}.field_type_list .frm-dropdown-menu{min-width:150px !important}#frm_field_group_controls .frm-dropdown-menu,.frm-field-action-icons .frm-dropdown-menu{min-width:180px !important}.frm-field-action-icons .frm-dropdown-toggle svg,#frm_field_group_controls .frm-dropdown-toggle svg{color:#9ea9b8}.multiselect-container.frm-dropdown-menu,#search-submit .frm-dropdown-menu{min-width:200px !important}.preview .frm-dropdown-menu{min-width:230px !important}.frm-dropdown-menu.dropdown-menu-right{right:0;left:auto}.frm-dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.frm-dropdown-menu>.dropdown-item{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu .frm_dropdown_li{clear:both;font-weight:400;white-space:nowrap;text-decoration:none;border-radius:var(--small-radius)}.frm-dropdown-menu>.active>a,.frm-dropdown-menu>.active>a:hover,.frm-dropdown-menu>.active>a:focus{text-decoration:none;outline:0}.frm-select-list-item.disabled,.frm-dropdown-menu>.disabled>a,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{color:#999}.frm-select-list-item.disabled:hover,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{text-decoration:none;background-color:rgba(0,0,0,0);background-image:none;cursor:not-allowed}.open>.frm-dropdown-menu{display:block}.open>a{outline:0}.dropdown-header{display:block;padding:3px 10px;font-size:var(--text-xs);color:var(--grey-400)}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.dropdown-menu-right>.frm-dropdown-menu,.pull-right>.frm-dropdown-menu{right:0;left:auto}.navbar-fixed-bottom .dropdown .caret{border-top:0 dotted;border-bottom:4px solid #000;content:""}.navbar-fixed-bottom .dropdown .frm-dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.btn{border:1px solid #ddd;background:#fff;height:28px;line-height:var(--leading)}a.frm_option_icon::before{color:var(--primary-500);font-size:22px;width:22px;height:22px}a.frm_option_icon:focus::before,a.frm_option_icon:hover::before{color:var(--primary-700)}.frm_top_left .frm-dropdown-toggle{color:#999}.frm-card ol{margin-left:15px}.frm-dropdown-toggle{text-decoration:none}.frm-card .frm-dropdown-toggle{border:1px solid var(--grey-300);border-radius:var(--small-radius);font-size:13px;color:var(--grey-700);padding:7px 20px}.frm-dropdown-menu .frm_icon_font{vertical-align:middle;color:#5f6c72;margin-right:3px}.multiselect-container.frm-dropdown-menu{top:auto;left:auto;font-size:var(--text-sm);padding:4px;margin-bottom:3px}.multiselect-container{position:absolute;list-style-type:none;margin:0;padding:0;width:100%;max-width:250px}.multiselect-container button.multiselect-option{width:100%;text-align:left;border:none;margin-bottom:4px}.multiselect-container button.multiselect-option label{margin-left:5px}.accordion-container .multiselect-container label{padding:3px 19px 3px 7px}.frm-btn-group.btn-group>.btn-group:nth-child(2)>.multiselect.btn{border-top-left-radius:4px;border-bottom-left-radius:4px}.frm-btn-group.btn-group,.frm-btn-group.btn-group-vertical{display:block}.multiselect-option label{max-width:calc(100% - 22px);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}#frm_field_multiselect_popup{background:#fff;height:48px;position:fixed;border-radius:4px;box-shadow:0 8px 24px rgba(40,47,54,.15);color:rgba(40,47,54,.85);font-size:13px;right:30px;bottom:10px;z-index:2}#frm_field_multiselect_popup>div{display:inline-block;line-height:48px;vertical-align:top}#frm_field_multiselect_popup.frm-unmergable>.frm-merge-fields-into-row,#frm_field_multiselect_popup.frm-unmergable>.frm-multiselect-popup-separator{display:none}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator){padding:0 20px;cursor:pointer}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator):hover{background:rgba(245,245,245,.9607843137)}.frm-builder-popup-heading{font-weight:600;font-size:11px;line-height:15px;text-transform:uppercase;color:rgba(40,47,54,.45);margin-bottom:7px}.frm-builder-popup-subheading{font-size:12px;line-height:16px;color:rgba(40,47,54,.45)}#frm_field_group_popup input[type=text]{height:30px;border-radius:3px;font-size:14px;padding:8px;color:#545f6e;border-color:rgba(40,47,54,.2)}.frm-multiselect-popup-separator{height:36px;width:1px;position:relative;top:6px;background:#c4c4c4}.frm-sortable-helper,.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider){pointer-events:none}.frm-sortable-helper{z-index:99}.frm_code_list a.button{display:block;text-align:center;font-size:11px;overflow:hidden}#frm-navbarDrop+.frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0;min-width:300px;max-height:256px}.frm_code_list.frm-full-hover li{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu>.dropdown-item>a:visited,.frm-dropdown-menu>.dropdown-item>a:link,.frm-dropdown-menu .frm_dropdown_li,.frm_code_list.frm-full-hover a{display:flex;color:var(--grey-700);padding:5px 10px;font-size:var(--text-md);gap:var(--gap-xs);align-items:center}.multiselect-container button.multiselect-option.disabled{opacity:.5}.frm_code_list.frm-full-hover a span{max-width:83px;margin-right:var(--gap-xs);margin-left:auto}.frm_code_list.frm-full-hover a{border-radius:var(--small-radius)}.frm_code_list.frm-full-hover a:not(#frm-insert-condition),.frm_code_list.frm-full-hover a span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frm_code_list.frm-full-hover a:focus span:last-child{outline:1px solid var(--primary-500);outline-offset:var(--gap-2xs)}.frm_code_list.frm-full-hover.frmcenter a{display:block}#frm-layout-classes frm-full-hover a span{max-width:45%}.frm-select-list-item.active,.frm-select-list-item:hover,.frm_wrap .ui-autocomplete li div.ui-state-active,.frm_wrap .ui-autocomplete li.ui-state-focus,.multiselect-container button.multiselect-option.active,.multiselect-container button.multiselect-option:hover,.frm-dropdown-menu>.dropdown-item>a:hover,.frm_code_list.frm-full-hover a:hover span,.frm_code_list.frm-full-hover a:hover{background:var(--primary-25);color:var(--primary-500)}.frm-select-list-item .frmsvg,.frm-dropdown-menu>.dropdown-item>a .frmsvg{opacity:.8}.frm-select-list-item:hover .frmsvg,.frm-dropdown-menu>.dropdown-item>a:hover .frmsvg{opacity:1}.frm-dropdown-menu.frm_code_list>li>a{padding:3px 15px;width:300px}#frm_edit_box_content_modal .frm-with-search,.frm-dropdown-menu .frm-with-search{padding:var(--gap-xs) 10px 0}.frm-dropdown-menu .subsubsub{padding:0 10px}.frm_grid_container{overflow:visible}.frm_code_list.frm_grid_container{grid-gap:var(--gap-xs)}.frm_code_list.frm_grid_container li{width:auto;margin:0}.frm_code_list.frm_grid_container a{display:block;font-size:var(--text-md) !important;font-weight:500;text-align:center;color:var(--primary-500);background-color:var(--light-blue);border:1px solid var(--primary-300);border-radius:var(--small-radius);padding:10px 0;box-shadow:var(--box-shadow-sm)}.frm_code_list.frm_grid_container a:hover{background-color:var(--primary-500);color:#fff}.frm_code_list.frm_grid_container a:focus-visible{outline:2px solid var(--primary-500);outline-offset:-1px}.frm-single-settings .frm_code_list.frm-full-hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{padding:0;margin:var(--gap-xs) -10px 0}.frm-single-settings .frm_code_list.frm-full-hover>li>a,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a{font-size:var(--text-md);color:var(--grey-900);padding:var(--gap-xs) 12px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span{margin:0}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:first-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:first-child{max-width:130px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:last-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:last-child{max-width:120px;margin-left:auto}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover{font-weight:500}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover .frmsvg,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover .frmsvg,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover span{color:var(--primary-500)}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg{width:20px;height:20px}#post-body-content+.frm-right-panel h3.accordion-section-title{padding:7px 10px 8px 14px;font-size:var(--text-md);color:var(--grey-700)}.frm-with-line,.accordion-section-content h4{font-size:var(--text-md);font-weight:400;margin:20px -20px 10px;padding:0 20px;color:var(--grey-700);position:relative;border:none !important}.frm-with-line span,.accordion-section-content h4 span{background:#fff;padding:0 var(--gap-xs);position:relative;display:inline-block;z-index:2}.accordion-section-content h4 span{background:var(--sidebar-color)}.frm-right-panel .frm-with-line span{background:var(--sidebar-color) !important;margin-left:-4px}.frm-right-panel .frm-inline-modal .frm-with-line span{background:#fff !important}.frm-with-line::before,.accordion-section-content h4::before{content:"";display:block;position:absolute;border-bottom:1px solid var(--grey-300);left:0;width:100%;top:50%}.control-section .accordion-section-title::after,.customize-pane-child .accordion-section-title::after{top:15px}.accordion-container .frm-dropdown-menu{min-width:40px}.frm-btn-group .multiselect.dropdown-toggle{box-sizing:border-box;min-height:unset;cursor:pointer}.accordion-container .frm-dropdown-menu::before,.accordion-container .multiselect.dropdown-toggle::before{font-family:"s11-fp" !important}.frm-search input[name=s],.frm-search .dropdown-toggle,.frm-search input.frm-search-input{color:var(--grey-800);border-color:var(--grey-300);border-radius:var(--small-radius);box-shadow:var(--box-shadow-xs)}.frm-search input[type=search],.frm-search input[type=text]{padding-left:var(--gap-lg) !important}.frm-search .dropdown-toggle{width:100%;float:none;max-width:200px;background:rgba(0,0,0,0);padding:7px;padding-left:33px !important;min-height:32px;text-align:inherit;overflow:hidden;text-overflow:ellipsis}.frm-search #search-submit a{color:var(--grey-800)}.frm-search #search-submit .caret{opacity:.7}.frm-white-body .search-box input[name=s],#wpwrap .frm-search input[type=search]{flex:1;font-size:var(--text-md);line-height:var(--text-xl);padding:var(--gap-xs)}span.multiselect-selected-text{white-space:nowrap;display:inline-block;max-width:calc(90% - var(--gap-xs));text-overflow:ellipsis;overflow:hidden}.frm_pro_tip,.frm-cta{justify-content:space-between;align-items:center;gap:var(--gap-2xl);padding:var(--gap-xs) var(--gap-sm);border-radius:var(--small-radius);background:var(--primary-25)}.frm-cta.frm-cta-border{border:1px solid var(--primary-200)}.frm-cta.frm-cta-border .frm-cta-footer{background-color:#fff;padding:12px var(--gap-sm);border-top:1px solid var(--primary-200);border-bottom-left-radius:var(--small-radius);border-bottom-right-radius:var(--small-radius);margin-top:12px;margin-bottom:calc(-1*var(--gap-sm));margin-left:calc(-1*var(--gap-sm));margin-right:calc(-1*var(--gap-sm))}.frm-cta h4{font-weight:600;margin-top:0;margin-bottom:var(--gap-2xs)}.frm-cta-green{background-color:var(--success-25)}.frm-cta-green .frm-banner-title{gap:calc(var(--gap-2xs) + 1px);color:var(--grey-700)}.frm-cta-green.frm-cta-border{border-color:var(--success-100)}.frm-cta-green.frm-cta-border .frm-cta-footer{border-color:var(--success-100)}.frm-cta-red{background-color:var(--error-25)}.frm-cta-red.frm-cta-border{border-color:var(--error-100)}.frm-cta-icon{padding:3px 15px 3px 0;border-right:1px solid currentColor}#frm-upgrade-banner{gap:0}#frm-upgrade-banner .frm-cta-icon+.frm-cta-content{margin-right:auto;padding-left:15px}#frm-upgrade-banner.frm-gradient h4,#frm-upgrade-banner.frm-gradient p{color:currentColor}#frm-upgrade-banner.frm-gradient h4{font-size:16px;font-weight:600}#frm-upgrade-banner.frm-gradient p{font-size:14px}.frm-right-panel .inside .frm_pro_tip,.frm_pro_tip{color:var(--grey-700);background:#ffe7de;margin:0 auto;display:flex;gap:var(--gap-xs)}.frm_field_list .frm_pro_tip{margin:10px 15px;position:relative;width:calc(100% - 30px);box-sizing:border-box;font-size:14px}.frm_pro_tip .frmsvg,.frm_pro_tip i{color:var(--orange)}.frm-tip-info{flex:1;text-align:left}.frm-tip-cta{color:var(--orange)}.frm-gradient .frm-tip-cta,.frm-light-tip .frm-gradient .frm-tip-cta{color:currentColor;font-weight:700}.frm-tip-badge{font-size:9px;font-weight:700;text-transform:uppercase;color:#1e63d5;background-color:#fff;line-height:1;border-radius:4px;padding:3px 4px}.frm-light-tip .frm_pro_tip{background:var(--primary-25)}.frm-light-tip .frm_pro_tip .frmsvg,.frm-light-tip .frm_pro_tip i,.frm-light-tip .frm-tip-cta{color:var(--primary-500)}.nav-tab-wrapper .frm_pro_tip{float:right}.frm-gradient,.frm-upgrade-bar{background:linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important;color:#fff !important;border:0 !important}.frm-gradient.frm-button-primary:not([disabled]),.frm-gradient.frm-button-primary:not([disabled]):hover,.frm-gradient.frm-button-primary:not([disabled]):focus{background:linear-gradient(90deg, #1961d5, #816cfa) !important}.frm-upgrade-bar,.frm-gradient{position:relative}.frm-upgrade-bar::before,.frm-gradient::before{content:"";display:none;position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgba(255,255,255,.1);z-index:0}.frm-upgrade-bar:hover::before,.frm-gradient:hover::before,.frm-gradient:focus::before{display:block}.frm-upgrade-bar-inner,.frm-gradient>*{position:relative;z-index:1}.frm-upgrade-bar{border-bottom:1px solid var(--sidebar-hover);padding:9px 0;font-size:12px;text-align:center}.frm-upgrade-bar a{color:currentColor !important;text-decoration:underline}.frm-upgrade-bar a:focus{outline:1px dotted var(--sidebar-hover)}.frm-upgrade-bar span{opacity:.9}.toplevel_page_formidable #wpbody-content>.error{margin:1px;padding:5px 12px}.frm_error_style,.frm_warning_style,.frm_note_style2,.frm_note_style,.frm_message,#post-body-content .frm_updated_message,div.frm_updated_message{border-radius:var(--small-radius);background-color:#d5f2dc;color:#1e561f;padding:var(--gap-sm) var(--gap-md);font-size:var(--text-sm);margin:var(--gap-sm) 0;text-align:left}.frm_note_style2{background:linear-gradient(90deg, #e9effa, #fcf6fe) padding-box,linear-gradient(90deg, #1961d5, #e8abef) border-box;border:1px solid rgba(0,0,0,0)}#frm_top_bar+.wrap>.frm_updated_message,#frm_top_bar+.wrap>.frm_warning_style{display:inline-block;width:100%;box-sizing:border-box}#post-body-content>.frm_updated_message{margin:5px 65px}#form_global_settings #post-body-content>.frm_updated_message,#form_global_settings #post-body-content>.frm_warning_style{margin:5px 25px}.frm_error_style{color:#973937;background-color:#ebcccc;clear:both}.frm_error_style a{text-decoration:underline;font-weight:600}.frm_error_style svg{opacity:.7}.frm_warning_style{color:#7a4d05;background-color:#fff2d2}.frm_warning_heading{font-weight:700;margin-bottom:4px}.frm_warning_style{position:relative;padding-right:calc(var(--gap-md) + 15px)}body.rtl .frm_warning_style{padding-right:var(--gap-md);padding-left:calc(var(--gap-md) + 15px)}.frm-warning-dismiss{position:absolute;top:10px;right:10px;display:flex;cursor:pointer;transition:opacity .2s ease-out}body.rtl .frm-warning-dismiss{left:10px;right:auto}.frm-warning-dismiss:hover{opacity:.8}.frm-warning-dismiss.frmsvg,.frm-warning-dismiss.frmsvg svg{width:15px;height:15px}.frm_note_style{background:rgba(188,224,253,.23);color:var(--grey-700)}.frm-banner-alert{text-align:left;margin:0;border-radius:0;padding:10px 0 10px 40px}.frm-banner-alert a{color:var(--primary-500);font-weight:400;text-decoration:none}.frm_updated_message ul,.frm_updated_message li,.frm_warning_style ul,.frm_warning_style li,.frm_error_style ul,.frm_error_style li{margin:0}.frm-inline-message{border:1px solid var(--primary-700);border-radius:var(--small-radius);color:var(--primary-700);background:#fff;text-align:center;padding:20px;font-size:var(--text-sm);line-height:var(--leading)}.frm-inline-message a{text-decoration:underline;font-weight:600;color:var(--primary-700)}.frm_pro_heading span{margin-top:10px}.frm_pro_heading .alignright{text-align:right}.frm-yes{color:var(--green);font-size:var(--text-xl)}.frm-nope{color:var(--grey-400);font-size:var(--text-xl)}.frm-modal:not(#frm-dismissable-cta) .postbox{max-height:600px;overflow:hidden;margin-bottom:0}.frm-modal .postbox .frm_modal_top,.frm-dialog .frm_common_modal .postbox>div:first-child,.frm-error-modal .frm_modal_top{padding:var(--gap-md) var(--gap-md) 0;position:relative}.frm-modal h2,.frm-modal .postbox .inside h2,.frm-modal .postbox .frm-modal-title,.frm-dialog .frm_common_modal .postbox>div:first-child>div:first-child,.frm-error-modal .frm-modal-title{display:inline-block;font-size:var(--text-lg);color:var(--grey-900);font-weight:600;margin:0;padding:0}.frm-modal h3{font-weight:500}.frm-inline-modal>a.dismiss,.frm-modal .postbox>a.dismiss,.frm-modal .postbox .frm-modal-title+div:last-child,.frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{position:absolute;top:19px;right:19px;display:flex;z-index:2}body.rtl .frm-inline-modal>a.dismiss,body.rtl .frm-modal .postbox>a.dismiss,body.rtl .frm-modal .postbox .frm-modal-title+div:last-child,body.rtl .frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{right:unset;left:30px}.frm-info-modal .postbox>a.dismiss,.frm-inline-modal>a.dismiss{right:13px;top:13px}.frm-modal .postbox .frm-modal-title+div:last-child a,.frm-modal a.dismiss .frmsvg,.frm_common_modal .frm_modal_top a .frmsvg{color:var(--grey-500)}.frm-modal .postbox .frm-modal-title+div:last-child a:hover,.frm-modal a.dismiss .frmsvg:hover,.frm_common_modal .frm_modal_top a .frmsvg:hover{color:var(--grey-700)}.frm-modal .frm_modal_content>div.inside,.frm_common_modal .frm_modal_content>div.inside{padding:var(--gap-md);margin:0;font-size:var(--text-sm);color:var(--grey-700)}.frm-modal p{color:var(--grey-900)}.frm_common_modal .postbox{display:flex;flex-direction:column}.frm-modal .postbox>div.inside .cta-inside{overflow-y:auto;height:auto}.frm_modal_footer{padding:0 var(--gap-md) var(--gap-sm);text-align:right}body.frm-body-with-open-modal{overflow-y:hidden}.frm-dialog{z-index:100;padding:0 !important;border-radius:16px;border:none;background-color:#fff;max-width:100% !important}.frm-dialog .postbox{background:rgba(0,0,0,0);box-shadow:none;border:none;line-height:var(--leading)}.frm-dialog input[type=text],.frm-dialog textarea{font-size:var(--text-md)}.frm-dialog textarea{height:75px}.frm-dialog button.frm-button-primary{margin-right:10px}.frm-dialog .frm-sub-label,.frm-sub-label{color:var(--grey);text-transform:none;padding-left:8px}h2 .frm-sub-label{font-size:var(--text-md)}.frm-views-editor-body .ui-widget-overlay,.frm-white-body .ui-widget-overlay,.toplevel_page_formidable .ui-widget-overlay,body[class*=formidable-payments] .ui-widget-overlay,body.plugins-php .ui-widget-overlay{position:fixed;width:100%;height:100%;top:0;left:0;right:0;bottom:0;background:var(--grey-500);opacity:.5;z-index:2}.frm-circled-icon{width:60px;height:60px;border-radius:50%;background-color:var(--primary-25)}.frm-circled-icon-large{width:80px;height:80px}.frm-circled-icon-green{background-color:var(--success-50)}.frm-circled-icon .frmsvg{width:21px;height:24px}.frm-circled-icon .frmsvg.frm_svg32{width:32px !important;height:32px !important}.frm-circled-icon-large .frmsvg{width:24px}.frm-circled-icon .frmsvg use{color:var(--primary-500)}.frm-circled-icon-green .frmsvg use{color:var(--success-500)}.frm-border-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--grey-300);border-radius:var(--small-radius)}.frm-upgrade-message img{max-width:100%}.frm-inline-flex,#wpbody-content .frm-inline-flex{display:inline-flex}.frm-flex{display:flex}.frm-force-flex{display:flex !important}.frm_hidden,.js .frm-hide-js{display:none}.frm-flex-box{display:flex;gap:var(--gap-sm)}.frm-flex-col{display:flex;flex-direction:column}.frm-flex-full{flex:1}.frm-force-flex-center,.frm-flex-center{justify-content:center;align-items:center}.frm-flex-center{display:flex}.frm-force-flex-center{display:flex !important}.frm-shrink-0{flex-shrink:0}.frm-gap-0{gap:0 !important}.frm-gap-2xs{gap:var(--gap-2xs)}.frm-gap-xs{gap:var(--gap-xs)}.frm-gap-sm{gap:var(--gap-sm)}.frm-gap-md{gap:var(--gap-md)}.frm-gap-xl{gap:var(--gap-xl)}.frm-justify-start{justify-content:start !important}.frm-justify-center{justify-content:center !important}.frm-justify-between{justify-content:space-between}.frm-justify-end{justify-content:end}.frm-items-start{align-items:flex-start}.frm-items-center{align-items:center}.frm-items-stretch{align-items:stretch}.frm-self-normal{align-self:normal}#wpbody-content .frm-flex-wrap{flex-wrap:wrap}.frm-grow{flex-grow:1}.frm-order-first{order:-9999}.frm-order-last{order:9999}.frm-order-none{order:0}.frm-h-stack-sm,.frm-h-stack-xs,.frm-h-stack{display:flex !important;align-items:center}.frm-h-stack-sm>input[type=checkbox],.frm-h-stack-xs>input[type=checkbox],.frm-h-stack>input[type=checkbox],.frm-h-stack-sm>input[type=radio],.frm-h-stack-xs>input[type=radio],.frm-h-stack>input[type=radio]{margin:0 !important}.frm-h-stack{gap:var(--gap-2xs)}.frm-h-stack-xs{gap:var(--gap-xs)}.frm-h-stack-sm{gap:var(--gap-sm)}.frm-flex-row-reverse{flex-direction:row-reverse}.frm-info-modal a,.frm-info-modal ul,.frm-info-modal p,.frm-info-modal,.settings-lite-cta a,.settings-lite-cta ul,.settings-lite-cta{color:var(--grey-500);font-size:var(--text-md);box-shadow:none !important}.frm-info-modal h3,.settings-lite-cta h3{font-size:17px !important}.frm-green-icons .frmsvg{color:var(--green)}.frm-info-modal .postbox .inside,.settings-lite-cta .postbox .inside{padding:var(--gap-md);margin:0}.cta-inside a{color:var(--orange)}.info-modal-inside a.frm-standard-link{color:var(--primary-500)}.info-modal-inside a.frm-standard-link:hover{color:var(--primary-700)}.frm_no_p_margin>p{margin:0}.frm_spinner.frm-wait,.frm_spinner.spinner{float:left;visibility:hidden;margin:0 10px}.frm_visible_spinner.frm-wait,.frm_visible_spinner.spinner{visibility:visible;float:none}.frm_form_action_settings .frm_spinner.frm-wait,.frm_form_action_settings .frm_spinner.spinner{visibility:visible;float:none;vertical-align:bottom}.frm_form_action_settings .frm_loading{font-size:15px;text-align:center}.frm_ajax_settings_tab .frm-wait,.frm_ajax_settings_tab .spinner{visibility:visible;float:none;margin-top:20px}.wp-core-ui .frm_loading_button.button-primary.frm-button-primary,.frm_loading_button,.frm_loading_form.frm_button_submit{position:relative !important;opacity:.8;color:rgba(0,0,0,0) !important;text-shadow:none !important}.frm_loading_button:hover,.frm_loading_button:active,.frm_loading_button:focus,.frm_loading_form.frm_button_submit:hover,.frm_loading_form.frm_button_submit:active,.frm_loading_form.frm_button_submit:focus{cursor:not-allowed;color:rgba(0,0,0,0) !important;outline:none !important;box-shadow:none}.frm-wait{margin:20px;width:20px;height:20px;position:relative;display:inline-block}#frm-show-fields .frm-wait:only-child{position:absolute;left:50px;top:30px}.frm-wait::before,.frm_loading_button::before,.frm_loading_form.frm_button_submit::before{content:"";display:inline-block;position:absolute;background:rgba(0,0,0,0);border:1px solid #fff;border-top-color:rgba(0,0,0,0);border-left-color:rgba(0,0,0,0);border-radius:50%;box-sizing:border-box;top:50%;left:50%;margin-top:-10px;margin-left:-10px;width:20px;height:20px;animation:spin 2s linear infinite}.frm-wait::before{border-bottom-color:var(--primary-700);border-right-color:var(--primary-700)}.frm_loading_button.frm-button-secondary::before{border-bottom-color:var(--primary-500);border-right-color:var(--primary-500)}input[type=submit]:focus{outline:none !important}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.frmsvg{fill:currentColor;width:18px;height:18px;vertical-align:middle}body.frm_preview_page .ui-widget-overlay{position:fixed;width:100%;height:100%;top:0;left:0;right:0;bottom:0;background:var(--grey-500);opacity:.5;z-index:2}#frm_testing_mode{border-radius:1rem;background-color:#fff;border-color:rgba(0,0,0,.1019607843);border-width:1px;border-style:solid;padding:16px 20px;margin-bottom:40px;position:relative}#frm_testing_mode h2{font-size:18px;font-weight:600;color:#000;margin-bottom:0}#frm_testing_mode label{font-size:12px;font-weight:600}#frm_testing_mode label span.frm_toggle_opt{color:var(--grey-800);font-weight:600}#frm_testing_mode label:not(:first-child){margin-left:var(--gap-xs)}#frm_testing_mode a.frm_button{margin-left:auto;border-radius:20px;font-size:14px}#frm_testing_mode hr{color:unset;background:var(--grey-200);height:1px;border:none}#frm_testing_mode>div:nth-of-type(2){display:flex;align-items:center}#frm_testing_mode .multiselect.dropdown-toggle::after{border:none}#frm_testing_mode .frmsvg{width:11px;height:11px;margin-right:var(--gap-2xs);position:relative;top:1px}#frm_testing_mode .frm_toggle_block{gap:var(--gap-xs)}#frm_testing_mode label:not(.frm_toggle_block){margin-right:2px}#frm_testing_mode select{width:auto !important;min-height:auto !important;outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);border-width:1px;padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;line-height:var(--leading);appearance:none;background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;padding-right:var(--gap-lg) !important}#frm_testing_mode select:focus{background-color:rgba(0,0,0,0) !important}#frm_testing_mode select,#frm_testing_mode .btn-group button.multiselect.dropdown-toggle{border-radius:var(--medium-radius);font-size:12px;font-weight:600;height:30px}#frm_testing_mode .btn-group button.multiselect.dropdown-toggle{padding-top:0;padding-bottom:0}#frm_testing_mode .multiselect-selected-text{position:relative;top:2px}#frm_testing_mode #frm_testmode_fill_in_empty_form_fields{background-color:var(--primary-500);color:#fff;padding:8px 18px}#frm_testing_mode .frm_help{vertical-align:top}#frm_testing_mode .frm-button-secondary:hover,#frm_testmode_disable_required_fields_modal .frm-button-secondary:hover,#frm_ai_autofill_error_modal .frm-button-secondary:hover{border-color:var(--grey-300) !important;color:var(--grey-800);background:var(--grey-50) !important;box-shadow:none !important;outline:none !important}#frm_testing_mode a,#frm_testmode_disable_required_fields_modal a,#frm_ai_autofill_error_modal a{text-decoration:none}#frm_testmode_disable_required_fields_modal p{font-size:16px}#frm_test_mode_pagination{display:inline-block;margin-left:var(--gap-xs)}#frm_test_mode_pagination input[type=button]{border:1px solid var(--grey-300);padding:8px 12px;border-radius:8px;font-size:12px;background-color:#fff}#frm_test_mode_pagination input[type=button].frm_test_mode_active_page{background-color:var(--primary-500);border-color:var(--primary-500);color:#fff}#frm_test_mode_pagination input[type=button]:not(.frm_noallow){cursor:pointer}#frm_testmode_start_over{position:absolute;right:20px;top:20px;background-color:#fff;color:var(--grey-800);border-radius:20px;padding:4px 12px;border-color:var(--grey-300);font-weight:600}#frm_testmode_start_over img{vertical-align:middle;position:relative;bottom:2px}.frm_noallow{opacity:.5}#frm_testmode_enabled_form_actions_container{vertical-align:middle;display:inline-block;max-width:200px}#frm_testmode_upgrade{padding:var(--gap-xs) var(--gap-sm);text-align:center;font-size:var(--text-xs);margin-top:var(--gap-sm);line-height:var(--text-xs);font-weight:500;text-decoration:none;display:block;margin-left:-20px;margin-right:-20px;margin-bottom:-16px;border-radius:0 0 16px 16px}.frm_warning_style:has(.frm-addon-button){display:flex;padding:var(--gap-sm);line-height:40px}.frm_warning_style .frm-addon-button,#frm_upgrade_modal a.frm-button-primary{text-decoration:none}#frm_upgrade_modal a.frm-button-primary{cursor:pointer}.frm-dialog{z-index:1001}.frm-dialog+.ui-widget-overlay{z-index:1000}@media(max-width: 1024px){#frm_testing_mode>div>label:not(#frm_quick_jump_label){width:100%;display:block !important;margin-left:0 !important}#frm_testing_mode>div>label:not(#frm_quick_jump_label){margin-top:var(--gap-sm)}#frm_testmode_fill_in_empty_form_fields{display:block}#frm_testing_mode>div:nth-of-type(2){flex-direction:column;align-items:normal}#frm_test_mode_pagination{margin-left:0}} + */ +.tooltip { + /* Copied from Bootstrap */ + position: absolute; + display: block; + margin: 0; + font-style: normal; + font-weight: 400; + line-height: 1.5; + text-align: left; + text-align: start; + text-decoration: none; + text-shadow: none; + text-transform: none; + letter-spacing: normal; + word-break: normal; + word-spacing: normal; + white-space: normal; + line-break: auto; + font-size: 0.875rem; + word-wrap: break-word; + opacity: 0; + /* Custom rules */ + z-index: 9999999; + pointer-events: none; +} + +.tooltip.show { + opacity: 0.9; +} + +.tooltip .arrow { + position: absolute; + display: block; + width: 0.8rem; + height: 0.4rem; + margin-left: 0 !important; +} + +.tooltip .arrow::before { + position: absolute; + content: ""; + border-color: transparent; + border-style: solid; +} + +.bs-tooltip-top, +.bs-tooltip-auto[x-placement^=top] { + padding: 0.4rem 0; +} + +.bs-tooltip-top .arrow, +.bs-tooltip-auto[x-placement^=top] .arrow { + bottom: 0; +} + +.bs-tooltip-top .arrow::before, +.bs-tooltip-auto[x-placement^=top] .arrow::before { + top: 0; + border-width: 0.4rem 0.4rem 0; + border-top-color: #000; +} + +.bs-tooltip-right, +.bs-tooltip-auto[x-placement^=right] { + padding: 0 0.4rem; +} + +.bs-tooltip-right .arrow, +.bs-tooltip-auto[x-placement^=right] .arrow { + left: 0; + width: 0.4rem; + height: 0.8rem; +} + +.bs-tooltip-right .arrow::before, +.bs-tooltip-auto[x-placement^=right] .arrow::before { + right: 0; + border-width: 0.4rem 0.4rem 0.4rem 0; + border-right-color: #000; +} + +.bs-tooltip-bottom, +.bs-tooltip-auto[x-placement^=bottom] { + padding: 0.4rem 0; +} + +.bs-tooltip-bottom .arrow, +.bs-tooltip-auto[x-placement^=bottom] .arrow { + top: 0; +} + +.bs-tooltip-bottom .arrow::before, +.bs-tooltip-auto[x-placement^=bottom] .arrow::before { + bottom: 0; + border-width: 0 0.4rem 0.4rem; + border-bottom-color: #000; +} + +.bs-tooltip-left, +.bs-tooltip-auto[x-placement^=left] { + padding: 0 0.4rem; +} + +.bs-tooltip-left .arrow, +.bs-tooltip-auto[x-placement^=left] .arrow { + right: 0; + width: 0.4rem; + height: 0.8rem; +} + +.bs-tooltip-left .arrow::before, +.bs-tooltip-auto[x-placement^=left] .arrow::before { + left: 0; + border-width: 0.4rem 0 0.4rem 0.4rem; + border-left-color: #000; +} + +.tooltip-inner { + max-width: 200px; + padding: 0.25rem 0.5rem; + color: #fff; + text-align: center; + background-color: #000; + border-radius: 0.25rem; +} + +.frm-dropdown-menu.show { + display: block; +} + +.frm-single-settings .frm-dropdown-menu.show { + background: #fff; +} + +/* End Bootstrap */ +.preview.dropdown .dropdown-menu { + min-width: 205px; +} + +.frm_clear { + clear: both; +} + +.frm_clearfix::after { + content: "."; + display: block; + clear: both; + visibility: hidden; + line-height: 0; + height: 0; +} + +.frm_clearfix { + display: block; +} + +.frm_admin_progress { + overflow: hidden; + height: 20px; + margin-bottom: 20px; + background-color: #f5f5f5; + border-radius: 4px; + box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1); +} + +.frm_admin_progress_bar { + float: left; + width: 0; + height: 100%; + font-size: 12px; + line-height: 20px; + color: #fff; + text-align: center; + box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15); + transition: width 0.6s ease; + background-color: #04a4cc; +} + +.tooltip.frm_tooltip { + position: fixed; + top: auto !important; + bottom: 0 !important; + left: 0 !important; + max-width: none; + width: 100% !important; + z-index: 99999; +} + +.tooltip.frm_tooltip.bottom { + padding: 0; +} + +.frm_tooltip .tooltip-inner { + max-width: none; + min-height: 40px !important; + text-align: left; + box-shadow: 5px 5px 25px rgba(0, 0, 0, 0.5); + padding: 10px 40px; + border-top-color: #ccc; + background: var(--sidebar-color); + color: var(--grey-700); + border-radius: 0; + opacity: 1; + font-size: var(--text-sm); +} + +#frm_custom_css_box { + width: 100%; +} + +/** + * Components - Dropdown + */ +/*Switch form dropdown*/ +h1 .fa-caret-down { + font-size: 18px; +} + +.caret { + display: inline-block; + width: 19px; + height: 9px; + margin-right: -8px; + vertical-align: middle; +} + +.caret, +.wp-admin .frm_wrap select, +.frm_wrap .frm_form_builder select, +.frm_wrap .ui-autocomplete-input { + background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; + padding-right: var(--gap-lg) !important; +} + +.caret { + padding-right: var(--gap-xs) !important; + background-position-x: 5px; +} + +.frm-btn-group .caret { + float: right; + margin-top: calc(var(--text-md) / 2); +} + +.dropdown { + position: relative; +} + +.dropdown-toggle:focus { + outline: 0; +} + +.frm_wrap .ui-autocomplete, +#frm_adv_info.frm-dropdown-menu, +.frm-dropdown-menu { + /* Copied from .dropdown-menu rules from Bootstrap */ + position: absolute; + top: 100%; + left: 0; + z-index: 1000; + display: none; + padding-left: 4px; + padding-right: 4px; + margin: var(--gap-xs) 0 0; + text-align: left; + list-style: none; + background: none; + background-color: #fff; + background-clip: padding-box; + border: 1px solid var(--grey-100); + border-radius: 0.25rem; + box-shadow: var(--box-shadow-lg); + /* Custom rules */ + max-height: 200px; + overflow-y: auto; + overflow-x: hidden; + font-size: var(--text-md); + width: auto; + min-width: 160px; +} + +.frm6 .frm-dropdown-menu { + min-width: 100px; + max-width: 99%; +} + +#frm_bs_dropdown .frm-dropdown-menu { + max-width: 400px; +} + +.field_type_list .frm-dropdown-menu { + min-width: 150px !important; +} + +#frm_field_group_controls .frm-dropdown-menu, +.frm-field-action-icons .frm-dropdown-menu { + min-width: 180px !important; +} + +.frm-field-action-icons .frm-dropdown-toggle svg, +#frm_field_group_controls .frm-dropdown-toggle svg { + color: #9ea9b8; +} + +.multiselect-container.frm-dropdown-menu, +#search-submit .frm-dropdown-menu { + min-width: 200px !important; +} + +.preview .frm-dropdown-menu { + min-width: 230px !important; +} + +.frm-dropdown-menu.dropdown-menu-right { + right: 0; + left: auto; +} + +.frm-dropdown-menu .divider { + height: 1px; + margin: 9px 0; + overflow: hidden; + background-color: #e5e5e5; +} + +.frm-dropdown-menu > .dropdown-item { + margin: 0; +} + +.frm-select-list-item, +.frm_wrap .ui-autocomplete li > div, +.multiselect-container button.multiselect-option, +.frm-dropdown-menu > .dropdown-item > a, +.frm-dropdown-menu .frm_dropdown_li { + clear: both; + font-weight: 400; + white-space: nowrap; + text-decoration: none; + border-radius: var(--small-radius); +} + +.frm-dropdown-menu > .active > a, +.frm-dropdown-menu > .active > a:hover, +.frm-dropdown-menu > .active > a:focus { + text-decoration: none; + outline: 0; +} + +.frm-select-list-item.disabled, +.frm-dropdown-menu > .disabled > a, +.frm-dropdown-menu > .disabled > a:hover, +.frm-dropdown-menu > .disabled > a:focus { + color: #999; +} + +.frm-select-list-item.disabled:hover, +.frm-dropdown-menu > .disabled > a:hover, +.frm-dropdown-menu > .disabled > a:focus { + text-decoration: none; + background-color: transparent; + background-image: none; + cursor: not-allowed; +} + +.open > .frm-dropdown-menu { + display: block; +} + +.open > a { + outline: 0; +} + +.dropdown-header { + display: block; + padding: 3px 10px; + font-size: var(--text-xs); + color: var(--grey-400); +} + +.dropdown-backdrop { + position: fixed; + left: 0; + right: 0; + bottom: 0; + top: 0; + z-index: 990; +} + +.dropdown-menu-right > .frm-dropdown-menu, +.pull-right > .frm-dropdown-menu { + right: 0; + left: auto; +} + +.navbar-fixed-bottom .dropdown .caret { + border-top: 0 dotted; + border-bottom: 4px solid #000; + content: ""; +} + +.navbar-fixed-bottom .dropdown .frm-dropdown-menu { + top: auto; + bottom: 100%; + margin-bottom: 1px; +} + +.btn { + border: 1px solid #ddd; + background: #fff; + height: 28px; + line-height: var(--leading); +} + +a.frm_option_icon::before { + color: var(--primary-500); + font-size: 22px; + width: 22px; + height: 22px; +} + +a.frm_option_icon:focus::before, +a.frm_option_icon:hover::before { + color: var(--primary-700); +} + +.frm_top_left .frm-dropdown-toggle { + color: #999; +} + +.frm-card ol { + margin-left: 15px; +} + +.frm-dropdown-toggle { + text-decoration: none; +} + +.frm-card .frm-dropdown-toggle { + border: 1px solid var(--grey-300); + border-radius: var(--small-radius); + font-size: 13px; + color: var(--grey-700); + padding: 7px 20px; +} + +.frm-dropdown-menu .frm_icon_font { + vertical-align: middle; + color: #5f6c72; + margin-right: 3px; +} + +/* BS Multiselect */ +.multiselect-container.frm-dropdown-menu { + top: auto; + left: auto; + font-size: var(--text-sm); + padding: 4px; + margin-bottom: 3px; +} + +/** + * Components - Multiselect + */ +.multiselect-container { + position: absolute; + list-style-type: none; + margin: 0; + padding: 0; + width: 100%; + max-width: 250px; +} + +.multiselect-container button.multiselect-option { + width: 100%; + text-align: left; + border: none; + margin-bottom: 4px; +} + +.multiselect-container button.multiselect-option label { + margin-left: 5px; +} + +.accordion-container .multiselect-container label { + padding: 3px 19px 3px 7px; +} + +.frm-btn-group.btn-group > .btn-group:nth-child(2) > .multiselect.btn { + border-top-left-radius: 4px; + border-bottom-left-radius: 4px; +} + +.frm-btn-group.btn-group, +.frm-btn-group.btn-group-vertical { + display: block; +} + +.multiselect-option label { + max-width: calc(100% - 22px); + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; +} + +/** + * Field multiselect popup + */ +#frm_field_multiselect_popup { + background: white; + height: 48px; + position: fixed; + border-radius: 4px; + box-shadow: 0 8px 24px rgba(40, 47, 54, 0.15); + color: rgba(40, 47, 54, 0.85); + font-size: 13px; + right: 30px; + bottom: 10px; + z-index: 2; +} + +#frm_field_multiselect_popup > div { + display: inline-block; + line-height: 48px; + vertical-align: top; +} + +#frm_field_multiselect_popup.frm-unmergable > .frm-merge-fields-into-row, +#frm_field_multiselect_popup.frm-unmergable > .frm-multiselect-popup-separator { + display: none; +} + +#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator) { + padding: 0 20px; + cursor: pointer; +} + +#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator):hover { + background: rgba(245, 245, 245, 0.9607843137); +} + +.frm-builder-popup-heading { + font-weight: 600; + font-size: 11px; + line-height: 15px; + text-transform: uppercase; + color: rgba(40, 47, 54, 0.45); + margin-bottom: 7px; +} + +.frm-builder-popup-subheading { + font-size: 12px; + line-height: 16px; + color: rgba(40, 47, 54, 0.45); +} + +#frm_field_group_popup input[type=text] { + height: 30px; + border-radius: 3px; + font-size: 14px; + padding: 8px; + color: rgb(84, 95, 110); + border-color: rgba(40, 47, 54, 0.2); +} + +.frm-multiselect-popup-separator { + height: 36px; + width: 1px; + position: relative; + top: 6px; + background: #c4c4c4; +} + +.frm-sortable-helper, +.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider) { + pointer-events: none; +} + +.frm-sortable-helper { + /* Make sure the item being dragged appears above other form builder fields */ + z-index: 99; +} + +/** + * Component: Code List + */ +.frm_code_list a.button { + display: block; + text-align: center; + font-size: 11px; + overflow: hidden; +} + +#frm-navbarDrop + .frm_code_list.frm-full-hover { + margin: var(--gap-xs) 0 0; + min-width: 300px; + max-height: 256px; +} + +.frm_code_list.frm-full-hover li { + margin: 0; +} + +.frm-select-list-item, +.frm_wrap .ui-autocomplete li > div, +.multiselect-container button.multiselect-option, +.frm-dropdown-menu > .dropdown-item > a, +.frm-dropdown-menu > .dropdown-item > a:visited, +.frm-dropdown-menu > .dropdown-item > a:link, +.frm-dropdown-menu .frm_dropdown_li, +.frm_code_list.frm-full-hover a { + display: flex; + color: var(--grey-700); + padding: 5px 10px; + font-size: var(--text-md); + gap: var(--gap-xs); + align-items: center; +} + +.multiselect-container button.multiselect-option.disabled { + opacity: 0.5; +} + +.frm_code_list.frm-full-hover a span { + max-width: 83px; + margin-right: var(--gap-xs); + margin-left: auto; +} + +.frm_code_list.frm-full-hover a { + border-radius: var(--small-radius); +} +.frm_code_list.frm-full-hover a:not(#frm-insert-condition), +.frm_code_list.frm-full-hover a span { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} +.frm_code_list.frm-full-hover a:focus span:last-child { + outline: 1px solid var(--primary-500); + outline-offset: var(--gap-2xs); +} + +.frm_code_list.frm-full-hover.frmcenter a { + display: block; +} + +#frm-layout-classes frm-full-hover a span { + max-width: 45%; +} + +.frm-select-list-item.active, +.frm-select-list-item:hover, +.frm_wrap .ui-autocomplete li div.ui-state-active, +.frm_wrap .ui-autocomplete li.ui-state-focus, +.multiselect-container button.multiselect-option.active, +.multiselect-container button.multiselect-option:hover, +.frm-dropdown-menu > .dropdown-item > a:hover, +.frm_code_list.frm-full-hover a:hover span, +.frm_code_list.frm-full-hover a:hover { + background: var(--primary-25); + color: var(--primary-500); +} + +.frm-select-list-item .frmsvg, +.frm-dropdown-menu > .dropdown-item > a .frmsvg { + opacity: 0.8; +} + +.frm-select-list-item:hover .frmsvg, +.frm-dropdown-menu > .dropdown-item > a:hover .frmsvg { + opacity: 1; +} + +.frm-dropdown-menu.frm_code_list > li > a { + padding: 3px 15px; + width: 300px; +} + +#frm_edit_box_content_modal .frm-with-search, +.frm-dropdown-menu .frm-with-search { + padding: var(--gap-xs) 10px 0; +} + +.frm-dropdown-menu .subsubsub { + padding: 0 10px; +} + +.frm_grid_container { + overflow: visible; +} + +.frm_code_list.frm_grid_container { + grid-gap: var(--gap-xs); +} + +.frm_code_list.frm_grid_container li { + width: auto; + margin: 0; +} + +.frm_code_list.frm_grid_container a { + display: block; + font-size: var(--text-md) !important; + font-weight: 500; + text-align: center; + color: var(--primary-500); + background-color: var(--light-blue); + border: 1px solid var(--primary-300); + border-radius: var(--small-radius); + padding: 10px 0; + box-shadow: var(--box-shadow-sm); +} +.frm_code_list.frm_grid_container a:hover { + background-color: var(--primary-500); + color: #fff; +} +.frm_code_list.frm_grid_container a:focus-visible { + outline: 2px solid var(--primary-500); + outline-offset: -1px; +} + +.frm-single-settings .frm_code_list.frm-full-hover, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { + padding: 0; + margin: var(--gap-xs) -10px 0; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a { + font-size: var(--text-md); + color: var(--grey-900); + padding: var(--gap-xs) 12px; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a span, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span { + margin: 0; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a span:first-child, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:first-child { + max-width: 130px; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a span:last-child, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:last-child { + max-width: 120px; + margin-left: auto; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover { + font-weight: 500; +} +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover .frmsvg, +.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover span, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover .frmsvg, +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover span { + color: var(--primary-500); +} + +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { + margin: var(--gap-xs) 0 0; +} +#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg { + width: 20px; + height: 20px; +} + +/** + * Accordion + */ +#post-body-content + .frm-right-panel h3.accordion-section-title { + padding: 7px 10px 8px 14px; + font-size: var(--text-md); + color: var(--grey-700); +} + +.frm-with-line, +.accordion-section-content h4 { + font-size: var(--text-md); + font-weight: 400; + margin: 20px -20px 10px; + padding: 0 20px; + color: var(--grey-700); + position: relative; + border: none !important; +} + +.frm-with-line span, +.accordion-section-content h4 span { + background: #fff; + padding: 0 var(--gap-xs); + position: relative; + display: inline-block; + z-index: 2; +} + +.accordion-section-content h4 span { + background: var(--sidebar-color); +} + +.frm-right-panel .frm-with-line span { + background: var(--sidebar-color) !important; + margin-left: -4px; +} + +.frm-right-panel .frm-inline-modal .frm-with-line span { + background: #fff !important; +} + +.frm-with-line::before, +.accordion-section-content h4::before { + content: ""; + display: block; + position: absolute; + border-bottom: 1px solid var(--grey-300); + left: 0; + width: 100%; + top: 50%; +} + +.control-section .accordion-section-title::after, +.customize-pane-child .accordion-section-title::after { + top: 15px; +} + +.accordion-container .frm-dropdown-menu { + min-width: 40px; +} + +.frm-btn-group .multiselect.dropdown-toggle { + box-sizing: border-box; + min-height: unset; + cursor: pointer; +} + +.accordion-container .frm-dropdown-menu::before, +.accordion-container .multiselect.dropdown-toggle::before { + font-family: "s11-fp" !important; +} + +/** + * Search Inputs + */ +.frm-search input[name=s], +.frm-search .dropdown-toggle, +.frm-search input.frm-search-input { + color: var(--grey-800); + border-color: var(--grey-300); + border-radius: var(--small-radius); + box-shadow: var(--box-shadow-xs); +} +.frm-search input[type=search], +.frm-search input[type=text] { + padding-left: var(--gap-lg) !important; +} +.frm-search .dropdown-toggle { + width: 100%; + float: none; + max-width: 200px; + background: transparent; + padding: 7px; + padding-left: 33px !important; + min-height: 32px; + text-align: inherit; + overflow: hidden; + text-overflow: ellipsis; +} +.frm-search #search-submit a { + color: var(--grey-800); +} +.frm-search #search-submit .caret { + opacity: 0.7; +} + +.frm-white-body .search-box input[name=s], +#wpwrap .frm-search input[type=search] { + flex: 1; + font-size: var(--text-md); + line-height: var(--text-xl); + padding: var(--gap-xs); +} + +span.multiselect-selected-text { + white-space: nowrap; + display: inline-block; + max-width: calc(90% - var(--gap-xs)); + text-overflow: ellipsis; + overflow: hidden; +} + +/** + * Component: Call-to-Action + */ +.frm_pro_tip, +.frm-cta { + justify-content: space-between; + align-items: center; + gap: var(--gap-2xl); + padding: var(--gap-xs) var(--gap-sm); + border-radius: var(--small-radius); + background: var(--primary-25); +} + +.frm-cta.frm-cta-border { + border: 1px solid var(--primary-200); +} + +.frm-cta.frm-cta-border .frm-cta-footer { + background-color: #fff; + padding: 12px var(--gap-sm); + border-top: 1px solid var(--primary-200); + border-bottom-left-radius: var(--small-radius); + border-bottom-right-radius: var(--small-radius); + margin-top: 12px; + margin-bottom: calc(-1 * var(--gap-sm)); + margin-left: calc(-1 * var(--gap-sm)); + margin-right: calc(-1 * var(--gap-sm)); +} + +.frm-cta h4 { + font-weight: 600; + margin-top: 0; + margin-bottom: var(--gap-2xs); +} + +.frm-cta-green { + background-color: var(--success-25); +} + +.frm-cta-green .frm-banner-title { + gap: calc(var(--gap-2xs) + 1px); + color: var(--grey-700); +} + +.frm-cta-green.frm-cta-border { + border-color: var(--success-100); +} + +.frm-cta-green.frm-cta-border .frm-cta-footer { + border-color: var(--success-100); +} + +.frm-cta-red { + background-color: var(--error-25); +} + +.frm-cta-red.frm-cta-border { + border-color: var(--error-100); +} + +.frm-cta-icon { + padding: 3px 15px 3px 0; + border-right: 1px solid currentColor; +} + +#frm-upgrade-banner { + gap: 0; +} + +#frm-upgrade-banner .frm-cta-icon + .frm-cta-content { + margin-right: auto; + padding-left: 15px; +} + +#frm-upgrade-banner.frm-gradient h4, +#frm-upgrade-banner.frm-gradient p { + color: currentColor; +} + +#frm-upgrade-banner.frm-gradient h4 { + font-size: 16px; + font-weight: 600; +} + +#frm-upgrade-banner.frm-gradient p { + font-size: 14px; +} + +.frm-right-panel .inside .frm_pro_tip, +.frm_pro_tip { + color: var(--grey-700); + background: #ffe7de; + margin: 0 auto; + display: flex; + gap: var(--gap-xs); +} + +.frm_field_list .frm_pro_tip { + margin: 10px 15px; + position: relative; + width: calc(100% - 30px); + box-sizing: border-box; + font-size: 14px; +} + +.frm_pro_tip .frmsvg, +.frm_pro_tip i { + color: var(--orange); +} + +.frm-tip-info { + flex: 1; + text-align: left; +} + +.frm-tip-cta { + color: var(--orange); +} + +.frm-gradient .frm-tip-cta, +.frm-light-tip .frm-gradient .frm-tip-cta { + color: currentColor; + font-weight: 700; +} + +.frm-tip-badge { + font-size: 9px; + font-weight: 700; + text-transform: uppercase; + color: #1e63d5; + background-color: #fff; + line-height: 1; + border-radius: 4px; + padding: 3px 4px; +} + +.frm-light-tip .frm_pro_tip { + background: var(--primary-25); +} + +.frm-light-tip .frm_pro_tip .frmsvg, +.frm-light-tip .frm_pro_tip i, +.frm-light-tip .frm-tip-cta { + color: var(--primary-500); +} + +.nav-tab-wrapper .frm_pro_tip { + float: right; +} + +/** + * Components - Upgrade Bar + */ +.frm-gradient, +.frm-upgrade-bar { + background: linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important; + color: #fff !important; + border: 0 !important; +} + +.frm-gradient.frm-button-primary:not([disabled]), +.frm-gradient.frm-button-primary:not([disabled]):hover, +.frm-gradient.frm-button-primary:not([disabled]):focus { + background: linear-gradient(90deg, #1961d5, #816cfa) !important; +} + +.frm-upgrade-bar, +.frm-gradient { + position: relative; +} + +.frm-upgrade-bar::before, +.frm-gradient::before { + content: ""; + display: none; + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + background-color: rgba(255, 255, 255, 0.1); + z-index: 0; +} + +.frm-upgrade-bar:hover::before, +.frm-gradient:hover::before, +.frm-gradient:focus::before { + display: block; +} + +.frm-upgrade-bar-inner, +.frm-gradient > * { + position: relative; + z-index: 1; +} + +.frm-upgrade-bar { + border-bottom: 1px solid var(--sidebar-hover); + padding: 9px 0; + font-size: 12px; + text-align: center; +} + +.frm-upgrade-bar a { + color: currentColor !important; + text-decoration: underline; +} + +.frm-upgrade-bar a:focus { + outline: 1px dotted var(--sidebar-hover); +} + +.frm-upgrade-bar span { + opacity: 0.9; +} + +/** + * Components - Message Styles + */ +.toplevel_page_formidable #wpbody-content > .error { + margin: 1px; + padding: 5px 12px; +} + +.frm_error_style, +.frm_warning_style, +.frm_note_style2, +.frm_note_style, +.frm_message, +#post-body-content .frm_updated_message, +div.frm_updated_message { + border-radius: var(--small-radius); + background-color: #d5f2dc; + color: #1e561f; + padding: var(--gap-sm) var(--gap-md); + font-size: var(--text-sm); + margin: var(--gap-sm) 0; + text-align: left; +} + +.frm_note_style2 { + background: linear-gradient(90deg, #e9effa, #fcf6fe) padding-box, linear-gradient(90deg, #1961d5, #e8abef) border-box; + border: 1px solid transparent; +} + +#frm_top_bar + .wrap > .frm_updated_message, +#frm_top_bar + .wrap > .frm_warning_style { + display: inline-block; + width: 100%; + box-sizing: border-box; +} + +#post-body-content > .frm_updated_message { + margin: 5px 65px; +} + +#form_global_settings #post-body-content > .frm_updated_message, +#form_global_settings #post-body-content > .frm_warning_style { + margin: 5px 25px; +} + +.frm_error_style { + color: #973937; + background-color: #ebcccc; + clear: both; +} + +.frm_error_style a { + text-decoration: underline; + font-weight: 600; +} + +.frm_error_style svg { + opacity: 0.7; +} + +.frm_warning_style { + color: #7a4d05; + background-color: #fff2d2; +} + +.frm_warning_heading { + font-weight: 700; + margin-bottom: 4px; +} + +/* Warning message dismiss */ +.frm_warning_style { + position: relative; + padding-right: calc(var(--gap-md) + 15px); +} + +body.rtl .frm_warning_style { + padding-right: var(--gap-md); + padding-left: calc(var(--gap-md) + 15px); +} + +.frm-warning-dismiss { + position: absolute; + top: 10px; + right: 10px; + display: flex; + cursor: pointer; + transition: opacity 0.2s ease-out; +} + +body.rtl .frm-warning-dismiss { + left: 10px; + right: auto; +} + +.frm-warning-dismiss:hover { + opacity: 0.8; +} + +.frm-warning-dismiss.frmsvg, +.frm-warning-dismiss.frmsvg svg { + width: 15px; + height: 15px; +} + +.frm_note_style { + background: rgba(188, 224, 253, 0.23); + color: var(--grey-700); +} + +.frm-banner-alert { + text-align: left; + margin: 0; + border-radius: 0; + padding: 10px 0 10px 40px; +} + +.frm-banner-alert a { + color: var(--primary-500); + font-weight: 400; + text-decoration: none; +} + +.frm_updated_message ul, +.frm_updated_message li, +.frm_warning_style ul, +.frm_warning_style li, +.frm_error_style ul, +.frm_error_style li { + margin: 0; +} + +.frm-inline-message { + border: 1px solid var(--primary-700); + border-radius: var(--small-radius); + color: var(--primary-700); + background: #fff; + text-align: center; + padding: 20px; + font-size: var(--text-sm); + line-height: var(--leading); +} + +.frm-inline-message a { + text-decoration: underline; + font-weight: 600; + color: var(--primary-700); +} + +.frm_pro_heading span { + margin-top: 10px; +} + +.frm_pro_heading .alignright { + text-align: right; +} + +.frm-yes { + color: var(--green); + font-size: var(--text-xl); +} + +.frm-nope { + color: var(--grey-400); + font-size: var(--text-xl); +} + +/** + * Components - Modal + */ +.frm-modal:not(#frm-dismissable-cta) .postbox { + max-height: 600px; + overflow: hidden; + margin-bottom: 0; +} + +.frm-modal .postbox .frm_modal_top, +.frm-dialog .frm_common_modal .postbox > div:first-child, +.frm-error-modal .frm_modal_top { + padding: var(--gap-md) var(--gap-md) 0; + position: relative; +} + +.frm-modal h2, +.frm-modal .postbox .inside h2, +.frm-modal .postbox .frm-modal-title, +.frm-dialog .frm_common_modal .postbox > div:first-child > div:first-child, +.frm-error-modal .frm-modal-title { + display: inline-block; + font-size: var(--text-lg); + color: var(--grey-900); + font-weight: 600; + margin: 0; + padding: 0; +} + +.frm-modal h3 { + font-weight: 500; +} + +/* Dismiss icon button */ +.frm-inline-modal > a.dismiss, +.frm-modal .postbox > a.dismiss, +.frm-modal .postbox .frm-modal-title + div:last-child, +.frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { + position: absolute; + top: 19px; + right: 19px; + display: flex; + z-index: 2; +} + +body.rtl .frm-inline-modal > a.dismiss, +body.rtl .frm-modal .postbox > a.dismiss, +body.rtl .frm-modal .postbox .frm-modal-title + div:last-child, +body.rtl .frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { + right: unset; + left: 30px; +} + +.frm-info-modal .postbox > a.dismiss, +.frm-inline-modal > a.dismiss { + right: 13px; + top: 13px; +} + +.frm-modal .postbox .frm-modal-title + div:last-child a, +.frm-modal a.dismiss .frmsvg, +.frm_common_modal .frm_modal_top a .frmsvg { + color: var(--grey-500); +} + +.frm-modal .postbox .frm-modal-title + div:last-child a:hover, +.frm-modal a.dismiss .frmsvg:hover, +.frm_common_modal .frm_modal_top a .frmsvg:hover { + color: var(--grey-700); +} + +.frm-modal .frm_modal_content > div.inside, +.frm_common_modal .frm_modal_content > div.inside { + padding: var(--gap-md); + margin: 0; + font-size: var(--text-sm); + color: var(--grey-700); +} + +.frm-modal p { + color: var(--grey-900); +} + +.frm_common_modal .postbox { + display: flex; + flex-direction: column; +} + +.frm-modal .postbox > div.inside .cta-inside { + overflow-y: auto; + height: auto; +} + +.frm_modal_footer { + padding: 0 var(--gap-md) var(--gap-sm); + text-align: right; +} + +body.frm-body-with-open-modal { + overflow-y: hidden; +} + +/** + * Component: Dialog + */ +.frm-dialog { + z-index: 100; + padding: 0 !important; + border-radius: 16px; + border: none; + background-color: #fff; + max-width: 100% !important; +} + +.frm-dialog .postbox { + background: transparent; + box-shadow: none; + border: none; + line-height: var(--leading); +} + +.frm-dialog input[type=text], +.frm-dialog textarea { + font-size: var(--text-md); +} + +.frm-dialog textarea { + height: 75px; +} + +.frm-dialog button.frm-button-primary { + margin-right: 10px; +} + +.frm-dialog .frm-sub-label, +.frm-sub-label { + color: var(--grey); + text-transform: none; + padding-left: 8px; +} + +h2 .frm-sub-label { + font-size: var(--text-md); +} + +.frm-views-editor-body .ui-widget-overlay, +.frm-white-body .ui-widget-overlay, +.toplevel_page_formidable .ui-widget-overlay, +body[class*=formidable-payments] .ui-widget-overlay, +body.plugins-php .ui-widget-overlay { + position: fixed; + width: 100%; + height: 100%; + top: 0; + left: 0; + right: 0; + bottom: 0; + background: var(--grey-500); + opacity: 0.5; + z-index: 2; +} + +/** + * Component: Circled Icons + */ +.frm-circled-icon { + width: 60px; + height: 60px; + border-radius: 50%; + background-color: var(--primary-25); +} + +.frm-circled-icon-large { + width: 80px; + height: 80px; +} + +.frm-circled-icon-green { + background-color: var(--success-50); +} + +.frm-circled-icon .frmsvg { + width: 21px; + height: 24px; +} +.frm-circled-icon .frmsvg.frm_svg32 { + width: 32px !important; + height: 32px !important; +} + +.frm-circled-icon-large .frmsvg { + width: 24px; +} + +.frm-circled-icon .frmsvg use { + color: var(--primary-500); +} + +.frm-circled-icon-green .frmsvg use { + color: var(--success-500); +} + +.frm-border-icon { + display: flex; + align-items: center; + justify-content: center; + width: 40px; + height: 40px; + border: 1px solid var(--grey-300); + border-radius: var(--small-radius); +} + +.frm-upgrade-message img { + max-width: 100%; +} + +/** + * Utilities - Flex + */ +.frm-inline-flex, +#wpbody-content .frm-inline-flex { + display: inline-flex; +} + +.frm-flex { + display: flex; +} + +.frm-force-flex { + display: flex !important; +} + +.frm_hidden, +.js .frm-hide-js { + display: none; +} + +.frm-flex-box { + display: flex; + gap: var(--gap-sm); +} + +.frm-flex-col { + display: flex; + flex-direction: column; +} + +.frm-flex-full { + flex: 1; +} + +.frm-force-flex-center, .frm-flex-center { + justify-content: center; + align-items: center; +} + +.frm-flex-center { + display: flex; +} + +.frm-force-flex-center { + display: flex !important; +} + +.frm-shrink-0 { + flex-shrink: 0; +} + +.frm-gap-0 { + gap: 0 !important; +} + +.frm-gap-2xs { + gap: var(--gap-2xs); +} + +.frm-gap-xs { + gap: var(--gap-xs); +} + +.frm-gap-sm { + gap: var(--gap-sm); +} + +.frm-gap-md { + gap: var(--gap-md); +} + +.frm-gap-xl { + gap: var(--gap-xl); +} + +.frm-justify-start { + justify-content: start !important; +} + +.frm-justify-center { + justify-content: center !important; +} + +.frm-justify-between { + justify-content: space-between; +} + +.frm-justify-end { + justify-content: end; +} + +.frm-items-start { + align-items: flex-start; +} + +.frm-items-center { + align-items: center; +} + +.frm-items-stretch { + align-items: stretch; +} + +.frm-self-normal { + align-self: normal; +} + +#wpbody-content .frm-flex-wrap { + flex-wrap: wrap; +} + +.frm-grow { + flex-grow: 1; +} + +.frm-order-first { + order: -9999; +} + +.frm-order-last { + order: 9999; +} + +.frm-order-none { + order: 0; +} + +.frm-h-stack-sm, .frm-h-stack-xs, .frm-h-stack { + display: flex !important; + align-items: center; +} +.frm-h-stack-sm > input[type=checkbox], .frm-h-stack-xs > input[type=checkbox], .frm-h-stack > input[type=checkbox], +.frm-h-stack-sm > input[type=radio], +.frm-h-stack-xs > input[type=radio], +.frm-h-stack > input[type=radio] { + margin: 0 !important; +} + +.frm-h-stack { + gap: var(--gap-2xs); +} + +.frm-h-stack-xs { + gap: var(--gap-xs); +} + +.frm-h-stack-sm { + gap: var(--gap-sm); +} + +.frm-flex-row-reverse { + flex-direction: row-reverse; +} + +/** + * Component: Info Modals + */ +.frm-info-modal a, +.frm-info-modal ul, +.frm-info-modal p, +.frm-info-modal, +.settings-lite-cta a, +.settings-lite-cta ul, +.settings-lite-cta { + color: var(--grey-500); + font-size: var(--text-md); + box-shadow: none !important; +} + +.frm-info-modal h3, +.settings-lite-cta h3 { + font-size: 17px !important; +} + +.frm-green-icons .frmsvg { + color: var(--green); +} + +.frm-info-modal .postbox .inside, +.settings-lite-cta .postbox .inside { + padding: var(--gap-md); + margin: 0; +} + +.cta-inside a { + color: var(--orange); +} + +.info-modal-inside a.frm-standard-link { + color: var(--primary-500); +} + +.info-modal-inside a.frm-standard-link:hover { + color: var(--primary-700); +} + +.frm_no_p_margin > p { + margin: 0; +} + +/** + * Components - Loading + */ +.frm_spinner.frm-wait, +.frm_spinner.spinner { + float: left; + visibility: hidden; + margin: 0 10px; +} + +.frm_visible_spinner.frm-wait, +.frm_visible_spinner.spinner { + visibility: visible; + float: none; +} + +.frm_form_action_settings .frm_spinner.frm-wait, +.frm_form_action_settings .frm_spinner.spinner { + visibility: visible; + float: none; + vertical-align: bottom; +} + +.frm_form_action_settings .frm_loading { + font-size: 15px; + text-align: center; +} + +.frm_ajax_settings_tab .frm-wait, +.frm_ajax_settings_tab .spinner { + visibility: visible; + float: none; + margin-top: 20px; +} + +.wp-core-ui .frm_loading_button.button-primary.frm-button-primary, +.frm_loading_button, +.frm_loading_form.frm_button_submit { + position: relative !important; + opacity: 0.8; + color: transparent !important; + text-shadow: none !important; +} + +.frm_loading_button:hover, +.frm_loading_button:active, +.frm_loading_button:focus, +.frm_loading_form.frm_button_submit:hover, +.frm_loading_form.frm_button_submit:active, +.frm_loading_form.frm_button_submit:focus { + cursor: not-allowed; + color: transparent !important; + outline: none !important; + box-shadow: none; +} + +.frm-wait { + margin: 20px; + width: 20px; + height: 20px; + position: relative; + display: inline-block; +} + +#frm-show-fields .frm-wait:only-child { + position: absolute; + left: 50px; + top: 30px; +} + +.frm-wait::before, +.frm_loading_button::before, +.frm_loading_form.frm_button_submit::before { + content: ""; + display: inline-block; + position: absolute; + background: transparent; + border: 1px solid #fff; + border-top-color: transparent; + border-left-color: transparent; + border-radius: 50%; + box-sizing: border-box; + top: 50%; + left: 50%; + margin-top: -10px; + margin-left: -10px; + width: 20px; + height: 20px; + animation: spin 2s linear infinite; +} + +.frm-wait::before { + border-bottom-color: var(--primary-700); + border-right-color: var(--primary-700); +} + +.frm_loading_button.frm-button-secondary::before { + border-bottom-color: var(--primary-500); + border-right-color: var(--primary-500); +} + +input[type=submit]:focus { + outline: none !important; +} + +/* Effects */ +@keyframes spin { + 0% { + transform: rotate(0deg); + } + 100% { + transform: rotate(360deg); + } +} +.frmsvg { + fill: currentColor; + width: 18px; + height: 18px; + vertical-align: middle; +} + +body.frm_preview_page .ui-widget-overlay { + position: fixed; + width: 100%; + height: 100%; + top: 0; + left: 0; + right: 0; + bottom: 0; + background: var(--grey-500); + opacity: 0.5; + z-index: 2; +} + +#frm_testing_mode { + border-radius: 1rem; + background-color: #fff; + border-color: rgba(0, 0, 0, 0.1019607843); + border-width: 1px; + border-style: solid; + padding: 16px 20px; + margin-bottom: 40px; + position: relative; +} +#frm_testing_mode h2 { + font-size: 18px; + font-weight: 600; + color: rgb(0, 0, 0); + margin-bottom: 0; +} +#frm_testing_mode label { + font-size: 12px; + font-weight: 600; +} +#frm_testing_mode label span.frm_toggle_opt { + color: var(--grey-800); + font-weight: 600; +} +#frm_testing_mode label:not(:first-child) { + margin-left: var(--gap-xs); +} +#frm_testing_mode a.frm_button { + margin-left: auto; + border-radius: 20px; + font-size: 14px; +} +#frm_testing_mode hr { + color: unset; + background: var(--grey-200); + height: 1px; + border: none; +} +#frm_testing_mode > div:nth-of-type(2) { + display: flex; + align-items: center; +} +#frm_testing_mode .multiselect.dropdown-toggle::after { + border: none; +} +#frm_testing_mode .frmsvg { + width: 11px; + height: 11px; + margin-right: var(--gap-2xs); + position: relative; + top: 1px; +} +#frm_testing_mode .frm_toggle_block { + gap: var(--gap-xs); +} +#frm_testing_mode label:not(.frm_toggle_block) { + margin-right: 2px; +} +#frm_testing_mode select { + width: auto !important; + min-height: auto !important; + outline: 0; + box-shadow: var(--box-shadow-xs); + border-radius: var(--small-radius); + border-width: 1px; + padding: 5px 14px; + border-color: var(--grey-300); + color: var(--grey-800); + font-size: var(--text-md); + margin: 0; + line-height: var(--leading); + appearance: none; + background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; + padding-right: var(--gap-lg) !important; +} +#frm_testing_mode select:focus { + background-color: transparent !important; +} +#frm_testing_mode select, +#frm_testing_mode .btn-group button.multiselect.dropdown-toggle { + border-radius: var(--medium-radius); + font-size: 12px; + font-weight: 600; + height: 30px; +} +#frm_testing_mode .btn-group button.multiselect.dropdown-toggle { + padding-top: 0; + padding-bottom: 0; +} +#frm_testing_mode .multiselect-selected-text { + position: relative; + top: 2px; +} +#frm_testing_mode #frm_testmode_fill_in_empty_form_fields { + background-color: var(--primary-500); + color: #fff; + padding: 8px 18px; +} +#frm_testing_mode .frm_help { + vertical-align: top; +} + +#frm_testing_mode .frm-button-secondary:hover, +#frm_testmode_disable_required_fields_modal .frm-button-secondary:hover, +#frm_ai_autofill_error_modal .frm-button-secondary:hover { + border-color: var(--grey-300) !important; + color: var(--grey-800); + background: var(--grey-50) !important; + box-shadow: none !important; + outline: none !important; +} +#frm_testing_mode a, +#frm_testmode_disable_required_fields_modal a, +#frm_ai_autofill_error_modal a { + text-decoration: none; +} + +#frm_testmode_disable_required_fields_modal p { + font-size: 16px; +} + +#frm_test_mode_pagination { + display: inline-block; + margin-left: var(--gap-xs); +} +#frm_test_mode_pagination input[type=button] { + border: 1px solid var(--grey-300); + padding: 8px 12px; + border-radius: 8px; + font-size: 12px; + background-color: #fff; +} +#frm_test_mode_pagination input[type=button].frm_test_mode_active_page { + background-color: var(--primary-500); + border-color: var(--primary-500); + color: #fff; +} +#frm_test_mode_pagination input[type=button]:not(.frm_noallow) { + cursor: pointer; +} + +#frm_testmode_start_over { + position: absolute; + right: 20px; + top: 20px; + background-color: #fff; + color: var(--grey-800); + border-radius: 20px; + padding: 4px 12px; + border-color: var(--grey-300); + font-weight: 600; +} +#frm_testmode_start_over img { + vertical-align: middle; + position: relative; + bottom: 2px; +} + +.frm_noallow { + opacity: 0.5; +} + +#frm_testmode_enabled_form_actions_container { + vertical-align: middle; + display: inline-block; + max-width: 200px; +} + +#frm_testmode_upgrade { + padding: var(--gap-xs) var(--gap-sm); + text-align: center; + font-size: var(--text-xs); + margin-top: var(--gap-sm); + line-height: var(--text-xs); + font-weight: 500; + text-decoration: none; + display: block; + margin-left: -20px; + margin-right: -20px; + margin-bottom: -16px; + border-radius: 0 0 16px 16px; +} + +.frm_warning_style:has(.frm-addon-button) { + display: flex; + padding: var(--gap-sm); + line-height: 40px; +} + +.frm_warning_style .frm-addon-button, +#frm_upgrade_modal a.frm-button-primary { + text-decoration: none; +} + +#frm_upgrade_modal a.frm-button-primary { + cursor: pointer; +} + +.frm-dialog { + z-index: 1001; +} + +.frm-dialog + .ui-widget-overlay { + z-index: 1000; +} + +@media (max-width: 1024px) { + #frm_testing_mode > div > label:not(#frm_quick_jump_label) { + width: 100%; + display: block !important; + margin-left: 0 !important; + } + #frm_testing_mode > div > label:not(#frm_quick_jump_label) { + margin-top: var(--gap-sm); + } + #frm_testmode_fill_in_empty_form_fields { + display: block; + } + #frm_testing_mode > div:nth-of-type(2) { + flex-direction: column; + align-items: normal; + } + #frm_test_mode_pagination { + margin-left: 0; + } +} + +/*# sourceMappingURL=frm_testing_mode.css.map*/ \ No newline at end of file diff --git a/js/addons-page.js b/js/addons-page.js index a95f680f96..84a8b7026f 100644 --- a/js/addons-page.js +++ b/js/addons-page.js @@ -1 +1,4845 @@ -(()=>{var t={8616:t=>{t.exports=function(t,e){var n,r,o=0;function i(){var i,a,c=n,l=arguments.length;t:for(;c;){if(c.args.length===arguments.length){for(a=0;a{var r;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function i(t){return function(t,e){var n,r,a,c,l,s,u,f,d,p=1,y=t.length,m="";for(r=0;r=0),c.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,c.width?parseInt(c.width):0);break;case"e":n=c.precision?parseFloat(n).toExponential(c.precision):parseFloat(n).toExponential();break;case"f":n=c.precision?parseFloat(n).toFixed(c.precision):parseFloat(n);break;case"g":n=c.precision?String(Number(n.toPrecision(c.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=c.precision?n.substring(0,c.precision):n;break;case"t":n=String(!!n),n=c.precision?n.substring(0,c.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=c.precision?n.substring(0,c.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=c.precision?n.substring(0,c.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}o.json.test(c.type)?m+=n:(!o.number.test(c.type)||f&&!c.sign?d="":(d=f?"+":"-",n=n.toString().replace(o.sign,"")),s=c.pad_char?"0"===c.pad_char?"0":c.pad_char.charAt(1):" ",u=c.width-(d+n).length,l=c.width&&u>0?s.repeat(u):"",m+=c.align?d+n+l:"0"===s?d+l+n:l+d+n)}return m}(function(t){if(c[t])return c[t];for(var e,n=t,r=[],i=0;n;){if(null!==(e=o.text.exec(n)))r.push(e[0]);else if(null!==(e=o.modulo.exec(n)))r.push("%");else{if(null===(e=o.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){i|=1;var a=[],l=e[2],s=[];if(null===(s=o.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(s[1]);""!==(l=l.substring(s[0].length));)if(null!==(s=o.key_access.exec(l)))a.push(s[1]);else{if(null===(s=o.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(s[1])}e[2]=a}else i|=2;if(3===i)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}n=n.substring(e[0].length)}return c[t]=r}(t),arguments)}function a(t,e){return i.apply(null,[t].concat(e||[]))}var c=Object.create(null);"undefined"!=typeof window&&(window.sprintf=i,window.vsprintf=a,void 0===(r=function(){return{sprintf:i,vsprintf:a}}.call(e,n,e,t))||(t.exports=r))}()}},e={};function n(r){var o=e[r];if(void 0!==o)return o.exports;var i=e[r]={exports:{}};return t[r](i,i.exports,n),i.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t=window.frmGlobal,e=t.url,r=(t.nonce,"frm_hidden"),o="frm-hide-js",i="frm-current";function a(t){return a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},a(t)}function c(t,e){for(var n=0;n1&&void 0!==arguments[1]?arguments[1]:"default";!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.elements=e,this.type=n,this.prepareElements()},e=[{key:"fadeIn",value:function(){var t=this;this.applyStyleToElements(function(e){e.classList.add("frm-fadein-up"),e.addEventListener("animationend",function(){t.resetOpacity(),e.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){t.applyStyleToElements(function(t,n){t.classList.remove("frm-animate"),t.style.transitionDelay="".concat((n+1)*e,"s")})},200)}},{key:"prepareElements",value:function(){var t=this;this.applyStyleToElements(function(e){"default"===t.type&&(e.style.opacity="0.0"),"cascade"===t.type&&e.classList.add("frm-init-cascade-animation"),"cascade-3d"===t.type&&e.classList.add("frm-init-fadein-3d"),e.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(t){return t.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(t){this.elements instanceof Element?t(this.elements,0):0":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},j=["(","?"],E={")":["("],":":["?","?:"]},P=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var F={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,n){if(t)throw e;return n}};var I={contextDelimiter:"",onMissingKey:null};function D(t,e){var n;for(n in this.data=t,this.pluralForms={},this.options={},I)this.options[n]=void 0!==e&&n in e?e[n]:I[n]}function L(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function q(t){for(var e=1;e=0||_[o]<_[n]){a.push(o);break}i.push(o)}E[n]||a.push(n),t=t.substr(e.index+n.length)}return(t=t.trim())&&i.push(t),i.concat(a.reverse())}(t);return function(t){return function(t,e){var n,r,o,i,a,c,l=[];for(n=0;n3&&void 0!==arguments[3]?arguments[3]:10,a=t[e];if(B(n)&&z(r))if("function"==typeof o)if("number"==typeof i){var c={callback:o,priority:i,namespace:r};if(a[n]){var l,s=a[n].handlers;for(l=s.length;l>0&&!(i>=s[l-1].priority);l--);l===s.length?s[l]=c:s.splice(l,0,c),a.__current.forEach(function(t){t.name===n&&t.currentIndex>=l&&t.currentIndex++})}else a[n]={handlers:[c],runs:0};"hookAdded"!==n&&t.doAction("hookAdded",n,r,o,i)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},$=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,o){var i=t[e];if(B(r)&&(n||z(o))){if(!i[r])return 0;var a=0;if(n)a=i[r].handlers.length,i[r]={runs:i[r].runs,handlers:[]};else for(var c=i[r].handlers,l=function(t){c[t].namespace===o&&(c.splice(t,1),a++,i.__current.forEach(function(e){e.name===r&&e.currentIndex>=t&&e.currentIndex--}))},s=c.length-1;s>=0;s--)l(s);return"hookRemoved"!==r&&t.doAction("hookRemoved",r,o),a}}},U=function(t,e){return function(n,r){var o=t[e];return void 0!==r?n in o&&o[n].handlers.some(function(t){return t.namespace===r}):n in o}},Z=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var o=t[e];o[r]||(o[r]={handlers:[],runs:0}),o[r].runs++;for(var i=o[r].handlers,a=arguments.length,c=new Array(a>1?a-1:0),l=1;l1&&void 0!==arguments[1]?arguments[1]:"default";r.data[e]=q(q(q({},R),r.data[e]),t),r.data[e][""]=q(q({},R[""]),r.data[e][""])},c=function(t,e){a(t,e),i()},l=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;return r.data[t]||a(void 0,t),r.dcnpgettext(t,e,n,o,i)},s=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},u=function(t,e,r){var o=l(r,e,t);return n?(o=n.applyFilters("i18n.gettext_with_context",o,t,e,r),n.applyFilters("i18n.gettext_with_context_"+s(r),o,t,e,r)):o};if(n){var f=function(t){N.test(t)&&i()};n.addAction("hookAdded","core/i18n",f),n.addAction("hookRemoved","core/i18n",f)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[t]},setLocaleData:c,resetLocaleData:function(t,e){r.data={},r.pluralForms={},c(t,e)},subscribe:function(t){return o.add(t),function(){return o.delete(t)}},__:function(t,e){var r=l(e,void 0,t);return n?(r=n.applyFilters("i18n.gettext",r,t,e),n.applyFilters("i18n.gettext_"+s(e),r,t,e)):r},_x:u,_n:function(t,e,r,o){var i=l(o,void 0,t,e,r);return n?(i=n.applyFilters("i18n.ngettext",i,t,e,r,o),n.applyFilters("i18n.ngettext_"+s(o),i,t,e,r,o)):i},_nx:function(t,e,r,o,i){var a=l(i,o,t,e,r);return n?(a=n.applyFilters("i18n.ngettext_with_context",a,t,e,r,o,i),n.applyFilters("i18n.ngettext_with_context_"+s(i),a,t,e,r,o,i)):a},isRTL:function(){return"rtl"===u("ltr","text direction")},hasTranslation:function(t,e,o){var i,a,c=e?e+""+t:t,l=!(null===(i=r.data)||void 0===i||null===(a=i[null!=o?o:"default"])||void 0===a||!a[c]);return n&&(l=n.applyFilters("i18n.has_translation",l,t,e,o),l=n.applyFilters("i18n.has_translation_"+s(o),l,t,e,o)),l}}}(0,0,V));G.getLocaleData.bind(G),G.setLocaleData.bind(G),G.resetLocaleData.bind(G),G.subscribe.bind(G);var H=G.__.bind(G),Q=(G._x.bind(G),G._n.bind(G),G._nx.bind(G),G.isRTL.bind(G),G.hasTranslation.bind(G),window.frmDom),W=Q.tag,Y=Q.div,tt=Q.a,et=Q.img;function nt(t){return nt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},nt(t)}function rt(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function ot(t,e,n){return(e=function(t){var e=function(t){if("object"!=nt(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=nt(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==nt(e)?e:e+""}(e))in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var it,at=document.getElementById("post-body-content"),ct=document.getElementById("".concat(h,"-sidebar")),lt=((it=tt({className:"button button-primary frm-button-primary"})).setAttribute("role","button"),Y({id:"".concat(h,"-empty-state"),className:"frm-flex-col frm-flex-center frm-gap-md ".concat(r),children:[et({src:"".concat(e,"/images/page-skeleton/empty-state.svg"),alt:H("Empty State","formidable")}),Y({className:"frmcenter",children:[W("h2",{className:"".concat(h,"-title frm-mb-0")}),W("p",{className:"".concat(h,"-text frm-mb-0")})]}),it]}));null==at||at.append(lt);var st=function(){var t=document.querySelector("#".concat(h,"-empty-state"));return{emptyState:t,emptyStateTitle:null==t?void 0:t.querySelector(".".concat(h,"-title")),emptyStateText:null==t?void 0:t.querySelector(".".concat(h,"-text")),emptyStateButton:null==t?void 0:t.querySelector(".button")}}(),ut=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==O(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var e=t;return{getElements:function(){return e},addElements:function(t){if("object"!==O(t)||null===t)throw new Error("addElements: newElements must be a non-null object");e=w(w({},e),t)}}}(function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==vt(t)||null===t)throw new Error("createPageState: initialState must be a non-null object");var e=t;return{getState:function(){return e},getSingleState:function(t){var n=Reflect.get(e,t);return void 0===n?null:n},setState:function(t){if("object"!==vt(t)||null===t)throw new Error("setState: newState must be a non-null object");e=yt(yt({},e),t)},setSingleState:function(t,n){Reflect.has(e,t)&&Reflect.set(e,t,n)}}}({notEmptySearchText:!1,selectedCategory:g,selectedCategoryEl:bt}),gt=ht.getState,St=ht.getSingleState,wt=ht.setState,xt=ht.setSingleState,Ot=function(t){var e,n=t.currentTarget,r=n.getAttribute("data-category"),o=gt(),a=o.selectedCategory,c=o.selectedCategoryEl,l=o.notEmptySearchText;if(a!==r){a=wp.hooks.applyFilters("frmPage.selectedCategory",r),c.classList.remove(i),(c=n).classList.add(i),wt({selectedCategory:a,selectedCategoryEl:c}),l&&((e=ft().searchInput).value="",e.dispatchEvent(new Event("input",{bubbles:!0}))),wp.hooks.doAction("frmPage.onCategoryClick",a);var u=ft().bodyContent;new s(u).fadeIn()}};function _t(t){"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),Ot(t))}var jt=window.frmAddonsVars.addonRequestURL,Et="frm-addons",Pt="available-addons",kt="active-addons",At="basic",Ct="plus",Tt="business",Ft="elite",It=ft(),Dt=It.bodyContent,Lt=It.sidebar;Dt&&Dt.querySelectorAll(".frm-card-item:not(.plugin-card-formidable-pro)").forEach(function(t){var e=t.dataset.categories;switch(!0){case e.includes(Tt):t.setAttribute("data-categories","".concat(e,",").concat(Ft));break;case e.includes(Ct):t.setAttribute("data-categories","".concat(e,",").concat(Tt,",").concat(Ft));break;case e.includes(At):t.setAttribute("data-categories","".concat(e,",").concat(Ct,",").concat(Tt,",").concat(Ft))}}),dt({upgradeBanner:document.getElementById("frm-upgrade-banner"),availableCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Pt,'"]')),activeCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(kt,'"]')),categoriesTopDivider:Lt.querySelector(".".concat(h,"-divider")),basicPlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(At,'"]')),plusPlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Ct,'"]')),businessPlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Tt,'"]')),elitePlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Ft,'"]')),addonsList:document.getElementById("".concat(Et,"-list")),addons:null==Dt?void 0:Dt.querySelectorAll(".frm-card-item"),availableAddons:null==Dt?void 0:Dt.querySelectorAll(".frm-card-item:not(.frm-locked-item)"),addonsToggle:null==Dt?void 0:Dt.querySelectorAll(".frm_toggle_block"),bodyContentChildren:null==Dt?void 0:Dt.children});var qt={};qt[Pt]=[],qt[kt]=[];var Rt,Nt=".".concat(h,"-cat-count");function zt(){var t=ft(),e=t.activeCategory,n=t.availableCategory,r=t.categoriesTopDivider,o=document.querySelectorAll(".frm-addon-active:not(.frm-locked-item)");0!==o.length?(qt[kt]=o,e.querySelector(Nt).textContent=o.length):m([e,n,r])}function Bt(){var t=gt().selectedCategory,e=ft(),n=e.emptyState,r=e.emptyStateButton,o=e.emptyStateTitle,i=e.emptyStateText;n.setAttribute("data-view",t),o.textContent=H("No add-ons found","formidable"),i.textContent=H("Sorry, we didn't find any add-ons that match your criteria.","formidable"),r.textContent=H("Request Add-On","formidable"),r.href=jt,r.setAttribute("target","_blank"),y([n,r])}function Mt(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=null==t?null:"undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(null!=n){var r,o,i,a,c=[],l=!0,s=!1;try{if(i=(n=n.call(t)).next,0===e){if(Object(n)!==n)return;l=!1}else for(;!(l=(r=i.call(n)).done)&&(c.push(r.value),c.length!==e);l=!0);}catch(t){s=!0,o=t}finally{try{if(!l&&null!=n.return&&(a=n.return(),Object(a)!==a))return}finally{if(s)throw o}}return c}}(t,e)||$t(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function $t(t,e){if(t){if("string"==typeof t)return Ut(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?Ut(t,e):void 0}}function Ut(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:r}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var o,i=!0,a=!1;return{s:function(){e=e.call(t)},n:function(){var t=e.next();return i=t.done,t},e:function(t){a=!0,o=t},f:function(){try{i||null==e.return||e.return()}finally{if(a)throw o}}}}(new Map([["frm-addon-not-installed",".frm-install-addon"],["frm-addon-installed",".frm-activate-addon"],["frm-addon-active",".frm-deactivate-addon"]]).entries());try{for(o.s();!(n=o.n()).done;){var i=Mt(n.value,2),a=i[0],c=i[1];if(r.classList.contains(a)){(Rt=r.querySelector(c)).click();break}}}catch(t){o.e(t)}finally{o.f()}}};var Kt=window.frmDom.search.init;function Xt(t,e){var n=t.foundSomething,r=t.notEmptySearchText;if(!e||"search"!==e.type||""!==e.target.value){var o=gt(),a=ft().allItemsCategory;xt("notEmptySearchText",r),o.notEmptySearchText||o.selectedCategory?(o.selectedCategory&&(function(t){var e=ft(),n=e.bodyContent,r=e.bodyContentChildren,o=e.addonsList;t&&St("selectedCategoryEl").classList.remove(i),m(r),v(o),new s(n).fadeIn()}(r),r&&xt("selectedCategory","")),function(t){if(t){var e,n=ft().emptyState;e=n,"none"!==window.getComputedStyle(e).getPropertyValue("display")&&b(n)}else Bt()}(n)):a.dispatchEvent(new Event("click",{bubbles:!0}))}}function Jt(){var t;ft().categoryItems.forEach(function(t){p(t,Ot),t.addEventListener("keydown",_t)}),wp.hooks.addAction("frmPage.onCategoryClick","frmAddonsPage",function(t){!function(t){var e=ft(),n=e.bodyContent,r=e.addons,o=e.emptyState,i=e.upgradeBanner;b(o),v(i),n.dataset.category=t,g!==t?(m(r),0===qt[t].length?(Bt(),b(i)):y(qt[t])):y(r)}(t)}),ft().addonsToggle.forEach(function(t){return t.addEventListener("click",Zt)}),wp.hooks.addAction("frm_update_addon_state","frmAddonPage",function(){zt()}),t=ft().searchInput,Kt(t,"frm-card-item",{handleSearchResult:Xt})}var Vt;Vt=function(){(function(){var t,e,n,r,i,a,c,l,u,f,d=ft(),p=d.sidebar,y=d.searchInput,m=d.bodyContent,b=new s(m);y.value="",zt(),function(){var t=ft(),e=t.bodyContent,n=t.availableCategory,r=t.availableAddons;if(qt[Pt]=r,n){n.querySelector(Nt).textContent=r.length;var o=e.querySelector(".".concat(Et,"-available-count"));o&&(o.textContent=r.length)}}(),function(){var t=ft(),e=t.allItemsCategory,n=t.addons;e.querySelector(Nt).textContent=n.length}(),e=(t=ft()).basicPlanCategory,n=t.plusPlanCategory,r=t.businessPlanCategory,i=t.elitePlanCategory,c=(a=function(t){return parseInt(t.querySelector(Nt).textContent,10)||0})(e),l=a(n)-1,u=a(r)-1,f=a(i)-1,n.querySelector(Nt).textContent=c+l,r.querySelector(Nt).textContent=c+l+u,i.querySelector(Nt).textContent=c+l+u+f,m.classList.remove(o),p.classList.remove(o),b.fadeIn(),v(p)})(),ft().addons.forEach(function(t){var e=t.getAttribute("data-categories");e&&e.split(",").forEach(function(e){qt[e]||(qt[e]=[]),qt[e].push(t)})}),Jt()},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",Vt):Vt())})()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": +/*!*****************************************************************!*\ + !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ domReady) +/* harmony export */ }); +/** + * @typedef {() => void} Callback + * + * TODO: Remove this typedef and inline `() => void` type. + * + * This typedef is used so that a descriptive type is provided in our + * automatically generated documentation. + * + * An in-line type `() => void` would be preferable, but the generated + * documentation is `null` in that case. + * + * @see https://github.com/WordPress/gutenberg/issues/18045 + */ + +/** + * Specify a function to execute when the DOM is fully loaded. + * + * @param {Callback} callback A function to execute after the DOM is ready. + * + * @example + * ```js + * import domReady from '@wordpress/dom-ready'; + * + * domReady( function() { + * //do something after DOM loads. + * } ); + * ``` + * + * @return {void} + */ +function domReady(callback) { + if (typeof document === 'undefined') { + return; + } + + if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. + document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. + ) { + return void callback(); + } // DOMContentLoaded has not fired yet, delay callback until then. + + + document.addEventListener('DOMContentLoaded', callback); +} +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/addons-page/addons/categorizeAddons.js": +/*!*******************************************************!*\ + !*** ./js/src/addons-page/addons/categorizeAddons.js ***! + \*******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ buildCategorizedAddons: () => (/* binding */ buildCategorizedAddons), +/* harmony export */ categorizedAddons: () => (/* binding */ categorizedAddons) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); +/** + * Internal dependencies + */ + + +var categorizedAddons = {}; +categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.AVAILABLE] = []; +categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ACTIVE] = []; + +/** + * Builds a categorized list of addons. + * + * @return {void} + */ +function buildCategorizedAddons() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + addons = _getElements.addons; + addons.forEach(function (addon) { + // Extract and split the categories from data attribute + var dataCategories = addon.getAttribute('data-categories'); + if (!dataCategories) { + return; + } + var categories = dataCategories.split(','); + categories.forEach(function (category) { + // Initialize the category array if not already done + if (!categorizedAddons[category]) { + categorizedAddons[category] = []; + } + + // Add the addon to the appropriate category + categorizedAddons[category].push(addon); + }); + }); +} + +/***/ }), + +/***/ "./js/src/addons-page/addons/index.js": +/*!********************************************!*\ + !*** ./js/src/addons-page/addons/index.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ buildCategorizedAddons: () => (/* reexport safe */ _categorizeAddons__WEBPACK_IMPORTED_MODULE_0__.buildCategorizedAddons), +/* harmony export */ categorizedAddons: () => (/* reexport safe */ _categorizeAddons__WEBPACK_IMPORTED_MODULE_0__.categorizedAddons) +/* harmony export */ }); +/* harmony import */ var _categorizeAddons__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./categorizeAddons */ "./js/src/addons-page/addons/categorizeAddons.js"); + + +/***/ }), + +/***/ "./js/src/addons-page/constants.js": +/*!*****************************************!*\ + !*** ./js/src/addons-page/constants.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ PLANS: () => (/* binding */ PLANS), +/* harmony export */ PREFIX: () => (/* binding */ PREFIX), +/* harmony export */ VIEWS: () => (/* binding */ VIEWS), +/* harmony export */ addonRequestURL: () => (/* binding */ addonRequestURL) +/* harmony export */ }); +var addonRequestURL = window.frmAddonsVars.addonRequestURL; + +var PREFIX = 'frm-addons'; +var VIEWS = { + AVAILABLE: 'available-addons', + ACTIVE: 'active-addons' +}; +var PLANS = { + BASIC: 'basic', + PLUS: 'plus', + BUSINESS: 'business', + ELITE: 'elite' +}; + +/***/ }), + +/***/ "./js/src/addons-page/elements/elements.js": +/*!*************************************************!*\ + !*** ./js/src/addons-page/elements/elements.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + +var _getElements = (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + bodyContent = _getElements.bodyContent, + sidebar = _getElements.sidebar; +if (bodyContent) { + bodyContent.querySelectorAll('.frm-card-item:not(.plugin-card-formidable-pro)').forEach(function (addon) { + var categories = addon.dataset.categories; + switch (true) { + case categories.includes(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS): + addon.setAttribute('data-categories', "".concat(categories, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE)); + break; + case categories.includes(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.PLUS): + addon.setAttribute('data-categories', "".concat(categories, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE)); + break; + case categories.includes(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BASIC): + addon.setAttribute('data-categories', "".concat(categories, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.PLUS, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE)); + break; + } + }); +} +(0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements)({ + // Body elements + upgradeBanner: document.getElementById('frm-upgrade-banner'), + // Category elements + availableCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.AVAILABLE, "\"]")), + activeCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ACTIVE, "\"]")), + categoriesTopDivider: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-divider")), + basicPlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BASIC, "\"]")), + plusPlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.PLUS, "\"]")), + businessPlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS, "\"]")), + elitePlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE, "\"]")), + // Card elements + addonsList: document.getElementById("".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-list")), + addons: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.querySelectorAll('.frm-card-item'), + availableAddons: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.querySelectorAll('.frm-card-item:not(.frm-locked-item)'), + addonsToggle: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.querySelectorAll('.frm_toggle_block'), + // Add children of the bodyContent to the elements object + bodyContentChildren: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.children +}); + + +/***/ }), + +/***/ "./js/src/addons-page/elements/index.js": +/*!**********************************************!*\ + !*** ./js/src/addons-page/elements/index.js ***! + \**********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/addons-page/elements/elements.js"); + + +/***/ }), + +/***/ "./js/src/addons-page/events/addonToggleListener.js": +/*!**********************************************************!*\ + !*** ./js/src/addons-page/events/addonToggleListener.js ***! + \**********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _ui___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../ui/ */ "./js/src/addons-page/ui/index.js"); +function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } +function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +/** + * Internal dependencies + */ + + +var targetButton; + +/** + * Manages event handling for addons toggle. + * + * @return {void} + */ +function addAddonToggleEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + addonsToggle = _getElements.addonsToggle; + addonsToggle.forEach(function (addonToggle) { + return addonToggle.addEventListener('click', onAddonToggleClick); + }); + wp.hooks.addAction('frm_update_addon_state', 'frmAddonPage', function () { + (0,_ui___WEBPACK_IMPORTED_MODULE_1__.setupActiveCategory)(); + }); +} + +/** + * Handles the click event on the addon toggle. + * + * @private + * @param {Event} event The click event object. + * @return {void} + */ +var onAddonToggleClick = function onAddonToggleClick(event) { + var _targetButton; + if ((_targetButton = targetButton) !== null && _targetButton !== void 0 && _targetButton.classList.contains('frm_loading_button')) { + return; + } + var addonToggle = event.currentTarget; + var addon = addonToggle.closest('.frm-card-item'); + var actionMap = new Map([['frm-addon-not-installed', '.frm-install-addon'], ['frm-addon-installed', '.frm-activate-addon'], ['frm-addon-active', '.frm-deactivate-addon']]); + var _iterator = _createForOfIteratorHelper(actionMap.entries()), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var _step$value = _slicedToArray(_step.value, 2), + className = _step$value[0], + selector = _step$value[1]; + if (addon.classList.contains(className)) { + targetButton = addon.querySelector(selector); + targetButton.click(); + break; + } + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addAddonToggleEvents); + +/***/ }), + +/***/ "./js/src/addons-page/events/index.js": +/*!********************************************!*\ + !*** ./js/src/addons-page/events/index.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../ui */ "./js/src/addons-page/ui/index.js"); +/* harmony import */ var _addonToggleListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./addonToggleListener */ "./js/src/addons-page/events/addonToggleListener.js"); +/* harmony import */ var _searchListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./searchListener */ "./js/src/addons-page/events/searchListener.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + +/** + * Attaches event listeners for handling user interactions. + * + * @return {void} + */ +function addEventListeners() { + (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addCategoryEvents)(); + wp.hooks.addAction('frmPage.onCategoryClick', 'frmAddonsPage', function (selectedCategory) { + (0,_ui__WEBPACK_IMPORTED_MODULE_1__.showSelectedCategory)(selectedCategory); + }); + (0,_addonToggleListener__WEBPACK_IMPORTED_MODULE_2__["default"])(); + (0,_searchListener__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + +/***/ }), + +/***/ "./js/src/addons-page/events/searchListener.js": +/*!*****************************************************!*\ + !*** ./js/src/addons-page/events/searchListener.js ***! + \*****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/addons-page/shared/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../ui */ "./js/src/addons-page/ui/index.js"); +/** + * Internal dependencies + */ + + + +var initSearch = window.frmDom.search.init; + +/** + * Adds search-related event listeners by calling the 'initSearch' function. + * + * @see frmDom.search method + * @return {void} + */ +function addSearchEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + searchInput = _getElements.searchInput; + initSearch(searchInput, 'frm-card-item', { + handleSearchResult: handleSearchResult + }); +} + +/** + * Manages UI state based on search results and input value. + * + * @private + * @param {Object} args Contains flags for search status. + * @param {boolean} args.foundSomething True if search yielded results. + * @param {boolean} args.notEmptySearchText True if search input is not empty. + * @param {Event} event The event object (input, search, or change event). + * @return {void} + */ +function handleSearchResult(_ref, event) { + var foundSomething = _ref.foundSomething, + notEmptySearchText = _ref.notEmptySearchText; + // Prevent double calls as window.frmDom.search.init attaches both 'input' and 'search' events, + // triggering this method twice on 'x' button click. + if (event && event.type === 'search' && event.target.value === '') { + return; + } + var state = (0,_shared__WEBPACK_IMPORTED_MODULE_1__.getState)(); + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + allItemsCategory = _getElements2.allItemsCategory; + (0,_shared__WEBPACK_IMPORTED_MODULE_1__.setSingleState)('notEmptySearchText', notEmptySearchText); + + // Revert to 'All Templates' if search and selected category are both empty + if (!state.notEmptySearchText && !state.selectedCategory) { + allItemsCategory.dispatchEvent(new Event('click', { + bubbles: true + })); + return; + } + + // Display search state if a category is selected + if (state.selectedCategory) { + (0,_ui__WEBPACK_IMPORTED_MODULE_2__.showSearchState)(notEmptySearchText); + + // Setting "selectedCategory" to an empty string as a flag for search state + if (notEmptySearchText) { + (0,_shared__WEBPACK_IMPORTED_MODULE_1__.setSingleState)('selectedCategory', ''); + } + } + (0,_ui__WEBPACK_IMPORTED_MODULE_2__.displaySearchElements)(foundSomething); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addSearchEvents); + +/***/ }), + +/***/ "./js/src/addons-page/shared/index.js": +/*!********************************************!*\ + !*** ./js/src/addons-page/shared/index.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setState) +/* harmony export */ }); +/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageState */ "./js/src/addons-page/shared/pageState.js"); + + +/***/ }), + +/***/ "./js/src/addons-page/shared/pageState.js": +/*!************************************************!*\ + !*** ./js/src/addons-page/shared/pageState.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setState) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/** + * External dependencies + */ + + +// NOTE: +// Use setState() here to add new states on the Add-Ons page. +// Check the 'core/page-skeleton' package for shared states you can use. + + + +/***/ }), + +/***/ "./js/src/addons-page/ui/index.js": +/*!****************************************!*\ + !*** ./js/src/addons-page/ui/index.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ displaySearchElements: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_2__.displaySearchElements), +/* harmony export */ setupActiveCategory: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__.setupActiveCategory), +/* harmony export */ setupInitialView: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__.setupInitialView), +/* harmony export */ showEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_3__.showEmptyState), +/* harmony export */ showSearchState: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_2__.showSearchState), +/* harmony export */ showSelectedCategory: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_1__.showSelectedCategory) +/* harmony export */ }); +/* harmony import */ var _setupInitialView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupInitialView */ "./js/src/addons-page/ui/setupInitialView.js"); +/* harmony import */ var _showSelectedCategory__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./showSelectedCategory */ "./js/src/addons-page/ui/showSelectedCategory.js"); +/* harmony import */ var _searchState__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./searchState */ "./js/src/addons-page/ui/searchState.js"); +/* harmony import */ var _showEmptyState__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./showEmptyState */ "./js/src/addons-page/ui/showEmptyState.js"); + + + + + +/***/ }), + +/***/ "./js/src/addons-page/ui/searchState.js": +/*!**********************************************!*\ + !*** ./js/src/addons-page/ui/searchState.js ***! + \**********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ displaySearchElements: () => (/* binding */ displaySearchElements), +/* harmony export */ showSearchState: () => (/* binding */ showSearchState) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../shared */ "./js/src/addons-page/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! . */ "./js/src/addons-page/ui/index.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + +/** + * Updates the UI to display the search state. + * + * @param {boolean} notEmptySearchText True if search input is not empty. + * @return {void} + */ +function showSearchState(notEmptySearchText) { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + bodyContent = _getElements.bodyContent, + bodyContentChildren = _getElements.bodyContentChildren, + addonsList = _getElements.addonsList; + + // Remove highlighting from the currently selected category if the search text is not empty + if (notEmptySearchText) { + (0,_shared__WEBPACK_IMPORTED_MODULE_4__.getSingleState)('selectedCategoryEl').classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_1__.CURRENT_CLASS); + } + + // Hide non-relevant elements in the body content + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hideElements)(bodyContentChildren); + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.show)(addonsList); + + // Smoothly display the updated UI elements + new core_utils__WEBPACK_IMPORTED_MODULE_2__.frmAnimate(bodyContent).fadeIn(); +} + +/** + * Displays search results based on search outcome. + * + * @param {boolean} foundSomething True if search yielded results. + * @return {void} + */ +function displaySearchElements(foundSomething) { + // Show empty state if no templates found + if (!foundSomething) { + (0,___WEBPACK_IMPORTED_MODULE_5__.showEmptyState)(); + return; + } + + // Hide empty state if currently displayed + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + emptyState = _getElements2.emptyState; + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_2__.isVisible)(emptyState)) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hide)(emptyState); + } +} + +/***/ }), + +/***/ "./js/src/addons-page/ui/setupInitialView.js": +/*!***************************************************!*\ + !*** ./js/src/addons-page/ui/setupInitialView.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ setupActiveCategory: () => (/* binding */ setupActiveCategory), +/* harmony export */ setupInitialView: () => (/* binding */ setupInitialView) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _addons__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../addons */ "./js/src/addons-page/addons/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); +/** + * External dependencies + */ + + + + +/** + * Internal dependencies + */ + + + +var CAT_COUNT_CLASS = ".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-cat-count"); + +/** + * Sets up the initial view, performing any required + * DOM manipulations for proper element presentation. + * + * @return {void} + */ +function setupInitialView() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + sidebar = _getElements.sidebar, + searchInput = _getElements.searchInput, + bodyContent = _getElements.bodyContent; + var bodyContentAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent); + searchInput.value = ''; + setupActiveCategory(); + setupAvailableCategory(); + setupAllAddonsCategory(); + setupPlansCategory(); + + // Smoothly display the updated UI elements + bodyContent.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); + sidebar.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); + bodyContentAnimate.fadeIn(); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(sidebar); +} + +/** + * Sets up the "Active" category, updating the + * categorizedAddons object and the category count. + * + * @return {void} + */ +function setupActiveCategory() { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + activeCategory = _getElements2.activeCategory, + availableCategory = _getElements2.availableCategory, + categoriesTopDivider = _getElements2.categoriesTopDivider; + var activeAddons = document.querySelectorAll('.frm-addon-active:not(.frm-locked-item)'); + if (activeAddons.length === 0) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([activeCategory, availableCategory, categoriesTopDivider]); + return; + } + _addons__WEBPACK_IMPORTED_MODULE_4__.categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_5__.VIEWS.ACTIVE] = activeAddons; + + // Set "Active" category count + activeCategory.querySelector(CAT_COUNT_CLASS).textContent = activeAddons.length; +} + +/** + * Sets up the "Available" category, updating the + * categorizedAddons object and the category count. + * + * @private + * @return {void} + */ +function setupAvailableCategory() { + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + bodyContent = _getElements3.bodyContent, + availableCategory = _getElements3.availableCategory, + availableAddons = _getElements3.availableAddons; + _addons__WEBPACK_IMPORTED_MODULE_4__.categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_5__.VIEWS.AVAILABLE] = availableAddons; + + // Set "Available" category count + if (availableCategory) { + availableCategory.querySelector(CAT_COUNT_CLASS).textContent = availableAddons.length; + var upgradeBannerAvailableCount = bodyContent.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_5__.PREFIX, "-available-count")); + if (upgradeBannerAvailableCount) { + upgradeBannerAvailableCount.textContent = availableAddons.length; + } + } +} + +/** + * Sets up the "All Add-Ons" category, updating the + * category count. + * + * @private + * @return {void} + */ +function setupAllAddonsCategory() { + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + allItemsCategory = _getElements4.allItemsCategory, + addons = _getElements4.addons; + + // Set "All Add-Ons" category count + allItemsCategory.querySelector(CAT_COUNT_CLASS).textContent = addons.length; +} + +/** + * Sets up the "All Add-Ons" category, updating the + * category count. + * + * @private + * @return {void} + */ +function setupPlansCategory() { + var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + basicPlanCategory = _getElements5.basicPlanCategory, + plusPlanCategory = _getElements5.plusPlanCategory, + businessPlanCategory = _getElements5.businessPlanCategory, + elitePlanCategory = _getElements5.elitePlanCategory; + var getCount = function getCount(category) { + return parseInt(category.querySelector(CAT_COUNT_CLASS).textContent, 10) || 0; + }; + + // The "Formidable Pro" add-on is included in all plans, so we just consider that in the basicCount + var basicCount = getCount(basicPlanCategory); + var plusCount = getCount(plusPlanCategory) - 1; + var businessCount = getCount(businessPlanCategory) - 1; + var eliteCount = getCount(elitePlanCategory) - 1; + + // Update the text content for each category + plusPlanCategory.querySelector(CAT_COUNT_CLASS).textContent = basicCount + plusCount; + businessPlanCategory.querySelector(CAT_COUNT_CLASS).textContent = basicCount + plusCount + businessCount; + elitePlanCategory.querySelector(CAT_COUNT_CLASS).textContent = basicCount + plusCount + businessCount + eliteCount; +} + +/***/ }), + +/***/ "./js/src/addons-page/ui/showEmptyState.js": +/*!*************************************************!*\ + !*** ./js/src/addons-page/ui/showEmptyState.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showEmptyState: () => (/* binding */ showEmptyState) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/addons-page/shared/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + +/** + * Display the search-empty state. + * + * @return {void} + */ +function showEmptyState() { + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + selectedCategory = _getState.selectedCategory; + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + emptyState = _getElements.emptyState, + emptyStateButton = _getElements.emptyStateButton, + emptyStateTitle = _getElements.emptyStateTitle, + emptyStateText = _getElements.emptyStateText; + emptyState.setAttribute('data-view', selectedCategory); + emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No add-ons found', 'formidable'); + emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Sorry, we didn\'t find any add-ons that match your criteria.', 'formidable'); + emptyStateButton.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Request Add-On', 'formidable'); + emptyStateButton.href = _constants__WEBPACK_IMPORTED_MODULE_4__.addonRequestURL; + emptyStateButton.setAttribute('target', '_blank'); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.showElements)([emptyState, emptyStateButton]); +} + +/***/ }), + +/***/ "./js/src/addons-page/ui/showSelectedCategory.js": +/*!*******************************************************!*\ + !*** ./js/src/addons-page/ui/showSelectedCategory.js ***! + \*******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ showSelectedCategory: () => (/* binding */ showSelectedCategory) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); +/* harmony import */ var _addons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../addons */ "./js/src/addons-page/addons/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! . */ "./js/src/addons-page/ui/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + +/** + * Show addons based on selected category. + * + * @param {string} selectedCategory The selected category to display addons for. + * @return {void} + */ +function showSelectedCategory(selectedCategory) { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + bodyContent = _getElements.bodyContent, + addons = _getElements.addons, + emptyState = _getElements.emptyState, + upgradeBanner = _getElements.upgradeBanner; + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(emptyState); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.show)(upgradeBanner); + bodyContent.dataset.category = selectedCategory; + if (core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS === selectedCategory) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)(addons); + return; + } + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(addons); + if (_addons__WEBPACK_IMPORTED_MODULE_3__.categorizedAddons[selectedCategory].length === 0) { + (0,___WEBPACK_IMPORTED_MODULE_4__.showEmptyState)(); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(upgradeBanner); + } else { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)(_addons__WEBPACK_IMPORTED_MODULE_3__.categorizedAddons[selectedCategory]); + } +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (showSelectedCategory); + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/factory/createPageElements.js": +/*!***************************************************!*\ + !*** ./js/src/core/factory/createPageElements.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* binding */ createPageElements) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page elements manager. + * + * @param {Object} [initialElements={}] An object containing initial DOM elements. + * @throws {Error} Throws an error if the `initialElements` is not an object. + * @return {Object} An object with methods to get and add elements. + */ +function createPageElements() { + var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialElements) !== 'object' || initialElements === null) { + throw new Error('createPageElements: initialElements must be a non-null object'); + } + var elements = initialElements; + + /** + * Retrieve the initialized essential DOM elements. + * + * @return {Object} The initialized elements object. + */ + function getElements() { + return elements; + } + + /** + * Add new elements to the elements object. + * + * @param {Object} newElements An object containing new elements to be added. + * @throws {Error} Throws an error if the `newElements` is not a non-null object. + * @return {void} Updates the elements object by merging the new elements into it. + */ + function addElements(newElements) { + if (_typeof(newElements) !== 'object' || newElements === null) { + throw new Error('addElements: newElements must be a non-null object'); + } + elements = _objectSpread(_objectSpread({}, elements), newElements); + } + return { + getElements: getElements, + addElements: addElements + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/createPageState.js": +/*!************************************************!*\ + !*** ./js/src/core/factory/createPageState.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageState: () => (/* binding */ createPageState) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page state manager. + * + * @param {Object} [initialState={}] An object containing the initial state. + * @throws {Error} Throws an error if the `initialState` is not a plain object. + * @return {Object} An object with methods to initialize, get, and set the page state. + */ +function createPageState() { + var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialState) !== 'object' || initialState === null) { + throw new Error('createPageState: initialState must be a non-null object'); + } + var state = initialState; + + /** + * Returns the current page state. + * + * @return {Object|null} The current state of the page or null if not initialized. + */ + var getState = function getState() { + return state; + }; + + /** + * Returns a specific property from the current page state. + * + * @param {string} propertyName The name of the property to retrieve. + * @return {*} The value of the specified property, or null if it doesn't exist. + */ + var getSingleState = function getSingleState(propertyName) { + var value = Reflect.get(state, propertyName); + + // We convert `undefined` to `null` for a consistent API. + // This makes it easier for users to handle the results since all missing properties return `null`. + return value === undefined ? null : value; + }; + + /** + * Updates the page state with new values. + * + * @param {Object} newState The new values to update the state with. + * @throws {Error} Throws an error if `newState` is not a plain object. + * @return {void} + */ + var setState = function setState(newState) { + if (_typeof(newState) !== 'object' || newState === null) { + throw new Error('setState: newState must be a non-null object'); + } + state = _objectSpread(_objectSpread({}, state), newState); + }; + + /** + * Updates a specific property in the page state with a new value. + * + * @param {string} propertyName The name of the property to update. + * @param {*} value The new value to set for the property. + * @return {void} + */ + var setSingleState = function setSingleState(propertyName, value) { + if (Reflect.has(state, propertyName)) { + Reflect.set(state, propertyName, value); + } + }; + return { + getState: getState, + getSingleState: getSingleState, + setState: setState, + setSingleState: setSingleState + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/index.js": +/*!**************************************!*\ + !*** ./js/src/core/factory/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), +/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) +/* harmony export */ }); +/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); +/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); + + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/constants.js": +/*!************************************************!*\ + !*** ./js/src/core/page-skeleton/constants.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ PREFIX: () => (/* binding */ PREFIX), +/* harmony export */ SEARCH_RESULT_ITEM: () => (/* binding */ SEARCH_RESULT_ITEM), +/* harmony export */ VIEWS: () => (/* binding */ VIEWS) +/* harmony export */ }); +var PREFIX = 'frm-page-skeleton'; +var SEARCH_RESULT_ITEM = 'frm-card-item'; +var VIEWS = { + ALL_ITEMS: 'all-items' +}; + +/***/ }), + +/***/ "./js/src/core/page-skeleton/elements/elements.js": +/*!********************************************************!*\ + !*** ./js/src/core/page-skeleton/elements/elements.js ***! + \********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* binding */ addElements), +/* harmony export */ getElements: () => (/* binding */ getElements) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); +/* harmony import */ var _emptyStateElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./emptyStateElement */ "./js/src/core/page-skeleton/elements/emptyStateElement.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +var bodyContent = document.getElementById('post-body-content'); +var sidebar = document.getElementById("".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-sidebar")); + +// Append empty state elements to body content +var emptyState = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.createEmptyStateElement)(); +bodyContent === null || bodyContent === void 0 || bodyContent.append(emptyState); +var emptyStateElements = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.getEmptyStateElements)(); +var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)(_objectSpread({ + bodyContent: bodyContent, + // Sidebar elements + sidebar: sidebar, + searchInput: sidebar.querySelector('.frm-search-input'), + categoryItems: sidebar.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat")), + allItemsCategory: sidebar.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS, "\"]")) + }, emptyStateElements)), + getElements = _createPageElements.getElements, + addElements = _createPageElements.addElements; + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/elements/emptyStateElement.js": +/*!*****************************************************************!*\ + !*** ./js/src/core/page-skeleton/elements/emptyStateElement.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createEmptyStateElement: () => (/* binding */ createEmptyStateElement), +/* harmony export */ getEmptyStateElements: () => (/* binding */ getEmptyStateElements) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + +var _window$frmDom = window.frmDom, + tag = _window$frmDom.tag, + div = _window$frmDom.div, + a = _window$frmDom.a, + img = _window$frmDom.img; + +/** + * Create and return the Empty State HTML element. + * + * @return {HTMLElement} The Empty State element. + */ +function createEmptyStateElement() { + var button = a({ + className: 'button button-primary frm-button-primary' + }); + button.setAttribute('role', 'button'); + return div({ + id: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state"), + className: "frm-flex-col frm-flex-center frm-gap-md ".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS), + children: [img({ + src: "".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.PLUGIN_URL, "/images/page-skeleton/empty-state.svg"), + alt: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Empty State', 'formidable') + }), div({ + className: 'frmcenter', + children: [tag('h2', { + className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title frm-mb-0") + }), tag('p', { + className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text frm-mb-0") + })] + }), button] + }); +} + +/** + * Return the elements related to the Empty State. + * + * @return {Object} Object containing Empty State related DOM elements. + */ +function getEmptyStateElements() { + var emptyState = document.querySelector("#".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state")); + return { + emptyState: emptyState, + emptyStateTitle: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title")), + emptyStateText: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text")), + emptyStateButton: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector('.button') + }; +} + +/***/ }), + +/***/ "./js/src/core/page-skeleton/elements/index.js": +/*!*****************************************************!*\ + !*** ./js/src/core/page-skeleton/elements/index.js ***! + \*****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/elements.js"); + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/events/categoryListener.js": +/*!**************************************************************!*\ + !*** ./js/src/core/page-skeleton/events/categoryListener.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addCategoryEvents: () => (/* binding */ addCategoryEvents) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/core/page-skeleton/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! . */ "./js/src/core/page-skeleton/events/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + +/** + * Manages event handling for sidebar category links. + * + * @return {void} + */ +function addCategoryEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + categoryItems = _getElements.categoryItems; + + // Attach click and keyboard event listeners to each sidebar category + categoryItems.forEach(function (category) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(category, onCategoryClick); + category.addEventListener('keydown', onCategoryKeydown); + }); +} + +/** + * Handles the click event on a category item. + * + * @private + * @param {Event} event The click event object. + */ +var onCategoryClick = function onCategoryClick(event) { + var clickedCategory = event.currentTarget; + var newSelectedCategory = clickedCategory.getAttribute('data-category'); + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + selectedCategory = _getState.selectedCategory, + selectedCategoryEl = _getState.selectedCategoryEl, + notEmptySearchText = _getState.notEmptySearchText; + + // If the selected category hasn't changed, return early + if (selectedCategory === newSelectedCategory) { + return; + } + + /** + * Filter hook to modify the selected category. + * + * @param {string} selectedCategory The selected category + */ + selectedCategory = wp.hooks.applyFilters('frmPage.selectedCategory', newSelectedCategory); + + // Highlight the newly clicked category and update the application state + selectedCategoryEl.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + selectedCategoryEl = clickedCategory; + selectedCategoryEl.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setState)({ + selectedCategory: selectedCategory, + selectedCategoryEl: selectedCategoryEl + }); + + // Reset the search input if it contains text + if (notEmptySearchText) { + (0,___WEBPACK_IMPORTED_MODULE_4__.resetSearchInput)(); + } + + /** + * Trigger custom action to update category content. + * + * @param {string} selectedCategory The selected category. + */ + wp.hooks.doAction('frmPage.onCategoryClick', selectedCategory); + + // Smoothly display the updated UI elements + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + bodyContent = _getElements2.bodyContent; + new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent).fadeIn(); +}; + +/** + * Handles the keyboard event on a category item. + * + * @param {KeyboardEvent} event The keyboard event object. + * @return {void} + */ +function onCategoryKeydown(event) { + // Only respond to 'Enter' or 'Space' key presses + if (event.key === 'Enter' || event.key === ' ') { + event.preventDefault(); + onCategoryClick(event); + } +} + +/***/ }), + +/***/ "./js/src/core/page-skeleton/events/index.js": +/*!***************************************************!*\ + !*** ./js/src/core/page-skeleton/events/index.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _categoryListener__WEBPACK_IMPORTED_MODULE_1__.addCategoryEvents), +/* harmony export */ resetSearchInput: () => (/* binding */ resetSearchInput) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _categoryListener__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./categoryListener */ "./js/src/core/page-skeleton/events/categoryListener.js"); +/** + * Internal dependencies + */ + + +/** + * Resets the value of the search input and triggers an input event. + * + * @return {void} + */ +function resetSearchInput() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + searchInput = _getElements.searchInput; + searchInput.value = ''; + searchInput.dispatchEvent(new Event('input', { + bubbles: true + })); +} + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/index.js": +/*!********************************************!*\ + !*** ./js/src/core/page-skeleton/index.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), +/* harmony export */ SEARCH_RESULT_ITEM: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.SEARCH_RESULT_ITEM), +/* harmony export */ VIEWS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.VIEWS), +/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.addCategoryEvents), +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.getElements), +/* harmony export */ getSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getState), +/* harmony export */ resetSearchInput: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.resetSearchInput), +/* harmony export */ setSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setState) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/core/page-skeleton/constants.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./shared */ "./js/src/core/page-skeleton/shared/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./events */ "./js/src/core/page-skeleton/events/index.js"); + + + + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/shared/index.js": +/*!***************************************************!*\ + !*** ./js/src/core/page-skeleton/shared/index.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setState) +/* harmony export */ }); +/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageState */ "./js/src/core/page-skeleton/shared/pageState.js"); + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/shared/pageState.js": +/*!*******************************************************!*\ + !*** ./js/src/core/page-skeleton/shared/pageState.js ***! + \*******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* binding */ getSingleState), +/* harmony export */ getState: () => (/* binding */ getState), +/* harmony export */ setSingleState: () => (/* binding */ setSingleState), +/* harmony export */ setState: () => (/* binding */ setState) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + allItemsCategory = _getElements.allItemsCategory; +var _createPageState = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageState)({ + notEmptySearchText: false, + selectedCategory: _constants__WEBPACK_IMPORTED_MODULE_2__.VIEWS.ALL_ITEMS, + selectedCategoryEl: allItemsCategory + }), + getState = _createPageState.getState, + getSingleState = _createPageState.getSingleState, + setState = _createPageState.setState, + setSingleState = _createPageState.setSingleState; + + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. +(() => { +"use strict"; +/*!*************************************!*\ + !*** ./js/src/addons-page/index.js ***! + \*************************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/addons-page/ui/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./js/src/addons-page/events/index.js"); +/* harmony import */ var _addons__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./addons */ "./js/src/addons-page/addons/index.js"); +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + + + +(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_3__["default"])(function () { + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.setupInitialView)(); + (0,_addons__WEBPACK_IMPORTED_MODULE_2__.buildCategorizedAddons)(); + (0,_events__WEBPACK_IMPORTED_MODULE_1__.addEventListeners)(); +}); +})(); + +/******/ })() +; +//# sourceMappingURL=addons-page.js.map \ No newline at end of file diff --git a/js/form-templates.js b/js/form-templates.js index d97f74de3e..5f2d576f97 100644 --- a/js/form-templates.js +++ b/js/form-templates.js @@ -1,2 +1,6798 @@ -/*! For license information please see form-templates.js.LICENSE.txt */ -(()=>{var t={8616:t=>{t.exports=function(t,e){var n,r,o=0;function a(){var a,i,c=n,l=arguments.length;t:for(;c;){if(c.args.length===arguments.length){for(i=0;i{var r;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function a(t){return function(t,e){var n,r,i,c,l,u,s,m,f,p=1,d=t.length,y="";for(r=0;r=0),c.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,c.width?parseInt(c.width):0);break;case"e":n=c.precision?parseFloat(n).toExponential(c.precision):parseFloat(n).toExponential();break;case"f":n=c.precision?parseFloat(n).toFixed(c.precision):parseFloat(n);break;case"g":n=c.precision?String(Number(n.toPrecision(c.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=c.precision?n.substring(0,c.precision):n;break;case"t":n=String(!!n),n=c.precision?n.substring(0,c.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=c.precision?n.substring(0,c.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=c.precision?n.substring(0,c.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}o.json.test(c.type)?y+=n:(!o.number.test(c.type)||m&&!c.sign?f="":(f=m?"+":"-",n=n.toString().replace(o.sign,"")),u=c.pad_char?"0"===c.pad_char?"0":c.pad_char.charAt(1):" ",s=c.width-(f+n).length,l=c.width&&s>0?u.repeat(s):"",y+=c.align?f+n+l:"0"===u?f+l+n:l+f+n)}return y}(function(t){if(c[t])return c[t];for(var e,n=t,r=[],a=0;n;){if(null!==(e=o.text.exec(n)))r.push(e[0]);else if(null!==(e=o.modulo.exec(n)))r.push("%");else{if(null===(e=o.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){a|=1;var i=[],l=e[2],u=[];if(null===(u=o.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(i.push(u[1]);""!==(l=l.substring(u[0].length));)if(null!==(u=o.key_access.exec(l)))i.push(u[1]);else{if(null===(u=o.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");i.push(u[1])}e[2]=i}else a|=2;if(3===a)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}n=n.substring(e[0].length)}return c[t]=r}(t),arguments)}function i(t,e){return a.apply(null,[t].concat(e||[]))}var c=Object.create(null);e.sprintf=a,e.vsprintf=i,"undefined"!=typeof window&&(window.sprintf=a,window.vsprintf=i,void 0===(r=function(){return{sprintf:a,vsprintf:i}}.call(e,n,e,t))||(t.exports=r))}()}},e={};function n(r){var o=e[r];if(void 0!==o)return o.exports;var a=e[r]={exports:{}};return t[r](a,a.exports,n),a.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t=window.frmGlobal,e=t.canAccessApplicationDashboard,r=t.applicationsUrl,o=window.frmFormTemplatesVars,a=o.FEATURED_TEMPLATES_IDS,i=o.FREE_TEMPLATES_IDS,c=o.upgradeLink,l="frm-form-templates",u="available-templates",s="favorites",m="custom",f="search",p="440px",d="550px",y="frm-page-skeleton",v="all-items";function h(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function b(t){for(var e=1;e":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},T=["(","?"],_={")":["("],":":["?","?:"]},E=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var P={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,n){if(t)throw e;return n}};var F={contextDelimiter:"",onMissingKey:null};function L(t,e){var n;for(n in this.data=t,this.pluralForms={},this.options={},F)this.options[n]=void 0!==e&&n in e?e[n]:F[n]}function B(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function D(t){for(var e=1;e=0||S[o]3&&void 0!==arguments[3]?arguments[3]:10,i=t[e];if(G(n)&&N(r))if("function"==typeof o)if("number"==typeof a){var c={callback:o,priority:a,namespace:r};if(i[n]){var l,u=i[n].handlers;for(l=u.length;l>0&&!(a>=u[l-1].priority);l--);l===u.length?u[l]=c:u.splice(l,0,c),i.__current.forEach(function(t){t.name===n&&t.currentIndex>=l&&t.currentIndex++})}else i[n]={handlers:[c],runs:0};"hookAdded"!==n&&t.doAction("hookAdded",n,r,o,a)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},z=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,o){var a=t[e];if(G(r)&&(n||N(o))){if(!a[r])return 0;var i=0;if(n)i=a[r].handlers.length,a[r]={runs:a[r].runs,handlers:[]};else for(var c=a[r].handlers,l=function(t){c[t].namespace===o&&(c.splice(t,1),i++,a.__current.forEach(function(e){e.name===r&&e.currentIndex>=t&&e.currentIndex--}))},u=c.length-1;u>=0;u--)l(u);return"hookRemoved"!==r&&t.doAction("hookRemoved",r,o),i}}},V=function(t,e){return function(n,r){var o=t[e];return void 0!==r?n in o&&o[n].handlers.some(function(t){return t.namespace===r}):n in o}},$=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var o=t[e];o[r]||(o[r]={handlers:[],runs:0}),o[r].runs++;for(var a=o[r].handlers,i=arguments.length,c=new Array(i>1?i-1:0),l=1;l1&&void 0!==arguments[1]?arguments[1]:"default";r.data[e]=D(D(D({},M),r.data[e]),t),r.data[e][""]=D(D({},M[""]),r.data[e][""])},c=function(t,e){i(t,e),a()},l=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,a=arguments.length>4?arguments[4]:void 0;return r.data[t]||i(void 0,t),r.dcnpgettext(t,e,n,o,a)},u=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},s=function(t,e,r){var o=l(r,e,t);return n?(o=n.applyFilters("i18n.gettext_with_context",o,t,e,r),n.applyFilters("i18n.gettext_with_context_"+u(r),o,t,e,r)):o};if(n){var m=function(t){q.test(t)&&a()};n.addAction("hookAdded","core/i18n",m),n.addAction("hookRemoved","core/i18n",m)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[t]},setLocaleData:c,resetLocaleData:function(t,e){r.data={},r.pluralForms={},c(t,e)},subscribe:function(t){return o.add(t),function(){return o.delete(t)}},__:function(t,e){var r=l(e,void 0,t);return n?(r=n.applyFilters("i18n.gettext",r,t,e),n.applyFilters("i18n.gettext_"+u(e),r,t,e)):r},_x:s,_n:function(t,e,r,o){var a=l(o,void 0,t,e,r);return n?(a=n.applyFilters("i18n.ngettext",a,t,e,r,o),n.applyFilters("i18n.ngettext_"+u(o),a,t,e,r,o)):a},_nx:function(t,e,r,o,a){var i=l(a,o,t,e,r);return n?(i=n.applyFilters("i18n.ngettext_with_context",i,t,e,r,o,a),n.applyFilters("i18n.ngettext_with_context_"+u(a),i,t,e,r,o,a)):i},isRTL:function(){return"rtl"===s("ltr","text direction")},hasTranslation:function(t,e,o){var a,i,c=e?e+""+t:t,l=!(null===(a=r.data)||void 0===a||null===(i=a[null!=o?o:"default"])||void 0===i||!i[c]);return n&&(l=n.applyFilters("i18n.has_translation",l,t,e,o),l=n.applyFilters("i18n.has_translation_"+u(o),l,t,e,o)),l}}}(0,0,Y));K.getLocaleData.bind(K),K.setLocaleData.bind(K),K.resetLocaleData.bind(K),K.subscribe.bind(K);var X=K.__.bind(K),W=(K._x.bind(K),K._n.bind(K),K._nx.bind(K),K.isRTL.bind(K),K.hasTranslation.bind(K),window.frmGlobal),Q=W.url,tt=(W.nonce,"frm_hidden"),et="frm-hide-js",nt="frm-current",rt=window.frmDom,ot=rt.tag,at=rt.div,it=rt.a,ct=rt.img;function lt(t){return lt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},lt(t)}function ut(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function st(t,e,n){return(e=function(t){var e=function(t){if("object"!=lt(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=lt(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==lt(e)?e:e+""}(e))in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var mt,ft=document.getElementById("post-body-content"),pt=document.getElementById("".concat(y,"-sidebar")),dt=((mt=it({className:"button button-primary frm-button-primary"})).setAttribute("role","button"),at({id:"".concat(y,"-empty-state"),className:"frm-flex-col frm-flex-center frm-gap-md ".concat(tt),children:[ct({src:"".concat(Q,"/images/page-skeleton/empty-state.svg"),alt:X("Empty State","formidable")}),at({className:"frmcenter",children:[ot("h2",{className:"".concat(y,"-title frm-mb-0")}),ot("p",{className:"".concat(y,"-text frm-mb-0")})]}),mt]}));null==ft||ft.append(dt);var yt=function(){var t=document.querySelector("#".concat(y,"-empty-state"));return{emptyState:t,emptyStateTitle:null==t?void 0:t.querySelector(".".concat(y,"-title")),emptyStateText:null==t?void 0:t.querySelector(".".concat(y,"-text")),emptyStateButton:null==t?void 0:t.querySelector(".button")}}(),vt=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==w(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var e=t;return{getElements:function(){return e},addElements:function(t){if("object"!==w(t)||null===t)throw new Error("addElements: newElements must be a non-null object");e=b(b({},e),t)}}}(function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==Tt(t)||null===t)throw new Error("createPageState: initialState must be a non-null object");var e=t;return{getState:function(){return e},getSingleState:function(t){var n=Reflect.get(e,t);return void 0===n?null:n},setState:function(t){if("object"!==Tt(t)||null===t)throw new Error("setState: newState must be a non-null object");e=wt(wt({},e),t)},setSingleState:function(t,n){Reflect.has(e,t)&&Reflect.set(e,t,n)}}}({notEmptySearchText:!1,selectedCategory:v,selectedCategoryEl:_t}),xt=Et.getState,Ot=Et.getSingleState,jt=Et.setState,It=Et.setSingleState;function Ct(t){return Ct="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},Ct(t)}function At(t,e){for(var n=0;n1&&void 0!==arguments[1]?arguments[1]:"default";!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.elements=e,this.type=n,this.prepareElements()},e=[{key:"fadeIn",value:function(){var t=this;this.applyStyleToElements(function(e){e.classList.add("frm-fadein-up"),e.addEventListener("animationend",function(){t.resetOpacity(),e.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){t.applyStyleToElements(function(t,n){t.classList.remove("frm-animate"),t.style.transitionDelay="".concat((n+1)*e,"s")})},200)}},{key:"prepareElements",value:function(){var t=this;this.applyStyleToElements(function(e){"default"===t.type&&(e.style.opacity="0.0"),"cascade"===t.type&&e.classList.add("frm-init-cascade-animation"),"cascade-3d"===t.type&&e.classList.add("frm-init-fadein-3d"),e.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(t){return t.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(t){this.elements instanceof Element?t(this.elements,0):02&&void 0!==arguments[2]?arguments[2]:"pushState";if(zt.set(t,e),Rt.search=zt.toString(),["pushState","replaceState"].includes(a)){var i=(n={},o=e,(r=function(t){var e=function(t){if("object"!=qt(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=qt(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==qt(e)?e:e+""}(r=t))in n?Object.defineProperty(n,r,{value:o,enumerable:!0,configurable:!0,writable:!0}):n[r]=o,n);window.history[a](i,"",Rt)}return Rt.toString()},Ut=function(t){return zt.has(t)},Ht=function(t){return"string"==typeof t&&/^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(t)},Zt=function(t){return t instanceof HTMLElement||console.warn("Invalid argument: Element must be an instance of HTMLElement")||!1},Jt=function(t){var e;return null===(e=Array.from(t))||void 0===e?void 0:e.forEach(function(t){return Kt(t)})},Yt=function(t){var e;return null===(e=Array.from(t))||void 0===e?void 0:e.forEach(function(t){return Xt(t)})},Kt=function(t){return null==t?void 0:t.classList.remove(tt)},Xt=function(t){return null==t?void 0:t.classList.add(tt)},Wt=function(t){var e=t.currentTarget,n=e.getAttribute("data-category"),r=xt(),o=r.selectedCategory,a=r.selectedCategoryEl,i=r.notEmptySearchText;if(o!==n){o=wp.hooks.applyFilters("frmPage.selectedCategory",n),a.classList.remove(nt),(a=e).classList.add(nt),jt({selectedCategory:o,selectedCategoryEl:a}),i&&te(),wp.hooks.doAction("frmPage.onCategoryClick",o);var c=ht().bodyContent;new Pt(c).fadeIn()}};function Qt(t){"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),Wt(t))}function te(){var t=ht().searchInput;t.value="",t.dispatchEvent(new Event("input",{bubbles:!0}))}var ee=ht().bodyContent,ne=document.getElementById("".concat(l,"-list")),re=document.getElementById("".concat(l,"-custom-list-section")),oe=document.querySelector(".".concat(y,'-cat[data-category="').concat(s,'"]')),ae=document.getElementById("".concat(l,"-modal"));bt({headerCancelButton:null===(Nt=document.getElementById("frm-publishing"))||void 0===Nt?void 0:Nt.querySelector("a"),createFormButton:document.getElementById("".concat(l,"-create-form")),pageTitle:document.getElementById("".concat(l,"-page-title")),pageTitleText:document.getElementById("".concat(l,"-page-title-text")),pageTitleDivider:document.getElementById("".concat(l,"-page-title-divider")),upsellBanner:null!==(Gt=document.getElementById("frm-renew-subscription-banner"))&&void 0!==Gt?Gt:document.getElementById("frm-upgrade-banner"),extraTemplateCountElements:document.querySelectorAll(".".concat(l,"-extra-templates-count")),templatesList:ne,templateItems:ne.querySelectorAll(".frm-card-item"),availableTemplateItems:ne.querySelectorAll(".frm-card-item:not(.".concat(l,"-locked-item)")),twinFeaturedTemplateItems:ne.querySelectorAll(".".concat(l,"-featured-item")),featuredTemplatesList:document.getElementById("".concat(l,"-featured-list")),customTemplatesSection:re,customTemplateItems:re.querySelectorAll(".frm-card-item"),customTemplatesTitle:document.getElementById("".concat(l,"-custom-list-title")),customTemplatesList:document.getElementById("".concat(l,"-custom-list")),favoritesCategory:oe,favoritesCategoryCountEl:null==oe?void 0:oe.querySelector(".".concat(y,"-cat-count")),availableTemplatesCategory:document.querySelector(".".concat(y,'-cat[data-category="').concat(u,'"]')),getFreeTemplatesBannerButton:document.querySelector(".frm-get-free-templates-banner .button"),modal:ae,modalItems:null==ae?void 0:ae.querySelectorAll(".".concat(l,"-modal-item")),showCreateTemplateModalButton:document.getElementById("frm-show-create-template-modal"),createTemplateModal:document.getElementById("frm-create-template-modal"),createTemplateFormsDropdown:document.getElementById("frm-create-template-modal-forms-select"),createTemplateName:document.getElementById("frm_create_template_name"),createTemplateDescription:document.getElementById("frm_create_template_description"),createTemplateButton:document.getElementById("frm-create-template-button"),renewAccountModal:document.getElementById("frm-renew-modal"),leaveEmailModal:document.getElementById("frm-leave-email-modal"),leaveEmailModalInput:document.getElementById("frm_leave_email"),leaveEmailModalButton:document.getElementById("frm-get-code-button"),upgradeModal:document.getElementById("frm-form-upgrade-modal"),upgradeModalTemplateNames:null==ae?void 0:ae.querySelectorAll(".frm-upgrade-modal-template-name"),upgradeModalPlansIcons:null==ae?void 0:ae.querySelectorAll(".frm-upgrade-modal-plan-icon"),upgradeModalLink:document.getElementById("frm-upgrade-modal-link"),newTemplateForm:document.getElementById("frm-new-template"),newTemplateNameInput:document.getElementById("frm_template_name"),newTemplateDescriptionInput:document.getElementById("frm_template_desc"),newTemplateLinkInput:document.getElementById("frm_link"),newTemplateActionInput:document.getElementById("frm_action_type"),bodyContentChildren:null==ee?void 0:ee.children});var ie,ce=window.frmDom,le=ce.tag,ue=ce.div,se=ce.span,me=ce.a,fe=ce.img,pe="".concat(Q,"/images/applications/thumbnails");var de=window.frmFormTemplatesVars,ye=de.templatesCount,ve=de.favoritesCount,he=de.customCount,be=ht().availableTemplateItems.length;jt({availableTemplatesCount:be,customCount:Number(he),extraTemplatesCount:ye-be,favoritesCount:ve}),window.frmDom.span;var ge=function(t,e){return t.textContent=String(e),t},we=function(t,e,n,r,o,a,i){e._counterStartTime||(e._counterStartTime=t,e._counterLastTimestamp=t,e._counterFrameDropCount=0,e._counterLastValue=n);var c=t-e._counterLastTimestamp,l=t-e._counterStartTime;if(c>50&&null!==e._counterLastTimestamp&&(e._counterFrameDropCount++,e._counterFrameDropCount>3))return e.style.transition="opacity ".concat(Math.max(o-l,100),"ms ease-out"),e.textContent=String(r),void delete e._counterAnimation;var u=Math.min(l/o,1),s=i(u),m=Math.round(n+a*s);m!==e._counterLastValue&&(e.textContent=String(m),e._counterLastValue=m),e._counterLastTimestamp=t,u<1?e._counterAnimation=requestAnimationFrame(function(t){return we(t,e,n,r,o,a,i)}):(e.textContent=String(r),["_counterAnimation","_counterStartTime","_counterLastTimestamp","_counterFrameDropCount","_counterLastValue"].forEach(function(t){return delete e[t]}),e.style.removeProperty("transition"))},Se=function(t){return 1-Math.pow(1-t,4)};const Te=function(){var t,e=ht(),n=e.sidebar,r=e.searchInput,o=e.bodyContent,a=e.twinFeaturedTemplateItems,c=e.availableTemplatesCategory,l=e.extraTemplateCountElements,u=new Pt(o);r.value="",Yt(a),function(t){if(t){var e,n,r=Ot("availableTemplatesCount");if(Ut("registered-for-free-templates"))history.replaceState({},"",Vt("registered-for-free-templates")),e=t,n=r,setTimeout(function(){e.dispatchEvent(new Event("click",{bubbles:!0}))},0),setTimeout(function(){!function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r="string"==typeof t?document.querySelector(t):t;if(!(r&&r instanceof HTMLElement))return null;var o="number"==typeof e?e:parseInt(e,10);if(isNaN(o))return console.warn("Counter: Invalid value provided, defaulting to 0"),ge(r,"0");if(0===o)return ge(r,"0");var a=n.duration,i=void 0===a?3e3:a,c=n.easing,l=void 0===c?Se:c,u=parseInt(r.textContent,10)||0,s=o-u;0===s||(r._counterAnimation&&cancelAnimationFrame(r._counterAnimation),r.classList.add("frm-fadein"),r._counterAnimation=requestAnimationFrame(function(t){return we(t,r,u,o,i,s,l)}))}(e.querySelector(".".concat(y,"-cat-count")),n)},150),setTimeout(function(){ht().availableTemplateItems.forEach(function(t){i.includes(Number(t.dataset.id))||(t.classList.add("frm-background-highlight"),t.addEventListener("animationend",function t(e){"backgroundHighlight"===e.animationName&&(this.classList.remove("frm-background-highlight"),this.removeEventListener("animationend",t))}))})},750);else t.querySelector(".".concat(y,"-cat-count")).textContent=r}}(c),l.forEach(function(t){return t.textContent=Ot("extraTemplatesCount")}),o.classList.remove(et),n.classList.remove(et),u.fadeIn(),Ut("return_page")&&(t=ht().headerCancelButton,new Pt(t).fadeIn())};function _e(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function a(n,r,o,a){var l=r&&r.prototype instanceof c?r:c,u=Object.create(l.prototype);return Ee(u,"_invoke",function(n,r,o){var a,c,l,u=0,s=o||[],m=!1,f={p:0,n:0,v:t,a:p,f:p.bind(t,4),d:function(e,n){return a=e,c=0,l=t,f.n=n,i}};function p(n,r){for(c=n,l=r,e=0;!m&&u&&!o&&e3?(o=d===r)&&(l=a[(c=a[4])?5:(c=3,3)],a[4]=a[5]=t):a[0]<=p&&((o=n<2&&pr||r>d)&&(a[4]=n,a[5]=r,f.n=d,c=0))}if(o||n>1)return i;throw m=!0,r}return function(o,s,d){if(u>1)throw TypeError("Generator is already running");for(m&&1===s&&p(s,d),c=s,l=d;(e=c<2?t:l)||!m;){a||(c?c<3?(c>1&&(f.n=-1),p(c,l)):f.n=l:f.v=l);try{if(u=2,a){if(c||(o="next"),e=a[o]){if(!(e=e.call(a,l)))throw TypeError("iterator result is not an object");if(!e.done)return e;l=e.value,c<2&&(c=0)}else 1===c&&(e=a.return)&&e.call(a),c<2&&(l=TypeError("The iterator does not provide a '"+o+"' method"),c=1);a=t}else if((e=(m=f.n<0)?l:n.call(r,f))!==i)break}catch(e){a=t,c=1,l=e}finally{u=1}}return{value:e,done:m}}}(n,o,a),!0),u}var i={};function c(){}function l(){}function u(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(Ee(e={},r,function(){return this}),e),m=u.prototype=c.prototype=Object.create(s);function f(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,Ee(t,o,"GeneratorFunction")),t.prototype=Object.create(m),t}return l.prototype=u,Ee(m,"constructor",u),Ee(u,"constructor",l),l.displayName="GeneratorFunction",Ee(u,o,"GeneratorFunction"),Ee(m),Ee(m,o,"Generator"),Ee(m,r,function(){return this}),Ee(m,"toString",function(){return"[object Generator]"}),(_e=function(){return{w:a,m:f}})()}function Ee(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}Ee=function(t,e,n,r){function a(e,n){Ee(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(a("next",0),a("throw",1),a("return",2))},Ee(t,e,n,r)}function xe(t,e,n,r,o,a,i){try{var c=t[a](i),l=c.value}catch(t){return void n(t)}c.done?e(l):Promise.resolve(l).then(r,o)}var Oe=null;function je(){var t;return t=_e().m(function t(){var e,n,r;return _e().w(function(t){for(;;)switch(t.n){case 0:e=window.frmAdminBuild,n=e.initModal,r=e.offsetModalY,(Oe=n("#frm-form-templates-modal",p))&&r(Oe,"103px"),Ut("free-templates")&&ht().leaveEmailModal&&dn(),wp.hooks.addAction("frmAdmin.beforeOpenConfirmModal","frmFormTemplates",function(t){var e=t.$info;e.dialog("option","width",d),r(e,"103px")});case 1:return t.a(2)}},t)}),je=function(){var e=this,n=arguments;return new Promise(function(r,o){var a=t.apply(e,n);function i(t){xe(a,r,o,i,c,"next",t)}function c(t){xe(a,r,o,i,c,"throw",t)}i(void 0)})},je.apply(this,arguments)}function Ie(){return Oe}function Ce(t){var e=ht().pageTitleText,n=t||Ot("selectedCategoryEl").querySelector(".".concat(y,"-cat-text")).textContent;e.textContent=n}var Ae=function(t){return!!Zt(t)&&t.classList.contains("".concat(l,"-favorite-item"))},ke=function(t){return!!Zt(t)&&t.classList.contains("".concat(l,"-custom-item"))},Pe={},Fe=function(){var t=ht(),e=t.createFormButton,n=t.newTemplateForm,r=t.newTemplateNameInput,o=t.newTemplateActionInput,a=window.frmAdminBuild.installNewForm;r.value="",o.value="frm_install_form",a(n,"frm_install_form",e)};var Le=".".concat(l,"-item-favorite-button"),Be="".concat(Le," use"),De="#frm_heart_solid_icon",Me="#frm_heart_icon",qe=function(t){var e,n=t.currentTarget,r=ht(),o=r.templatesList,i=r.featuredTemplatesList,c=r.favoritesCategoryCountEl,u=r.customTemplatesTitle,m=n.closest(".frm-card-item"),f=m.dataset.id,p=Ae(m),d=ke(m),y=function(t){return!!Zt(t)&&a.includes(Number(t.dataset.id))}(m),v=null;if(m.classList.toggle("".concat(l,"-favorite-item"),!p),y){var h=m.closest("#".concat(l,"-list"))?i:o;h&&(v=h.querySelector('.frm-card-item[data-id="'.concat(f,'"]'))).classList.toggle("".concat(l,"-favorite-item"),!p)}var b,g=xt(),w=g.selectedCategory,S=g.favoritesCount,T=p?"remove":"add",_=m.querySelector(Be),E=null===(e=v)||void 0===e?void 0:e.querySelector(Be);"add"===T?(++S.total,d?++S.custom:++S.default,_.setAttribute("href",De),null==E||E.setAttribute("href",De)):(--S.total,d?--S.custom:--S.default,_.setAttribute("href",Me),null==E||E.setAttribute("href",Me)),c.textContent=S.total,It("favoritesCount",S),s===w&&(0===S.total&&on(),Xt(m),0===S.default&&Xt(o),0!==S.custom&&0!==S.default||Xt(u)),b=function(){return t=f,e=T,n=d,r=new FormData,o=frmDom.ajax.doJsonPost,r.append("template_id",t),r.append("operation",e),r.append("is_custom_template",n),o("add_or_remove_favorite_template",r);var t,e,n,r,o},Ft=Ft.then(b).catch(b)};var Ne=function(t){var e=t.currentTarget,n=e.closest(".frm-card-item"),r=function(t){return!!Zt(t)&&t.classList.contains("".concat(l,"-locked-item"))}(n),o=ke(n);if(r||!o)if(t.preventDefault(),r)!function(t){var e=t.dataset.requiredPlan;switch(e){case"basic":case"plus":case"business":case"elite":fn(e,t);break;case"renew":pn();break;case"free":dn()}}(n);else{var a=ht(),i=a.newTemplateForm,c=a.newTemplateNameInput,u=a.newTemplateDescriptionInput,s=a.newTemplateLinkInput,m=a.newTemplateActionInput,f=window.frmAdminBuild.installNewForm,p=n.querySelector(".frm-form-template-name").textContent.trim(),d=n.querySelector(".frm-form-templates-item-description").textContent.trim(),y="frm_install_template";c.value=p,u.value=d,m.value=y,s.value=e.href,f(i,y,e)}};var Ge=window.frmDom.search.init;function Re(t,e){var n=t.foundSomething,r=t.notEmptySearchText;if(!e||"search"!==e.type||""!==e.target.value){var o=xt(),a=ht().allItemsCategory;It("notEmptySearchText",r),o.notEmptySearchText||o.selectedCategory?(o.selectedCategory&&(function(t){var e=ht(),n=e.bodyContent,r=e.bodyContentChildren,o=e.pageTitle,a=e.templatesList,i=e.applicationTemplates,c=new Pt(n);t&&Ot("selectedCategoryEl").classList.remove(nt),Yt(r),Ce(X("Search Result","formidable")),Jt([o,a,i]),c.fadeIn()}(r),r&&It("selectedCategory","")),function(t){if(t){var e,n=ht().emptyState;if(e=n,"none"!==window.getComputedStyle(e).getPropertyValue("display")){var r=ht().pageTitle;Xt(n),Kt(r)}var o=ht(),a=o.templatesList,i=o.applicationTemplates,c=o.applicationTemplatesTitle,l=o.applicationTemplatesList;Jt([a,i,c]),0===a.offsetHeight&&Yt([a,c]),0===(null==l?void 0:l.offsetHeight)&&Xt(i)}else!function(){var t,e=xt().notEmptySearchText,n=ht(),r=n.pageTitle,o=n.emptyState,a=n.emptyStateButton,i=n.applicationTemplates;if(f!==(null===(t=o.dataset)||void 0===t?void 0:t.view)){o.setAttribute("data-view",f);var c=ht(),l=c.emptyStateTitle,u=c.emptyStateText;l.textContent=X("No templates found","formidable"),u.textContent=X("Sorry, we didn't find any templates that match your criteria.","formidable"),a.textContent=X("Start from Scratch","formidable"),Yt([r,i]),Jt([o,a])}else e?(Kt(o),Yt([r,i])):(Xt(o),o.removeAttribute("data-view"))}()}(n)):a.dispatchEvent(new Event("click",{bubbles:!0}))}}var ze=function(){var t,e=ht().emptyState;f===(null===(t=e.dataset)||void 0===t?void 0:t.view)&&(It("selectedCategory",""),te(),ht().searchInput.focus())};var Ve=function(){var t=xt().selectedCategory;m===t&&yn()},$e=function(){var t=ht().createTemplateFormsDropdown,e=t.value;if(e&&"no-forms"!==e){Ue(!1);var n=t.options[t.selectedIndex],r=n.dataset.description.trim(),o=n.dataset.name.trim(),a=" ".concat(X("Template","formidable"));o.endsWith(a)||(o+=a);var i=ht(),c=i.createTemplateName,l=i.createTemplateDescription;c.value=o,l.value=r}else Ue(!0)},Ue=function(t){var e=ht(),n=e.createTemplateName,r=e.createTemplateDescription,o=e.createTemplateButton;[n,r].forEach(function(e){e.disabled=t,t&&(e.value="")}),o.classList.toggle("disabled",t)},He=function(){var t=window.frmAdminBuild.installNewForm,e="frm_create_template",n=ht(),r=n.newTemplateForm,o=n.newTemplateActionInput,a=n.newTemplateNameInput,i=n.newTemplateDescriptionInput,c=n.newTemplateLinkInput,l=n.createTemplateName,u=n.createTemplateDescription,s=n.createTemplateFormsDropdown,m=n.createTemplateButton;o.value=e,a.value=l.value.trim(),i.value=u.value.trim(),c.value=s.value,t(r,e,m)};function Ze(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function a(n,r,o,a){var l=r&&r.prototype instanceof c?r:c,u=Object.create(l.prototype);return Je(u,"_invoke",function(n,r,o){var a,c,l,u=0,s=o||[],m=!1,f={p:0,n:0,v:t,a:p,f:p.bind(t,4),d:function(e,n){return a=e,c=0,l=t,f.n=n,i}};function p(n,r){for(c=n,l=r,e=0;!m&&u&&!o&&e3?(o=d===r)&&(l=a[(c=a[4])?5:(c=3,3)],a[4]=a[5]=t):a[0]<=p&&((o=n<2&&pr||r>d)&&(a[4]=n,a[5]=r,f.n=d,c=0))}if(o||n>1)return i;throw m=!0,r}return function(o,s,d){if(u>1)throw TypeError("Generator is already running");for(m&&1===s&&p(s,d),c=s,l=d;(e=c<2?t:l)||!m;){a||(c?c<3?(c>1&&(f.n=-1),p(c,l)):f.n=l:f.v=l);try{if(u=2,a){if(c||(o="next"),e=a[o]){if(!(e=e.call(a,l)))throw TypeError("iterator result is not an object");if(!e.done)return e;l=e.value,c<2&&(c=0)}else 1===c&&(e=a.return)&&e.call(a),c<2&&(l=TypeError("The iterator does not provide a '"+o+"' method"),c=1);a=t}else if((e=(m=f.n<0)?l:n.call(r,f))!==i)break}catch(e){a=t,c=1,l=e}finally{u=1}}return{value:e,done:m}}}(n,o,a),!0),u}var i={};function c(){}function l(){}function u(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(Je(e={},r,function(){return this}),e),m=u.prototype=c.prototype=Object.create(s);function f(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,Je(t,o,"GeneratorFunction")),t.prototype=Object.create(m),t}return l.prototype=u,Je(m,"constructor",u),Je(u,"constructor",l),l.displayName="GeneratorFunction",Je(u,o,"GeneratorFunction"),Je(m),Je(m,o,"Generator"),Je(m,r,function(){return this}),Je(m,"toString",function(){return"[object Generator]"}),(Ze=function(){return{w:a,m:f}})()}function Je(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}Je=function(t,e,n,r){function a(e,n){Je(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(a("next",0),a("throw",1),a("return",2))},Je(t,e,n,r)}function Ye(t,e,n,r,o,a,i){try{var c=t[a](i),l=c.value}catch(t){return void n(t)}c.done?e(l):Promise.resolve(l).then(r,o)}var Ke=window.frmDom.tag,Xe=function(){var t,e=(t=Ze().m(function t(){var e,n,r,o,a,i,c,l,u;return Ze().w(function(t){for(;;)switch(t.p=t.n){case 0:if(e=ht(),n=e.leaveEmailModalInput,r=n.value.trim()){t.n=1;break}return vn("empty"),t.a(2);case 1:if(Ht(r)){t.n=2;break}return vn("invalid"),t.a(2);case 2:return o=ht(),(a=o.leaveEmailModalButton).style.setProperty("cursor","not-allowed"),a.classList.add("frm_loading_button"),(i=new FormData).append("email",r),l=frmDom.ajax.doJsonPost,t.p=3,t.n=4,l("get_free_templates",i);case 4:c=t.v,t.n=6;break;case 5:return t.p=5,u=t.v,console.error("An error occurred:",u),We(),t.a(2);case 6:if(c.success){t.n=7;break}return We(),t.a(2);case 7:Ut("free-templates")&&Vt("free-templates"),$t("registered-for-free-templates","1"),window.location.reload();case 8:return t.a(2)}},t,null,[[3,5]])}),function(){var e=this,n=arguments;return new Promise(function(r,o){var a=t.apply(e,n);function i(t){Ye(a,r,o,i,c,"next",t)}function c(t){Ye(a,r,o,i,c,"throw",t)}i(void 0)})});return function(){return e.apply(this,arguments)}}();function We(){var t=ht().leaveEmailModal;t.querySelector(".inside").replaceChildren(Ke("p",X("Failed to get templates, please try again later.","formidable"))),t.querySelector(".frm_modal_footer").classList.add("frm_hidden")}var Qe=function(t){if(!t.target.closest("a")){var e=t.currentTarget;window.location.href=e.dataset.href}};function tn(){var t,e,n,r;ht().categoryItems.forEach(function(t){Mt(t,Wt),t.addEventListener("keydown",Qt)}),wp.hooks.addAction("frmPage.onCategoryClick","frmFormTemplates",function(t){!function(t){var e=ht(),n=e.bodyContentChildren,r=e.pageTitle,o=e.showCreateTemplateModalButton,a=e.templatesList,i=e.templateItems,c=e.upsellBanner;switch(v!==t&&Yt(n),Ce(),Xt(o),Kt(r),t){case v:!function(){var t=ht(),e=t.bodyContentChildren,n=t.pageTitleDivider,r=t.templateItems,o=t.twinFeaturedTemplateItems,a=t.customTemplatesSection,i=t.emptyState,c=t.applicationTemplates;Jt([].concat(nn(e),nn(r))),Yt([n].concat(nn(o),[a,i,c]))}();break;case u:!function(){if(0!==xt().availableTemplatesCount){var t=ht(),e=t.templatesList,n=t.templateItems,r=t.availableTemplateItems,o=t.upsellBanner;Yt(n),Jt([o,e].concat(nn(r)))}else!function(){var t=ht(),e=t.pageTitle,n=t.emptyState,r=t.emptyStateButton;n.setAttribute("data-view",u);var o=ht(),a=o.emptyStateTitle,i=o.emptyStateText,c=xt().extraTemplatesCount;a.textContent=X("No Templates Available","formidable"),i.textContent=function(t){try{for(var e=arguments.length,n=new Array(e>1?e-1:0),r=1;r0&&s.push(r),t.custom>0){var f=Array.from(u).filter(function(t){return!Ae(t)});Yt(f),s.push(a),s.push(c),0===t.default?Xt(i):s.push(i)}Jt(s)}else on()}();break;case m:!function(){if(0!==xt().customCount){var t=ht(),e=t.showCreateTemplateModalButton,n=t.pageTitleDivider,r=t.customTemplatesSection,o=t.customTemplatesList,a=t.customTemplatesTitle,i=t.customTemplateItems;Xt(a),Jt([e,n,r,o].concat(nn(i)))}else!function(){var t=ht(),e=t.pageTitle,n=t.emptyState,r=t.emptyStateButton;n.setAttribute("data-view",m);var o=ht(),a=o.emptyStateTitle,i=o.emptyStateText;a.textContent=X("You currently have no templates.","formidable"),i.textContent=X("You haven't created any form templates. Begin now to simplify your workflow and save time.","formidable"),r.textContent=X("Create Template","formidable"),Xt(e),Jt([n,r])}()}();break;default:Yt(i),Jt([c,a].concat(nn(Pe[t])))}}(t)}),r=ht().createFormButton,Mt(r,Fe),document.querySelectorAll(Le).forEach(function(t){return Mt(t,qe)}),document.querySelectorAll(".".concat(l,"-use-template-button")).forEach(function(t){return t.addEventListener("click",Ne)}),t=ht(),e=t.searchInput,n=t.emptyStateButton,Ge(e,"frm-card-item",{handleSearchResult:Re}),Mt(n,ze),function(){var t=ht(),e=t.createTemplateFormsDropdown,n=t.createTemplateButton,r=t.showCreateTemplateModalButton,o=t.emptyStateButton;Mt(r,Ve),Mt(o,Ve),e.addEventListener("change",$e),Mt(n,He)}(),function(){var t=ht(),e=t.leaveEmailModalButton,n=t.getFreeTemplatesBannerButton;Mt(e,Xe),Mt(n,dn)}()}function en(t){var e,n;(function(t){if(t&&t.length){var e=t.map(function(t){return function(t){var e=t.name,n=t.key,o=t.hasLiteThumbnail,a=t.isWebp,i=o?a?"".concat(pe,"/").concat(n,".webp"):"".concat(pe,"/").concat(n,".png"):"".concat(pe,"/placeholder.svg");return le("li",{className:"frm-card-item",data:{href:"".concat(r,"&triggerViewApplicationModal=1&template=").concat(n),"frm-search-text":e.toLowerCase()},children:[ue({className:"".concat(l,"-item-icon"),child:fe({src:i})}),ue({className:"".concat(l,"-item-body"),children:[se({text:X("Ready Made Solution","formidable"),className:"frm-meta-tag frm-orange-tag frm-text-xs"}),le("h3",{text:e,className:"frm-text-sm frm-font-medium frm-m-0"}),me({text:X("See all applications","formidable"),className:"frm-text-xs frm-font-semibold",href:r})]})]})}(t)});ie=ue({id:"".concat(l,"-applications"),className:tt,children:[le("h2",{text:X("Application Templates"),className:"frm-text-sm frm-mb-sm"}),le("ul",{className:"".concat(l,"-list frm-list-grid-layout"),children:e})]})}})(t.templates),(e=ht()).applicationTemplates||void 0===ie||(e.bodyContent.append(ie),bt({applicationTemplates:ie,applicationTemplatesTitle:ie.querySelector("h2"),applicationTemplatesList:ie.querySelector(".".concat(l,"-list")),applicationTemplateItems:ie.querySelectorAll(".frm-card-item")})),void 0!==(n=ht().applicationTemplateItems)&&n.forEach(function(t){t.addEventListener("click",Qe)})}function nn(t){return function(t){if(Array.isArray(t))return rn(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return rn(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?rn(t,e):void 0}}(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function rn(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n3?(o=d===r)&&(l=a[(c=a[4])?5:(c=3,3)],a[4]=a[5]=t):a[0]<=p&&((o=n<2&&pr||r>d)&&(a[4]=n,a[5]=r,f.n=d,c=0))}if(o||n>1)return i;throw m=!0,r}return function(o,s,d){if(u>1)throw TypeError("Generator is already running");for(m&&1===s&&p(s,d),c=s,l=d;(e=c<2?t:l)||!m;){a||(c?c<3?(c>1&&(f.n=-1),p(c,l)):f.n=l:f.v=l);try{if(u=2,a){if(c||(o="next"),e=a[o]){if(!(e=e.call(a,l)))throw TypeError("iterator result is not an object");if(!e.done)return e;l=e.value,c<2&&(c=0)}else 1===c&&(e=a.return)&&e.call(a),c<2&&(l=TypeError("The iterator does not provide a '"+o+"' method"),c=1);a=t}else if((e=(m=f.n<0)?l:n.call(r,f))!==i)break}catch(e){a=t,c=1,l=e}finally{u=1}}return{value:e,done:m}}}(n,o,a),!0),u}var i={};function c(){}function l(){}function u(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(cn(e={},r,function(){return this}),e),m=u.prototype=c.prototype=Object.create(s);function f(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,cn(t,o,"GeneratorFunction")),t.prototype=Object.create(m),t}return l.prototype=u,cn(m,"constructor",u),cn(u,"constructor",l),l.displayName="GeneratorFunction",cn(u,o,"GeneratorFunction"),cn(m),cn(m,o,"Generator"),cn(m,r,function(){return this}),cn(m,"toString",function(){return"[object Generator]"}),(an=function(){return{w:a,m:f}})()}function cn(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}cn=function(t,e,n,r){function a(e,n){cn(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(a("next",0),a("throw",1),a("return",2))},cn(t,e,n,r)}function ln(t,e,n,r,o,a,i){try{var c=t[a](i),l=c.value}catch(t){return void n(t)}c.done?e(l):Promise.resolve(l).then(r,o)}function un(t){return function(){var e=this,n=arguments;return new Promise(function(r,o){var a=t.apply(e,n);function i(t){ln(a,r,o,i,c,"next",t)}function c(t){ln(a,r,o,i,c,"throw",t)}i(void 0)})}}var sn=function(t){return un(an().m(function e(){var n,r,o,a,i,c,l=arguments;return an().w(function(e){for(;;)switch(e.n){case 0:if(n=Ie()){e.n=1;break}return e.a(2);case 1:for(r=ht(),o=r.modalItems,Yt(o),n.dialog("option","width",p),a=l.length,i=new Array(a),c=0;c use").setAttribute("href",r?"#frm_checkmark_icon":"#frm_close_icon")});var u=e.dataset.slug?"-".concat(e.dataset.slug):"";l.href=c+u,Kt(o)}),pn=sn(function(){var t=ht().renewAccountModal;Kt(t)}),dn=sn(function(){var t=ht().leaveEmailModal;Kt(t)}),yn=sn(function(){Ie().dialog("option","width",d);var t=ht().createTemplateModal;Kt(t)}),vn=function(t){!function(t,e,n){var r=document.querySelector("#frm_leave_email"),o=document.querySelector("#frm_leave_email_error");r&&o?(o.setAttribute("frm-error",n),Kt(o),r.addEventListener("keyup",function(){Xt(o)},{once:!0})):console.warn("showFormError: Unable to find input or error element.")}(0,0,t)};var hn;hn=function(){wp.hooks.doAction("frmFormTemplates.beforeInitialize",{getState:xt,setState:jt}),e&&(0,frmDom.ajax.doJsonFetch)("get_applications_data&view=templates").then(en),function(){je.apply(this,arguments)}(),ht().templateItems.forEach(function(t){t.getAttribute("data-categories").split(",").forEach(function(e){Pe[e]||(Pe[e]=[]),Pe[e].push(t)})}),Te(),tn(),wp.hooks.doAction("frmFormTemplates.afterInitialize",{getState:xt,setState:jt}),wp.hooks.doAction("frm_new_form_modal_form",jQuery("#frm-new-template"))},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",hn):hn())})()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": +/*!*****************************************************************!*\ + !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ domReady) +/* harmony export */ }); +/** + * @typedef {() => void} Callback + * + * TODO: Remove this typedef and inline `() => void` type. + * + * This typedef is used so that a descriptive type is provided in our + * automatically generated documentation. + * + * An in-line type `() => void` would be preferable, but the generated + * documentation is `null` in that case. + * + * @see https://github.com/WordPress/gutenberg/issues/18045 + */ + +/** + * Specify a function to execute when the DOM is fully loaded. + * + * @param {Callback} callback A function to execute after the DOM is ready. + * + * @example + * ```js + * import domReady from '@wordpress/dom-ready'; + * + * domReady( function() { + * //do something after DOM loads. + * } ); + * ``` + * + * @return {void} + */ +function domReady(callback) { + if (typeof document === 'undefined') { + return; + } + + if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. + document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. + ) { + return void callback(); + } // DOMContentLoaded has not fired yet, delay callback until then. + + + document.addEventListener('DOMContentLoaded', callback); +} +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/factory/createPageElements.js": +/*!***************************************************!*\ + !*** ./js/src/core/factory/createPageElements.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* binding */ createPageElements) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page elements manager. + * + * @param {Object} [initialElements={}] An object containing initial DOM elements. + * @throws {Error} Throws an error if the `initialElements` is not an object. + * @return {Object} An object with methods to get and add elements. + */ +function createPageElements() { + var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialElements) !== 'object' || initialElements === null) { + throw new Error('createPageElements: initialElements must be a non-null object'); + } + var elements = initialElements; + + /** + * Retrieve the initialized essential DOM elements. + * + * @return {Object} The initialized elements object. + */ + function getElements() { + return elements; + } + + /** + * Add new elements to the elements object. + * + * @param {Object} newElements An object containing new elements to be added. + * @throws {Error} Throws an error if the `newElements` is not a non-null object. + * @return {void} Updates the elements object by merging the new elements into it. + */ + function addElements(newElements) { + if (_typeof(newElements) !== 'object' || newElements === null) { + throw new Error('addElements: newElements must be a non-null object'); + } + elements = _objectSpread(_objectSpread({}, elements), newElements); + } + return { + getElements: getElements, + addElements: addElements + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/createPageState.js": +/*!************************************************!*\ + !*** ./js/src/core/factory/createPageState.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageState: () => (/* binding */ createPageState) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page state manager. + * + * @param {Object} [initialState={}] An object containing the initial state. + * @throws {Error} Throws an error if the `initialState` is not a plain object. + * @return {Object} An object with methods to initialize, get, and set the page state. + */ +function createPageState() { + var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialState) !== 'object' || initialState === null) { + throw new Error('createPageState: initialState must be a non-null object'); + } + var state = initialState; + + /** + * Returns the current page state. + * + * @return {Object|null} The current state of the page or null if not initialized. + */ + var getState = function getState() { + return state; + }; + + /** + * Returns a specific property from the current page state. + * + * @param {string} propertyName The name of the property to retrieve. + * @return {*} The value of the specified property, or null if it doesn't exist. + */ + var getSingleState = function getSingleState(propertyName) { + var value = Reflect.get(state, propertyName); + + // We convert `undefined` to `null` for a consistent API. + // This makes it easier for users to handle the results since all missing properties return `null`. + return value === undefined ? null : value; + }; + + /** + * Updates the page state with new values. + * + * @param {Object} newState The new values to update the state with. + * @throws {Error} Throws an error if `newState` is not a plain object. + * @return {void} + */ + var setState = function setState(newState) { + if (_typeof(newState) !== 'object' || newState === null) { + throw new Error('setState: newState must be a non-null object'); + } + state = _objectSpread(_objectSpread({}, state), newState); + }; + + /** + * Updates a specific property in the page state with a new value. + * + * @param {string} propertyName The name of the property to update. + * @param {*} value The new value to set for the property. + * @return {void} + */ + var setSingleState = function setSingleState(propertyName, value) { + if (Reflect.has(state, propertyName)) { + Reflect.set(state, propertyName, value); + } + }; + return { + getState: getState, + getSingleState: getSingleState, + setState: setState, + setSingleState: setSingleState + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/index.js": +/*!**************************************!*\ + !*** ./js/src/core/factory/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), +/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) +/* harmony export */ }); +/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); +/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); + + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/constants.js": +/*!************************************************!*\ + !*** ./js/src/core/page-skeleton/constants.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ PREFIX: () => (/* binding */ PREFIX), +/* harmony export */ SEARCH_RESULT_ITEM: () => (/* binding */ SEARCH_RESULT_ITEM), +/* harmony export */ VIEWS: () => (/* binding */ VIEWS) +/* harmony export */ }); +var PREFIX = 'frm-page-skeleton'; +var SEARCH_RESULT_ITEM = 'frm-card-item'; +var VIEWS = { + ALL_ITEMS: 'all-items' +}; + +/***/ }), + +/***/ "./js/src/core/page-skeleton/elements/elements.js": +/*!********************************************************!*\ + !*** ./js/src/core/page-skeleton/elements/elements.js ***! + \********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* binding */ addElements), +/* harmony export */ getElements: () => (/* binding */ getElements) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); +/* harmony import */ var _emptyStateElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./emptyStateElement */ "./js/src/core/page-skeleton/elements/emptyStateElement.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +var bodyContent = document.getElementById('post-body-content'); +var sidebar = document.getElementById("".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-sidebar")); + +// Append empty state elements to body content +var emptyState = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.createEmptyStateElement)(); +bodyContent === null || bodyContent === void 0 || bodyContent.append(emptyState); +var emptyStateElements = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.getEmptyStateElements)(); +var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)(_objectSpread({ + bodyContent: bodyContent, + // Sidebar elements + sidebar: sidebar, + searchInput: sidebar.querySelector('.frm-search-input'), + categoryItems: sidebar.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat")), + allItemsCategory: sidebar.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS, "\"]")) + }, emptyStateElements)), + getElements = _createPageElements.getElements, + addElements = _createPageElements.addElements; + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/elements/emptyStateElement.js": +/*!*****************************************************************!*\ + !*** ./js/src/core/page-skeleton/elements/emptyStateElement.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createEmptyStateElement: () => (/* binding */ createEmptyStateElement), +/* harmony export */ getEmptyStateElements: () => (/* binding */ getEmptyStateElements) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + +var _window$frmDom = window.frmDom, + tag = _window$frmDom.tag, + div = _window$frmDom.div, + a = _window$frmDom.a, + img = _window$frmDom.img; + +/** + * Create and return the Empty State HTML element. + * + * @return {HTMLElement} The Empty State element. + */ +function createEmptyStateElement() { + var button = a({ + className: 'button button-primary frm-button-primary' + }); + button.setAttribute('role', 'button'); + return div({ + id: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state"), + className: "frm-flex-col frm-flex-center frm-gap-md ".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS), + children: [img({ + src: "".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.PLUGIN_URL, "/images/page-skeleton/empty-state.svg"), + alt: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Empty State', 'formidable') + }), div({ + className: 'frmcenter', + children: [tag('h2', { + className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title frm-mb-0") + }), tag('p', { + className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text frm-mb-0") + })] + }), button] + }); +} + +/** + * Return the elements related to the Empty State. + * + * @return {Object} Object containing Empty State related DOM elements. + */ +function getEmptyStateElements() { + var emptyState = document.querySelector("#".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state")); + return { + emptyState: emptyState, + emptyStateTitle: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title")), + emptyStateText: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text")), + emptyStateButton: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector('.button') + }; +} + +/***/ }), + +/***/ "./js/src/core/page-skeleton/elements/index.js": +/*!*****************************************************!*\ + !*** ./js/src/core/page-skeleton/elements/index.js ***! + \*****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/elements.js"); + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/events/categoryListener.js": +/*!**************************************************************!*\ + !*** ./js/src/core/page-skeleton/events/categoryListener.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addCategoryEvents: () => (/* binding */ addCategoryEvents) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/core/page-skeleton/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! . */ "./js/src/core/page-skeleton/events/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + +/** + * Manages event handling for sidebar category links. + * + * @return {void} + */ +function addCategoryEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + categoryItems = _getElements.categoryItems; + + // Attach click and keyboard event listeners to each sidebar category + categoryItems.forEach(function (category) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(category, onCategoryClick); + category.addEventListener('keydown', onCategoryKeydown); + }); +} + +/** + * Handles the click event on a category item. + * + * @private + * @param {Event} event The click event object. + */ +var onCategoryClick = function onCategoryClick(event) { + var clickedCategory = event.currentTarget; + var newSelectedCategory = clickedCategory.getAttribute('data-category'); + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + selectedCategory = _getState.selectedCategory, + selectedCategoryEl = _getState.selectedCategoryEl, + notEmptySearchText = _getState.notEmptySearchText; + + // If the selected category hasn't changed, return early + if (selectedCategory === newSelectedCategory) { + return; + } + + /** + * Filter hook to modify the selected category. + * + * @param {string} selectedCategory The selected category + */ + selectedCategory = wp.hooks.applyFilters('frmPage.selectedCategory', newSelectedCategory); + + // Highlight the newly clicked category and update the application state + selectedCategoryEl.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + selectedCategoryEl = clickedCategory; + selectedCategoryEl.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setState)({ + selectedCategory: selectedCategory, + selectedCategoryEl: selectedCategoryEl + }); + + // Reset the search input if it contains text + if (notEmptySearchText) { + (0,___WEBPACK_IMPORTED_MODULE_4__.resetSearchInput)(); + } + + /** + * Trigger custom action to update category content. + * + * @param {string} selectedCategory The selected category. + */ + wp.hooks.doAction('frmPage.onCategoryClick', selectedCategory); + + // Smoothly display the updated UI elements + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + bodyContent = _getElements2.bodyContent; + new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent).fadeIn(); +}; + +/** + * Handles the keyboard event on a category item. + * + * @param {KeyboardEvent} event The keyboard event object. + * @return {void} + */ +function onCategoryKeydown(event) { + // Only respond to 'Enter' or 'Space' key presses + if (event.key === 'Enter' || event.key === ' ') { + event.preventDefault(); + onCategoryClick(event); + } +} + +/***/ }), + +/***/ "./js/src/core/page-skeleton/events/index.js": +/*!***************************************************!*\ + !*** ./js/src/core/page-skeleton/events/index.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _categoryListener__WEBPACK_IMPORTED_MODULE_1__.addCategoryEvents), +/* harmony export */ resetSearchInput: () => (/* binding */ resetSearchInput) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _categoryListener__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./categoryListener */ "./js/src/core/page-skeleton/events/categoryListener.js"); +/** + * Internal dependencies + */ + + +/** + * Resets the value of the search input and triggers an input event. + * + * @return {void} + */ +function resetSearchInput() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + searchInput = _getElements.searchInput; + searchInput.value = ''; + searchInput.dispatchEvent(new Event('input', { + bubbles: true + })); +} + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/index.js": +/*!********************************************!*\ + !*** ./js/src/core/page-skeleton/index.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), +/* harmony export */ SEARCH_RESULT_ITEM: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.SEARCH_RESULT_ITEM), +/* harmony export */ VIEWS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.VIEWS), +/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.addCategoryEvents), +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.getElements), +/* harmony export */ getSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getState), +/* harmony export */ resetSearchInput: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.resetSearchInput), +/* harmony export */ setSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setState) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/core/page-skeleton/constants.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./shared */ "./js/src/core/page-skeleton/shared/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./events */ "./js/src/core/page-skeleton/events/index.js"); + + + + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/shared/index.js": +/*!***************************************************!*\ + !*** ./js/src/core/page-skeleton/shared/index.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setState) +/* harmony export */ }); +/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageState */ "./js/src/core/page-skeleton/shared/pageState.js"); + + +/***/ }), + +/***/ "./js/src/core/page-skeleton/shared/pageState.js": +/*!*******************************************************!*\ + !*** ./js/src/core/page-skeleton/shared/pageState.js ***! + \*******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* binding */ getSingleState), +/* harmony export */ getState: () => (/* binding */ getState), +/* harmony export */ setSingleState: () => (/* binding */ setSingleState), +/* harmony export */ setState: () => (/* binding */ setState) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + allItemsCategory = _getElements.allItemsCategory; +var _createPageState = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageState)({ + notEmptySearchText: false, + selectedCategory: _constants__WEBPACK_IMPORTED_MODULE_2__.VIEWS.ALL_ITEMS, + selectedCategoryEl: allItemsCategory + }), + getState = _createPageState.getState, + getSingleState = _createPageState.getSingleState, + setState = _createPageState.setState, + setSingleState = _createPageState.setSingleState; + + +/***/ }), + +/***/ "./js/src/core/ui/addProgressToCardBoxes.js": +/*!**************************************************!*\ + !*** ./js/src/core/ui/addProgressToCardBoxes.js ***! + \**************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Internal Dependencies + */ +var span = window.frmDom.span; + +/** + * Adds a progress bar to each card box element to visually indicate its position in the sequence. + * + * @param {Element[]} cardBoxes Collection of card box elements to enhance with progress bars. + * @return {void} + */ +function addProgressToCardBoxes(cardBoxes) { + if (!Array.isArray(cardBoxes) || !cardBoxes.length) { + console.warn('addProgressToCardBoxes: Expected a non-empty array of cardBoxes.'); + return; + } + cardBoxes.forEach(function (element, index) { + // Exclude cards that either don't require a progress bar or already include one + if (!element.classList.contains('frm-has-progress-bar') || element.querySelector('.frm-card-box-progress-bar')) { + return; + } + var progressBar = span(); + var widthPercentage = (index + 1) / cardBoxes.length * 100; + progressBar.style.width = "".concat(widthPercentage, "%"); + var progressBarContainer = span({ + className: 'frm-card-box-progress-bar', + child: progressBar + }); + element.prepend(progressBarContainer); + }); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addProgressToCardBoxes); + +/***/ }), + +/***/ "./js/src/core/ui/counter.js": +/*!***********************************!*\ + !*** ./js/src/core/ui/counter.js ***! + \***********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Updates the text content of an element with a counter value using smooth animation. + * + * @param {HTMLElement|string} element The DOM element or selector to update + * @param {number|string} value The new counter value to set + * @param {Object} options Animation options + * @param {number} options.duration Duration in milliseconds (default: 3000) + * @param {Function} options.easing Easing function (default: easeOutQuart) + * @throws {Error} When element is not found or invalid + * @return {HTMLElement} The updated element for method chaining + */ +var counter = function counter(element, value) { + var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var targetElement = typeof element === 'string' ? document.querySelector(element) : element; + if (!targetElement || !(targetElement instanceof HTMLElement)) { + return null; + } + var targetValue = typeof value === 'number' ? value : parseInt(value, 10); + if (isNaN(targetValue)) { + console.warn('Counter: Invalid value provided, defaulting to 0'); + return setElementValueAndReturn(targetElement, '0'); + } + + // Don't run the animation if the sent value is 0 + if (targetValue === 0) { + return setElementValueAndReturn(targetElement, '0'); + } + var _options$duration = options.duration, + duration = _options$duration === void 0 ? 3000 : _options$duration, + _options$easing = options.easing, + easing = _options$easing === void 0 ? easeOutQuart : _options$easing; + var startValue = parseInt(targetElement.textContent, 10) || 0; + var change = targetValue - startValue; + + // Skip animation if no change needed + if (change === 0) { + return targetElement; + } + + // Cancel any existing animation + if (targetElement._counterAnimation) { + cancelAnimationFrame(targetElement._counterAnimation); + } + + // Start animation + targetElement.classList.add('frm-fadein'); + targetElement._counterAnimation = requestAnimationFrame(function (timestamp) { + return _animateCounter(timestamp, targetElement, startValue, targetValue, duration, change, easing); + }); + return targetElement; +}; + +/** + * Helper function to set element text content and return element + * + * @param {HTMLElement} element Target element + * @param {string|number} value Value to set + * @return {HTMLElement} The element for method chaining + */ +var setElementValueAndReturn = function setElementValueAndReturn(element, value) { + element.textContent = String(value); + return element; +}; + +/** + * Standalone animation function for counter (optimized to prevent redefinition) + * + * @param {number} timestamp Current timestamp from requestAnimationFrame + * @param {HTMLElement} element Target element to animate + * @param {number} startValue Starting counter value + * @param {number} targetValue Target counter value + * @param {number} duration Animation duration in milliseconds + * @param {number} change Total change amount (targetValue - startValue) + * @param {Function} easing Easing function + * @return {void} + */ +var _animateCounter = function animateCounter(timestamp, element, startValue, targetValue, duration, change, easing) { + if (!element._counterStartTime) { + element._counterStartTime = timestamp; + element._counterLastTimestamp = timestamp; + element._counterFrameDropCount = 0; + element._counterLastValue = startValue; + } + var frameDelta = timestamp - element._counterLastTimestamp; + var elapsed = timestamp - element._counterStartTime; + + // Performance monitoring: detect animation stuttering + // If frame gaps exceed 50ms (indicating browser lag/blocking), count as frame drop + if (frameDelta > 50 && element._counterLastTimestamp !== null) { + element._counterFrameDropCount++; + + // Fallback strategy: after 3 frame drops, abandon JS animation for CSS transition + // This prevents choppy animations when browser is under heavy load + if (element._counterFrameDropCount > 3) { + element.style.transition = "opacity ".concat(Math.max(duration - elapsed, 100), "ms ease-out"); + element.textContent = String(targetValue); + delete element._counterAnimation; + return; + } + } + + // Calculate eased progress and current value + var progress = Math.min(elapsed / duration, 1); + var easedProgress = easing(progress); + var currentValue = Math.round(startValue + change * easedProgress); + + // Only update DOM if value actually changed (reduce unnecessary reflows) + if (currentValue !== element._counterLastValue) { + element.textContent = String(currentValue); + element._counterLastValue = currentValue; + } + element._counterLastTimestamp = timestamp; + + // Continue animation or finish + if (progress < 1) { + element._counterAnimation = requestAnimationFrame(function (timestamp) { + return _animateCounter(timestamp, element, startValue, targetValue, duration, change, easing); + }); + return; + } + + // Ensure final value is exact + element.textContent = String(targetValue); + + // Clean up all counter-related properties + ['_counterAnimation', '_counterStartTime', '_counterLastTimestamp', '_counterFrameDropCount', '_counterLastValue'].forEach(function (prop) { + return delete element[prop]; + }); + element.style.removeProperty('transition'); +}; + +/** + * Easing function for smooth animation + * + * @param {number} t Progress from 0 to 1 + * @return {number} Eased value + */ +var easeOutQuart = function easeOutQuart(t) { + return 1 - Math.pow(1 - t, 4); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (counter); + +/***/ }), + +/***/ "./js/src/core/ui/index.js": +/*!*********************************!*\ + !*** ./js/src/core/ui/index.js ***! + \*********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addProgressToCardBoxes: () => (/* reexport safe */ _addProgressToCardBoxes__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ counter: () => (/* reexport safe */ _counter__WEBPACK_IMPORTED_MODULE_1__["default"]) +/* harmony export */ }); +/* harmony import */ var _addProgressToCardBoxes__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./addProgressToCardBoxes */ "./js/src/core/ui/addProgressToCardBoxes.js"); +/* harmony import */ var _counter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./counter */ "./js/src/core/ui/counter.js"); + + + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }), + +/***/ "./js/src/form-templates/elements/applicationTemplatesElement.js": +/*!***********************************************************************!*\ + !*** ./js/src/form-templates/elements/applicationTemplatesElement.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addApplicationTemplatesElement: () => (/* binding */ addApplicationTemplatesElement), +/* harmony export */ createApplicationTemplates: () => (/* binding */ createApplicationTemplates) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./elements */ "./js/src/form-templates/elements/elements.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +var _window$frmDom = window.frmDom, + tag = _window$frmDom.tag, + div = _window$frmDom.div, + span = _window$frmDom.span, + a = _window$frmDom.a, + img = _window$frmDom.img; + +// Application templates element +var applicationTemplates; + +// Base URL for the thumbnail images of applications +var thumbnailBaseURL = "".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.PLUGIN_URL, "/images/applications/thumbnails"); + +/** + * Create and return the application templates HTML element. + * + * @param {Object[]} applications Array of application objects. + * @return {void} + */ +function createApplicationTemplates(applications) { + if (!applications || !applications.length) { + return; + } + var templateItems = applications.map(function (template) { + return createTemplateItem(template); + }); + applicationTemplates = div({ + id: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-applications"), + className: core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS, + children: [tag('h2', { + text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Application Templates'), + className: 'frm-text-sm frm-mb-sm' + }), tag('ul', { + className: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-list frm-list-grid-layout"), + children: templateItems + })] + }); +} + +/** + * Create and return an individual item element for a application template. + * + * @private + * @param {Object} template The application object. + * @return {HTMLElement} Element representing a single application template. + */ +function createTemplateItem(template) { + var name = template.name, + key = template.key, + hasLiteThumbnail = template.hasLiteThumbnail, + isWebp = template.isWebp; + var thumbnailURL = hasLiteThumbnail ? isWebp ? "".concat(thumbnailBaseURL, "/").concat(key, ".webp") : "".concat(thumbnailBaseURL, "/").concat(key, ".png") : "".concat(thumbnailBaseURL, "/placeholder.svg"); + return tag('li', { + className: 'frm-card-item', + data: { + href: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.applicationsUrl, "&triggerViewApplicationModal=1&template=").concat(key), + 'frm-search-text': name.toLowerCase() + }, + children: [div({ + className: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-item-icon"), + child: img({ + src: thumbnailURL + }) + }), div({ + className: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-item-body"), + children: [span({ + text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Ready Made Solution', 'formidable'), + className: 'frm-meta-tag frm-orange-tag frm-text-xs' + }), tag('h3', { + text: name, + className: 'frm-text-sm frm-font-medium frm-m-0' + }), a({ + text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('See all applications', 'formidable'), + className: 'frm-text-xs frm-font-semibold', + href: _shared__WEBPACK_IMPORTED_MODULE_2__.applicationsUrl + })] + })] + }); +} + +/** + * Inject application Templates elements into the DOM and the elements object. + * + * @return {void} + */ +function addApplicationTemplatesElement() { + var elements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(); + if (elements.applicationTemplates || undefined === applicationTemplates) { + return; + } + elements.bodyContent.append(applicationTemplates); + (0,_elements__WEBPACK_IMPORTED_MODULE_3__.addElements)({ + applicationTemplates: applicationTemplates, + applicationTemplatesTitle: applicationTemplates.querySelector('h2'), + applicationTemplatesList: applicationTemplates.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-list")), + applicationTemplateItems: applicationTemplates.querySelectorAll('.frm-card-item') + }); +} + +/***/ }), + +/***/ "./js/src/form-templates/elements/elements.js": +/*!****************************************************!*\ + !*** ./js/src/form-templates/elements/elements.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +var _document$getElementB, _document$getElementB2; +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + +var _getElements = (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + bodyContent = _getElements.bodyContent; +var templatesList = document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-list")); +var customTemplatesSection = document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-custom-list-section")); +var favoritesCategory = document.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_shared__WEBPACK_IMPORTED_MODULE_1__.VIEW_SLUGS.FAVORITES, "\"]")); +var modal = document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-modal")); +(0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements)({ + // Body elements + headerCancelButton: (_document$getElementB = document.getElementById('frm-publishing')) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.querySelector('a'), + createFormButton: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-create-form")), + pageTitle: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-page-title")), + pageTitleText: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-page-title-text")), + pageTitleDivider: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-page-title-divider")), + upsellBanner: (_document$getElementB2 = document.getElementById('frm-renew-subscription-banner')) !== null && _document$getElementB2 !== void 0 ? _document$getElementB2 : document.getElementById('frm-upgrade-banner'), + extraTemplateCountElements: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-extra-templates-count")), + // Templates elements + templatesList: templatesList, + templateItems: templatesList.querySelectorAll('.frm-card-item'), + availableTemplateItems: templatesList.querySelectorAll(".frm-card-item:not(.".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-locked-item)")), + twinFeaturedTemplateItems: templatesList.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-featured-item")), + featuredTemplatesList: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-featured-list")), + // Custom Templates Section elements + customTemplatesSection: customTemplatesSection, + customTemplateItems: customTemplatesSection.querySelectorAll('.frm-card-item'), + customTemplatesTitle: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-custom-list-title")), + customTemplatesList: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-custom-list")), + // Sidebar elements + favoritesCategory: favoritesCategory, + favoritesCategoryCountEl: favoritesCategory === null || favoritesCategory === void 0 ? void 0 : favoritesCategory.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat-count")), + availableTemplatesCategory: document.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_shared__WEBPACK_IMPORTED_MODULE_1__.VIEW_SLUGS.AVAILABLE_TEMPLATES, "\"]")), + getFreeTemplatesBannerButton: document.querySelector('.frm-get-free-templates-banner .button'), + // Modal elements + modal: modal, + modalItems: modal === null || modal === void 0 ? void 0 : modal.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-modal-item")), + // Create New Template Modal + showCreateTemplateModalButton: document.getElementById('frm-show-create-template-modal'), + createTemplateModal: document.getElementById('frm-create-template-modal'), + createTemplateFormsDropdown: document.getElementById('frm-create-template-modal-forms-select'), + createTemplateName: document.getElementById('frm_create_template_name'), + createTemplateDescription: document.getElementById('frm_create_template_description'), + createTemplateButton: document.getElementById('frm-create-template-button'), + // Renew Account Modal + renewAccountModal: document.getElementById('frm-renew-modal'), + // Leave Email Modal + leaveEmailModal: document.getElementById('frm-leave-email-modal'), + leaveEmailModalInput: document.getElementById('frm_leave_email'), + leaveEmailModalButton: document.getElementById('frm-get-code-button'), + // Upgrade Modal + upgradeModal: document.getElementById('frm-form-upgrade-modal'), + upgradeModalTemplateNames: modal === null || modal === void 0 ? void 0 : modal.querySelectorAll('.frm-upgrade-modal-template-name'), + upgradeModalPlansIcons: modal === null || modal === void 0 ? void 0 : modal.querySelectorAll('.frm-upgrade-modal-plan-icon'), + upgradeModalLink: document.getElementById('frm-upgrade-modal-link'), + // New Template Form elements + newTemplateForm: document.getElementById('frm-new-template'), + newTemplateNameInput: document.getElementById('frm_template_name'), + newTemplateDescriptionInput: document.getElementById('frm_template_desc'), + newTemplateLinkInput: document.getElementById('frm_link'), + newTemplateActionInput: document.getElementById('frm_action_type'), + // Add children of the bodyContent to the elements object. + bodyContentChildren: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.children +}); + + +/***/ }), + +/***/ "./js/src/form-templates/elements/index.js": +/*!*************************************************!*\ + !*** ./js/src/form-templates/elements/index.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addApplicationTemplatesElement: () => (/* reexport safe */ _applicationTemplatesElement__WEBPACK_IMPORTED_MODULE_1__.addApplicationTemplatesElement), +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ createApplicationTemplates: () => (/* reexport safe */ _applicationTemplatesElement__WEBPACK_IMPORTED_MODULE_1__.createApplicationTemplates), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/form-templates/elements/elements.js"); +/* harmony import */ var _applicationTemplatesElement__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./applicationTemplatesElement */ "./js/src/form-templates/elements/applicationTemplatesElement.js"); + + + +/***/ }), + +/***/ "./js/src/form-templates/events/applicationTemplateListener.js": +/*!*********************************************************************!*\ + !*** ./js/src/form-templates/events/applicationTemplateListener.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addApplicationTemplateEvents: () => (/* binding */ addApplicationTemplateEvents) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/** + * Internal dependencies + */ + + +/** + * Manages event handling for an application template. + * + * @return {void} + */ +function addApplicationTemplateEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + applicationTemplateItems = _getElements.applicationTemplateItems; + if (undefined === applicationTemplateItems) { + return; + } + + // Attach click event listener + applicationTemplateItems.forEach(function (template) { + template.addEventListener('click', onApplicationTemplateClick); + }); +} + +/** + * Handles the click event on an application template. + * + * @private + * @param {Event} event The click event object. + * @return {void} + */ +var onApplicationTemplateClick = function onApplicationTemplateClick(event) { + // Check if the clicked element is an anchor tag + if (event.target.closest('a')) { + return; + } + var applicationTemplate = event.currentTarget; + window.location.href = applicationTemplate.dataset.href; +}; + +/***/ }), + +/***/ "./js/src/form-templates/events/createFormButtonListener.js": +/*!******************************************************************!*\ + !*** ./js/src/form-templates/events/createFormButtonListener.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +/** + * Manages event handling for the "Create a blank form" button. + * + * @return {void} + */ +function addCreateFormButtonEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + createFormButton = _getElements.createFormButton; + + // Attach click event listener + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(createFormButton, onCreateFormButtonClick); +} + +/** + * Handles the click event on the "Create a blank form" button. + * + * @private + * @return {void} + */ +var onCreateFormButtonClick = function onCreateFormButtonClick() { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + createFormButton = _getElements2.createFormButton, + newTemplateForm = _getElements2.newTemplateForm, + newTemplateNameInput = _getElements2.newTemplateNameInput, + newTemplateActionInput = _getElements2.newTemplateActionInput; + var installNewForm = window.frmAdminBuild.installNewForm; + newTemplateNameInput.value = ''; + newTemplateActionInput.value = 'frm_install_form'; + installNewForm(newTemplateForm, 'frm_install_form', createFormButton); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addCreateFormButtonEvents); + +/***/ }), + +/***/ "./js/src/form-templates/events/createTemplateListeners.js": +/*!*****************************************************************!*\ + !*** ./js/src/form-templates/events/createTemplateListeners.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + + +/** + * Manages event handling for the 'Create New Template' modal. + * + * @return {void} + */ +function addCreateTemplateEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + createTemplateFormsDropdown = _getElements.createTemplateFormsDropdown, + createTemplateButton = _getElements.createTemplateButton, + showCreateTemplateModalButton = _getElements.showCreateTemplateModalButton, + emptyStateButton = _getElements.emptyStateButton; + + // Show the 'Create New Template' modal when either empty state or show modal button is clicked + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(showCreateTemplateModalButton, onShowCreateTemplateModalButtonClick); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(emptyStateButton, onShowCreateTemplateModalButtonClick); + + // Handle changes in the forms selection dropdown for creating a new template + createTemplateFormsDropdown.addEventListener('change', onFormsSelectChange); + + // Create a new template when the create button inside the modal is clicked + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(createTemplateButton, onCreateTemplateButtonClick); +} + +/** + * Handles the click event on the 'Create Template' button, showing the 'Create New Template' modal. + * + * @private + * @return {void} + */ +var onShowCreateTemplateModalButtonClick = function onShowCreateTemplateModalButtonClick() { + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + selectedCategory = _getState.selectedCategory; + if (!(0,_utils__WEBPACK_IMPORTED_MODULE_5__.isCustomCategory)(selectedCategory)) { + return; + } + (0,_ui__WEBPACK_IMPORTED_MODULE_4__.showCreateTemplateModal)(); +}; + +/** + * Handles changes in the forms selection dropdown for creating a new template. + * + * @private + * @return {void} + */ +var onFormsSelectChange = function onFormsSelectChange() { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + formsSelect = _getElements2.createTemplateFormsDropdown; + var formId = formsSelect.value; + if (!formId || formId === 'no-forms') { + toggleDisableModalElements(true); + return; + } + toggleDisableModalElements(false); + var selectedOption = formsSelect.options[formsSelect.selectedIndex]; + var formDescription = selectedOption.dataset.description.trim(); + var formName = selectedOption.dataset.name.trim(); + var templateString = " ".concat((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Template', 'formidable')); + if (!formName.endsWith(templateString)) { + formName += templateString; + } + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + createTemplateName = _getElements3.createTemplateName, + createTemplateDescription = _getElements3.createTemplateDescription; + createTemplateName.value = formName; + createTemplateDescription.value = formDescription; +}; + +/** + * Toggles the disabled state of elements in the 'Create Template' modal. + * + * @private + * @param {boolean} shouldDisable True to disable, false to enable. + * @return {void} + */ +var toggleDisableModalElements = function toggleDisableModalElements(shouldDisable) { + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + createTemplateName = _getElements4.createTemplateName, + createTemplateDescription = _getElements4.createTemplateDescription, + createTemplateButton = _getElements4.createTemplateButton; + + // Toggle the disabled attribute for input and textarea + [createTemplateName, createTemplateDescription].forEach(function (element) { + element.disabled = shouldDisable; + if (shouldDisable) { + element.value = ''; // Clear the content for input and textarea + } + }); + + // Toggle the disabled class for the button + createTemplateButton.classList.toggle('disabled', shouldDisable); +}; + +/** + * Handles the click event on the 'Create Template' button to create a new template. + * + * @private + * @return {void} + */ +var onCreateTemplateButtonClick = function onCreateTemplateButtonClick() { + var installNewForm = window.frmAdminBuild.installNewForm; + var actionName = 'frm_create_template'; + var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + newTemplateForm = _getElements5.newTemplateForm, + newTemplateActionInput = _getElements5.newTemplateActionInput, + newTemplateNameInput = _getElements5.newTemplateNameInput, + newTemplateDescriptionInput = _getElements5.newTemplateDescriptionInput, + newTemplateLinkInput = _getElements5.newTemplateLinkInput, + createTemplateName = _getElements5.createTemplateName, + createTemplateDescription = _getElements5.createTemplateDescription, + createTemplateFormsDropdown = _getElements5.createTemplateFormsDropdown, + createTemplateButton = _getElements5.createTemplateButton; + newTemplateActionInput.value = actionName; + newTemplateNameInput.value = createTemplateName.value.trim(); + newTemplateDescriptionInput.value = createTemplateDescription.value.trim(); + newTemplateLinkInput.value = createTemplateFormsDropdown.value; + + // Install new form template + installNewForm(newTemplateForm, actionName, createTemplateButton); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addCreateTemplateEvents); + +/***/ }), + +/***/ "./js/src/form-templates/events/favoriteButtonListener.js": +/*!****************************************************************!*\ + !*** ./js/src/form-templates/events/favoriteButtonListener.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + +var FAVORITE_BUTTON_CLASS = ".".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-item-favorite-button"); +var HEART_ICON_SELECTOR = "".concat(FAVORITE_BUTTON_CLASS, " use"); +var FILLED_HEART_ICON = '#frm_heart_solid_icon'; +var LINEAR_HEART_ICON = '#frm_heart_icon'; +var OPERATION = { + ADD: 'add', + REMOVE: 'remove' +}; + +/** + * Manages event handling for favorite buttons. + * + * @return {void} + */ +function addFavoriteButtonEvents() { + var favoriteButtons = document.querySelectorAll(FAVORITE_BUTTON_CLASS); + + // Attach click event listeners to each favorite button + favoriteButtons.forEach(function (favoriteButton) { + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(favoriteButton, onFavoriteButtonClick); + }); +} + +/** + * Handles the click event on the add to favorite button. + * + * @private + * @param {Event} event The click event object. + * @return {void} + */ +var onFavoriteButtonClick = function onFavoriteButtonClick(event) { + var _twinFeaturedTemplate; + var favoriteButton = event.currentTarget; + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + templatesList = _getElements.templatesList, + featuredTemplatesList = _getElements.featuredTemplatesList, + favoritesCategoryCountEl = _getElements.favoritesCategoryCountEl, + customTemplatesTitle = _getElements.customTemplatesTitle; + + /** + * Get necessary template information + */ + var template = favoriteButton.closest('.frm-card-item'); + var templateId = template.dataset.id; + var isFavorited = (0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFavoriteTemplate)(template); + var isTemplateCustom = (0,_utils__WEBPACK_IMPORTED_MODULE_4__.isCustomTemplate)(template); + var isTemplateFeatured = (0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFeaturedTemplate)(template); + + /** + * Toggle the favorite status in the UI. + * If template is featured, toggle its twin version in the respective list. + */ + var twinFeaturedTemplate = null; + template.classList.toggle("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-favorite-item"), !isFavorited); + if (isTemplateFeatured) { + var templateList = template.closest("#".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-list")) ? featuredTemplatesList : templatesList; + if (templateList) { + twinFeaturedTemplate = templateList.querySelector(".frm-card-item[data-id=\"".concat(templateId, "\"]")); + // Toggle twin template's favorite status + twinFeaturedTemplate.classList.toggle("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-favorite-item"), !isFavorited); + } + } + + /** + * Update favorite counts and icons based on the new state + */ + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_2__.getState)(), + selectedCategory = _getState.selectedCategory, + favoritesCount = _getState.favoritesCount; + var currentOperation = isFavorited ? OPERATION.REMOVE : OPERATION.ADD; + var heartIcon = template.querySelector(HEART_ICON_SELECTOR); + var twinTemplateHeartIcon = (_twinFeaturedTemplate = twinFeaturedTemplate) === null || _twinFeaturedTemplate === void 0 ? void 0 : _twinFeaturedTemplate.querySelector(HEART_ICON_SELECTOR); + if (OPERATION.ADD === currentOperation) { + // Increment favorite counts + ++favoritesCount.total; + if (isTemplateCustom) { + ++favoritesCount.custom; + } else { + ++favoritesCount.default; + } + // Set heart icon to filled + heartIcon.setAttribute('href', FILLED_HEART_ICON); + twinTemplateHeartIcon === null || twinTemplateHeartIcon === void 0 || twinTemplateHeartIcon.setAttribute('href', FILLED_HEART_ICON); + } else { + // Decrement favorite counts + --favoritesCount.total; + if (isTemplateCustom) { + --favoritesCount.custom; + } else { + --favoritesCount.default; + } + // Set heart icon to outline + heartIcon.setAttribute('href', LINEAR_HEART_ICON); + twinTemplateHeartIcon === null || twinTemplateHeartIcon === void 0 || twinTemplateHeartIcon.setAttribute('href', LINEAR_HEART_ICON); + } + + // Update UI and state to reflect new favorite counts + favoritesCategoryCountEl.textContent = favoritesCount.total; + (0,_shared__WEBPACK_IMPORTED_MODULE_2__.setSingleState)('favoritesCount', favoritesCount); + + /** + * Hide UI elements if 'Favorites' is active and counts are zero. + */ + if ((0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFavoritesCategory)(selectedCategory)) { + if (0 === favoritesCount.total) { + (0,_ui__WEBPACK_IMPORTED_MODULE_3__.showFavoritesEmptyState)(); + } + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(template); + if (0 === favoritesCount.default) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(templatesList); + } + if (0 === favoritesCount.custom || 0 === favoritesCount.default) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(customTemplatesTitle); + } + } + + // Update server-side data for favorite templates + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.addToRequestQueue)(function () { + return updateFavoriteTemplate(templateId, currentOperation, isTemplateCustom); + }); +}; + +/** + * Update server-side data for favorite templates. + * + * @param {string} id The template ID. + * @param {string} operation The operation to perform ('add' or 'remove'). + * @param {boolean} isCustom Flag indicating whether the template is custom. + * @return {Promise} The result of the server-side update. + */ +function updateFavoriteTemplate(id, operation, isCustom) { + var formData = new FormData(); + var doJsonPost = frmDom.ajax.doJsonPost; + formData.append('template_id', id); + formData.append('operation', operation); + formData.append('is_custom_template', isCustom); + return doJsonPost('add_or_remove_favorite_template', formData); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addFavoriteButtonEvents); + +/***/ }), + +/***/ "./js/src/form-templates/events/getFreeTemplatesListener.js": +/*!******************************************************************!*\ + !*** ./js/src/form-templates/events/getFreeTemplatesListener.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * External dependencies + */ + +var tag = window.frmDom.tag; + +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + + + +/** + * Manages event handling for the "Get Templates" button. + * + * @return {void} + */ +function addGetFreeTemplatesEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + leaveEmailModalButton = _getElements.leaveEmailModalButton, + getFreeTemplatesBannerButton = _getElements.getFreeTemplatesBannerButton; + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(leaveEmailModalButton, onGetTemplatesButtonClick); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(getFreeTemplatesBannerButton, _ui__WEBPACK_IMPORTED_MODULE_3__.showLeaveEmailModal); +} + +/** + * Handles the click event on the "Get Templates" button. + * + * @private + * @return {void} + */ +var onGetTemplatesButtonClick = /*#__PURE__*/function () { + var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { + var _getElements2, leaveEmailModalInput, email, _getElements3, leaveEmailModalButton, formData, data, doJsonPost, _t; + return _regenerator().w(function (_context) { + while (1) switch (_context.p = _context.n) { + case 0: + _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), leaveEmailModalInput = _getElements2.leaveEmailModalInput; + email = leaveEmailModalInput.value.trim(); // Check if the email field is empty + if (email) { + _context.n = 1; + break; + } + (0,_ui__WEBPACK_IMPORTED_MODULE_3__.showEmailAddressError)('empty'); + return _context.a(2); + case 1: + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isValidEmail)(email)) { + _context.n = 2; + break; + } + (0,_ui__WEBPACK_IMPORTED_MODULE_3__.showEmailAddressError)('invalid'); + return _context.a(2); + case 2: + // Disable the button + _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), leaveEmailModalButton = _getElements3.leaveEmailModalButton; + leaveEmailModalButton.style.setProperty('cursor', 'not-allowed'); + leaveEmailModalButton.classList.add('frm_loading_button'); + formData = new FormData(); + formData.append('email', email); + doJsonPost = frmDom.ajax.doJsonPost; + _context.p = 3; + _context.n = 4; + return doJsonPost('get_free_templates', formData); + case 4: + data = _context.v; + _context.n = 6; + break; + case 5: + _context.p = 5; + _t = _context.v; + console.error('An error occurred:', _t); + showFailedToGetTemplates(); + return _context.a(2); + case 6: + if (data.success) { + _context.n = 7; + break; + } + showFailedToGetTemplates(); + return _context.a(2); + case 7: + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hasQueryParam)('free-templates')) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.removeQueryParam)('free-templates'); + } + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.setQueryParam)('registered-for-free-templates', '1'); + window.location.reload(); + case 8: + return _context.a(2); + } + }, _callee, null, [[3, 5]]); + })); + return function onGetTemplatesButtonClick() { + return _ref.apply(this, arguments); + }; +}(); + +/** + * Shows a message indicating that templates could not be retrieved. + * + * @private + * @return {void} + */ +function showFailedToGetTemplates() { + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + leaveEmailModal = _getElements4.leaveEmailModal; + leaveEmailModal.querySelector('.inside').replaceChildren(tag('p', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Failed to get templates, please try again later.', 'formidable'))); + leaveEmailModal.querySelector('.frm_modal_footer').classList.add('frm_hidden'); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addGetFreeTemplatesEvents); + +/***/ }), + +/***/ "./js/src/form-templates/events/index.js": +/*!***********************************************!*\ + !*** ./js/src/form-templates/events/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addApplicationTemplateEvents: () => (/* reexport safe */ _applicationTemplateListener__WEBPACK_IMPORTED_MODULE_8__.addApplicationTemplateEvents), +/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _createFormButtonListener__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createFormButtonListener */ "./js/src/form-templates/events/createFormButtonListener.js"); +/* harmony import */ var _favoriteButtonListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./favoriteButtonListener */ "./js/src/form-templates/events/favoriteButtonListener.js"); +/* harmony import */ var _useTemplateButtonListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./useTemplateButtonListener */ "./js/src/form-templates/events/useTemplateButtonListener.js"); +/* harmony import */ var _searchListener__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./searchListener */ "./js/src/form-templates/events/searchListener.js"); +/* harmony import */ var _createTemplateListeners__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createTemplateListeners */ "./js/src/form-templates/events/createTemplateListeners.js"); +/* harmony import */ var _getFreeTemplatesListener__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./getFreeTemplatesListener */ "./js/src/form-templates/events/getFreeTemplatesListener.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); +/* harmony import */ var _applicationTemplateListener__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./applicationTemplateListener */ "./js/src/form-templates/events/applicationTemplateListener.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + + + + + +/** + * Attaches event listeners for handling user interactions. + * + * @return {void} + */ +function addEventListeners() { + (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addCategoryEvents)(); + wp.hooks.addAction('frmPage.onCategoryClick', 'frmFormTemplates', function (selectedCategory) { + // Display templates of the selected category + (0,_ui__WEBPACK_IMPORTED_MODULE_7__.showSelectedCategory)(selectedCategory); + }); + (0,_createFormButtonListener__WEBPACK_IMPORTED_MODULE_1__["default"])(); + (0,_favoriteButtonListener__WEBPACK_IMPORTED_MODULE_2__["default"])(); + (0,_useTemplateButtonListener__WEBPACK_IMPORTED_MODULE_3__["default"])(); + (0,_searchListener__WEBPACK_IMPORTED_MODULE_4__["default"])(); + (0,_createTemplateListeners__WEBPACK_IMPORTED_MODULE_5__["default"])(); + (0,_getFreeTemplatesListener__WEBPACK_IMPORTED_MODULE_6__["default"])(); +} + + +/***/ }), + +/***/ "./js/src/form-templates/events/searchListener.js": +/*!********************************************************!*\ + !*** ./js/src/form-templates/events/searchListener.js ***! + \********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + +var initSearch = window.frmDom.search.init; + +/** + * Adds search-related event listeners by calling the 'initSearch' function. + * + * @see frmDom.search method + * @return {void} + */ +function addSearchEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + searchInput = _getElements.searchInput, + emptyStateButton = _getElements.emptyStateButton; + initSearch(searchInput, 'frm-card-item', { + handleSearchResult: handleSearchResult + }); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(emptyStateButton, onEmptyStateButtonClick); +} + +/** + * Manages UI state based on search results and input value. + * + * @private + * @param {Object} args Contains flags for search status. + * @param {boolean} args.foundSomething True if search yielded results. + * @param {boolean} args.notEmptySearchText True if search input is not empty. + * @param {Event} event The event object (input, search, or change event). + * @return {void} + */ +function handleSearchResult(_ref, event) { + var foundSomething = _ref.foundSomething, + notEmptySearchText = _ref.notEmptySearchText; + // Prevent double calls as window.frmDom.search.init attaches both 'input' and 'search' events, + // triggering this method twice on 'x' button click. + if (event && event.type === 'search' && event.target.value === '') { + return; + } + var state = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(); + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + allItemsCategory = _getElements2.allItemsCategory; + (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('notEmptySearchText', notEmptySearchText); + + // Revert to 'All Templates' if search and selected category are both empty + if (!state.notEmptySearchText && !state.selectedCategory) { + allItemsCategory.dispatchEvent(new Event('click', { + bubbles: true + })); + return; + } + + // Display search state if a category is selected + if (state.selectedCategory) { + (0,_ui__WEBPACK_IMPORTED_MODULE_4__.showSearchState)(notEmptySearchText); + + // Setting "selectedCategory" to an empty string as a flag for search state + if (notEmptySearchText) { + (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('selectedCategory', ''); + } + } + (0,_ui__WEBPACK_IMPORTED_MODULE_4__.displaySearchElements)(foundSomething, notEmptySearchText); +} + +/** + * Handles the click event on the empty state button. + * + * @private + * @return {void} + */ +var onEmptyStateButtonClick = function onEmptyStateButtonClick() { + var _emptyState$dataset; + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + emptyState = _getElements3.emptyState; + if (_shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.SEARCH !== ((_emptyState$dataset = emptyState.dataset) === null || _emptyState$dataset === void 0 ? void 0 : _emptyState$dataset.view)) { + return; + } + + // Set selectedCategory to '' as search state flag that triggers ALL_ITEMS category if search input is empty + // @see handleSearchResult() + (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('selectedCategory', ''); + (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.resetSearchInput)(); + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + searchInput = _getElements4.searchInput; + searchInput.focus(); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addSearchEvents); + +/***/ }), + +/***/ "./js/src/form-templates/events/useTemplateButtonListener.js": +/*!*******************************************************************!*\ + !*** ./js/src/form-templates/events/useTemplateButtonListener.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _ui___WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../ui/ */ "./js/src/form-templates/ui/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); +/** + * Internal dependencies + */ + + + + + +/** + * Manages event handling for use template buttons. + * + * @return {void} + */ +function addUseTemplateButtonEvents() { + var useTemplateButtons = document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-use-template-button")); + + // Attach click event listeners to each use template button + useTemplateButtons.forEach(function (useTemplateButton) { + return useTemplateButton.addEventListener('click', onUseTemplateButtonClick); + }); +} + +/** + * Handles the click event on the use template button. + * + * @private + * @param {Event} event The click event object. + * @return {void} + */ +var onUseTemplateButtonClick = function onUseTemplateButtonClick(event) { + var useTemplateButton = event.currentTarget; + var template = useTemplateButton.closest('.frm-card-item'); + var isLocked = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.isLockedTemplate)(template); + var isTemplateCustom = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.isCustomTemplate)(template); + + // Allow the default link behavior, if the template is custom and not locked + if (!isLocked && isTemplateCustom) { + return; + } + + // Prevent the default link behavior for non-custom or locked templates + event.preventDefault(); + + // Handle locked templates + if (isLocked) { + (0,_ui___WEBPACK_IMPORTED_MODULE_2__.showLockedTemplateModal)(template); + return; + } + + // Prepare for new template installation + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + newTemplateForm = _getElements.newTemplateForm, + newTemplateNameInput = _getElements.newTemplateNameInput, + newTemplateDescriptionInput = _getElements.newTemplateDescriptionInput, + newTemplateLinkInput = _getElements.newTemplateLinkInput, + newTemplateActionInput = _getElements.newTemplateActionInput; + var installNewForm = window.frmAdminBuild.installNewForm; + var templateName = template.querySelector('.frm-form-template-name').textContent.trim(); + var templateDescription = template.querySelector('.frm-form-templates-item-description').textContent.trim(); + var actionName = 'frm_install_template'; + newTemplateNameInput.value = templateName; + newTemplateDescriptionInput.value = templateDescription; + newTemplateActionInput.value = actionName; + newTemplateLinkInput.value = useTemplateButton.href; + + // Install new form template + installNewForm(newTemplateForm, actionName, useTemplateButton); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addUseTemplateButtonEvents); + +/***/ }), + +/***/ "./js/src/form-templates/initializeFormTemplates.js": +/*!**********************************************************!*\ + !*** ./js/src/form-templates/initializeFormTemplates.js ***! + \**********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/form-templates/ui/index.js"); +/* harmony import */ var _templates__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./templates */ "./js/src/form-templates/templates/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./events */ "./js/src/form-templates/events/index.js"); +/** + * Internal dependencies + */ + + + + +/** + * Initializes form templates. + * + * @return {void} + */ +function initializeFormTemplates() { + (0,_templates__WEBPACK_IMPORTED_MODULE_1__.maybeAddApplicationTemplates)(); + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeModal)(); + (0,_templates__WEBPACK_IMPORTED_MODULE_1__.buildCategorizedTemplates)(); + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.setupInitialView)(); + (0,_events__WEBPACK_IMPORTED_MODULE_2__.addEventListeners)(); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeFormTemplates); + +/***/ }), + +/***/ "./js/src/form-templates/shared/constants.js": +/*!***************************************************!*\ + !*** ./js/src/form-templates/shared/constants.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ FEATURED_TEMPLATES_IDS: () => (/* binding */ FEATURED_TEMPLATES_IDS), +/* harmony export */ FREE_TEMPLATES_IDS: () => (/* binding */ FREE_TEMPLATES_IDS), +/* harmony export */ MODAL_SIZES: () => (/* binding */ MODAL_SIZES), +/* harmony export */ PLANS: () => (/* binding */ PLANS), +/* harmony export */ PREFIX: () => (/* binding */ PREFIX), +/* harmony export */ VIEW_SLUGS: () => (/* binding */ VIEW_SLUGS), +/* harmony export */ applicationsUrl: () => (/* binding */ applicationsUrl), +/* harmony export */ canAccessApplicationDashboard: () => (/* binding */ canAccessApplicationDashboard), +/* harmony export */ upgradeLink: () => (/* binding */ upgradeLink) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + canAccessApplicationDashboard = _window$frmGlobal.canAccessApplicationDashboard, + applicationsUrl = _window$frmGlobal.applicationsUrl; + +var _window$frmFormTempla = window.frmFormTemplatesVars, + FEATURED_TEMPLATES_IDS = _window$frmFormTempla.FEATURED_TEMPLATES_IDS, + FREE_TEMPLATES_IDS = _window$frmFormTempla.FREE_TEMPLATES_IDS, + upgradeLink = _window$frmFormTempla.upgradeLink; + +var PREFIX = 'frm-form-templates'; +var VIEW_SLUGS = { + AVAILABLE_TEMPLATES: 'available-templates', + FAVORITES: 'favorites', + CUSTOM: 'custom', + SEARCH: 'search' +}; +var PLANS = { + BASIC: 'basic', + PLUS: 'plus', + BUSINESS: 'business', + ELITE: 'elite', + RENEW: 'renew', + FREE: 'free' +}; +var MODAL_SIZES = { + GENERAL: '440px', + CREATE_TEMPLATE: '550px' +}; + +/***/ }), + +/***/ "./js/src/form-templates/shared/index.js": +/*!***********************************************!*\ + !*** ./js/src/form-templates/shared/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ FEATURED_TEMPLATES_IDS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.FEATURED_TEMPLATES_IDS), +/* harmony export */ FREE_TEMPLATES_IDS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.FREE_TEMPLATES_IDS), +/* harmony export */ MODAL_SIZES: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.MODAL_SIZES), +/* harmony export */ PLANS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PLANS), +/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), +/* harmony export */ VIEW_SLUGS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.VIEW_SLUGS), +/* harmony export */ applicationsUrl: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.applicationsUrl), +/* harmony export */ canAccessApplicationDashboard: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.canAccessApplicationDashboard), +/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setState), +/* harmony export */ upgradeLink: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.upgradeLink) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/form-templates/shared/constants.js"); +/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageState */ "./js/src/form-templates/shared/pageState.js"); + + + +/***/ }), + +/***/ "./js/src/form-templates/shared/pageState.js": +/*!***************************************************!*\ + !*** ./js/src/form-templates/shared/pageState.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setState) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + +var _window$frmFormTempla = window.frmFormTemplatesVars, + templatesCount = _window$frmFormTempla.templatesCount, + favoritesCount = _window$frmFormTempla.favoritesCount, + customCount = _window$frmFormTempla.customCount; +var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + availableTemplateItems = _getElements.availableTemplateItems; +var availableTemplatesCount = availableTemplateItems.length; +(0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setState)({ + availableTemplatesCount: availableTemplatesCount, + customCount: Number(customCount), + extraTemplatesCount: templatesCount - availableTemplatesCount, + favoritesCount: favoritesCount +}); + + +/***/ }), + +/***/ "./js/src/form-templates/templates/applicationTemplates.js": +/*!*****************************************************************!*\ + !*** ./js/src/form-templates/templates/applicationTemplates.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ maybeAddApplicationTemplates: () => (/* binding */ maybeAddApplicationTemplates) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ "./js/src/form-templates/events/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/** + * Internal dependencies + */ + + + + +/** + * Adds application templates if the user has dashboard access. + * + * @return {void} + */ +function maybeAddApplicationTemplates() { + // Exit if the user doesn't have permission to see application dashboard + if (!_shared__WEBPACK_IMPORTED_MODULE_2__.canAccessApplicationDashboard) { + return; + } + var doJsonFetch = frmDom.ajax.doJsonFetch; + doJsonFetch('get_applications_data&view=templates').then(setupApplicationTemplates); +} + +/** + * Sets up application templates by creating HTML elements, injecting them into the DOM, + * and adding event handlers. + * + * @private + * @param {Object} data The data object containing information for application templates. + * @return {void} + */ +function setupApplicationTemplates(data) { + // Create application templates + (0,_elements__WEBPACK_IMPORTED_MODULE_0__.createApplicationTemplates)(data.templates); + + // Inject templates into the DOM + (0,_elements__WEBPACK_IMPORTED_MODULE_0__.addApplicationTemplatesElement)(); + + // Set up event handling + (0,_events__WEBPACK_IMPORTED_MODULE_1__.addApplicationTemplateEvents)(); +} + +/***/ }), + +/***/ "./js/src/form-templates/templates/categorizeTemplates.js": +/*!****************************************************************!*\ + !*** ./js/src/form-templates/templates/categorizeTemplates.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ buildCategorizedTemplates: () => (/* binding */ buildCategorizedTemplates), +/* harmony export */ categorizedTemplates: () => (/* binding */ categorizedTemplates) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/** + * Internal dependencies + */ + +var categorizedTemplates = {}; + +/** + * Builds a categorized list of templates. + * + * @return {void} + */ +function buildCategorizedTemplates() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + templateItems = _getElements.templateItems; + templateItems.forEach(function (template) { + // Extract and split the categories from data attribute + var categories = template.getAttribute('data-categories').split(','); + categories.forEach(function (category) { + // Initialize the category array if not already done + if (!categorizedTemplates[category]) { + categorizedTemplates[category] = []; + } + + // Add the template to the appropriate category + categorizedTemplates[category].push(template); + }); + }); +} + +/***/ }), + +/***/ "./js/src/form-templates/templates/index.js": +/*!**************************************************!*\ + !*** ./js/src/form-templates/templates/index.js ***! + \**************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ buildCategorizedTemplates: () => (/* reexport safe */ _categorizeTemplates__WEBPACK_IMPORTED_MODULE_0__.buildCategorizedTemplates), +/* harmony export */ categorizedTemplates: () => (/* reexport safe */ _categorizeTemplates__WEBPACK_IMPORTED_MODULE_0__.categorizedTemplates), +/* harmony export */ maybeAddApplicationTemplates: () => (/* reexport safe */ _applicationTemplates__WEBPACK_IMPORTED_MODULE_1__.maybeAddApplicationTemplates) +/* harmony export */ }); +/* harmony import */ var _categorizeTemplates__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./categorizeTemplates */ "./js/src/form-templates/templates/categorizeTemplates.js"); +/* harmony import */ var _applicationTemplates__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./applicationTemplates */ "./js/src/form-templates/templates/applicationTemplates.js"); + + + +/***/ }), + +/***/ "./js/src/form-templates/ui/index.js": +/*!*******************************************!*\ + !*** ./js/src/form-templates/ui/index.js ***! + \*******************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ displaySearchElements: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_5__.displaySearchElements), +/* harmony export */ getModalWidget: () => (/* reexport safe */ _initializeModal__WEBPACK_IMPORTED_MODULE_1__.getModalWidget), +/* harmony export */ initializeModal: () => (/* reexport safe */ _initializeModal__WEBPACK_IMPORTED_MODULE_1__.initializeModal), +/* harmony export */ setupInitialView: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ showAllTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showAllTemplates), +/* harmony export */ showAvailableTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showAvailableTemplates), +/* harmony export */ showAvailableTemplatesEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showAvailableTemplatesEmptyState), +/* harmony export */ showCreateTemplateModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showCreateTemplateModal), +/* harmony export */ showCustomTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showCustomTemplates), +/* harmony export */ showCustomTemplatesEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showCustomTemplatesEmptyState), +/* harmony export */ showEmailAddressError: () => (/* reexport safe */ _showError__WEBPACK_IMPORTED_MODULE_8__.showEmailAddressError), +/* harmony export */ showFavoriteTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showFavoriteTemplates), +/* harmony export */ showFavoritesEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showFavoritesEmptyState), +/* harmony export */ showHeaderCancelButton: () => (/* reexport safe */ _showHeaderCancelButton__WEBPACK_IMPORTED_MODULE_3__.showHeaderCancelButton), +/* harmony export */ showLeaveEmailModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showLeaveEmailModal), +/* harmony export */ showLockedTemplateModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showLockedTemplateModal), +/* harmony export */ showRenewAccountModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showRenewAccountModal), +/* harmony export */ showSearchEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showSearchEmptyState), +/* harmony export */ showSearchState: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_5__.showSearchState), +/* harmony export */ showSelectedCategory: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showSelectedCategory), +/* harmony export */ showUpgradeModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showUpgradeModal), +/* harmony export */ updatePageTitle: () => (/* reexport safe */ _pageTitle__WEBPACK_IMPORTED_MODULE_2__.updatePageTitle) +/* harmony export */ }); +/* harmony import */ var _setupInitialView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupInitialView */ "./js/src/form-templates/ui/setupInitialView.js"); +/* harmony import */ var _initializeModal__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./initializeModal */ "./js/src/form-templates/ui/initializeModal.js"); +/* harmony import */ var _pageTitle__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./pageTitle */ "./js/src/form-templates/ui/pageTitle.js"); +/* harmony import */ var _showHeaderCancelButton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./showHeaderCancelButton */ "./js/src/form-templates/ui/showHeaderCancelButton.js"); +/* harmony import */ var _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./showSelectedCategory */ "./js/src/form-templates/ui/showSelectedCategory.js"); +/* harmony import */ var _searchState__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./searchState */ "./js/src/form-templates/ui/searchState.js"); +/* harmony import */ var _showEmptyState__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./showEmptyState */ "./js/src/form-templates/ui/showEmptyState.js"); +/* harmony import */ var _showModal__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./showModal */ "./js/src/form-templates/ui/showModal.js"); +/* harmony import */ var _showError__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./showError */ "./js/src/form-templates/ui/showError.js"); + + + + + + + + + + +/***/ }), + +/***/ "./js/src/form-templates/ui/initializeModal.js": +/*!*****************************************************!*\ + !*** ./js/src/form-templates/ui/initializeModal.js ***! + \*****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getModalWidget: () => (/* binding */ getModalWidget), +/* harmony export */ initializeModal: () => (/* binding */ initializeModal) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + +var modalWidget = null; + +/** + * Initialize the modal widget. + * + * @return {void} + */ +function initializeModal() { + return _initializeModal.apply(this, arguments); +} + +/** + * Retrieve the modal widget. + * + * @return {Object|false} The modal widget or false. + */ +function _initializeModal() { + _initializeModal = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { + var _window$frmAdminBuild, initModal, offsetModalY, _getElements, leaveEmailModal; + return _regenerator().w(function (_context) { + while (1) switch (_context.n) { + case 0: + _window$frmAdminBuild = window.frmAdminBuild, initModal = _window$frmAdminBuild.initModal, offsetModalY = _window$frmAdminBuild.offsetModalY; + modalWidget = initModal('#frm-form-templates-modal', _shared__WEBPACK_IMPORTED_MODULE_2__.MODAL_SIZES.GENERAL); + + // Set the vertical offset for the modal + if (modalWidget) { + offsetModalY(modalWidget, '103px'); + } + + // Show the email modal if the 'free-templates' query param is present + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hasQueryParam)('free-templates')) { + _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), leaveEmailModal = _getElements.leaveEmailModal; + if (leaveEmailModal) { + (0,___WEBPACK_IMPORTED_MODULE_3__.showLeaveEmailModal)(); + } + } + + // Customize the confirm modal appearance: adjusting its width and vertical position + wp.hooks.addAction('frmAdmin.beforeOpenConfirmModal', 'frmFormTemplates', function (options) { + var confirmModal = options.$info; + confirmModal.dialog('option', 'width', _shared__WEBPACK_IMPORTED_MODULE_2__.MODAL_SIZES.CREATE_TEMPLATE); + offsetModalY(confirmModal, '103px'); + }); + case 1: + return _context.a(2); + } + }, _callee); + })); + return _initializeModal.apply(this, arguments); +} +function getModalWidget() { + return modalWidget; +} + +/***/ }), + +/***/ "./js/src/form-templates/ui/pageTitle.js": +/*!***********************************************!*\ + !*** ./js/src/form-templates/ui/pageTitle.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ updatePageTitle: () => (/* binding */ updatePageTitle) +/* harmony export */ }); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + +/** + * Sets the page title based on a given string or the currently selected category. + * + * @param {string} [title] Optional title to display. + * @return {void} + */ +function updatePageTitle(title) { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + pageTitleText = _getElements.pageTitleText; + var newTitle = title || (0,_shared__WEBPACK_IMPORTED_MODULE_2__.getSingleState)('selectedCategoryEl').querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat-text")).textContent; + pageTitleText.textContent = newTitle; +} + +/***/ }), + +/***/ "./js/src/form-templates/ui/searchState.js": +/*!*************************************************!*\ + !*** ./js/src/form-templates/ui/searchState.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ displaySearchElements: () => (/* binding */ displaySearchElements), +/* harmony export */ showSearchState: () => (/* binding */ showSearchState) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! . */ "./js/src/form-templates/ui/index.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + +/** + * Updates the UI to display the search state. + * + * @param {boolean} notEmptySearchText True if search input is not empty. + * @return {void} + */ +function showSearchState(notEmptySearchText) { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + bodyContent = _getElements.bodyContent, + bodyContentChildren = _getElements.bodyContentChildren, + pageTitle = _getElements.pageTitle, + templatesList = _getElements.templatesList, + applicationTemplates = _getElements.applicationTemplates; + var bodyContentAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_2__.frmAnimate(bodyContent); + + // Remove highlighting from the currently selected category if the search text is not empty + if (notEmptySearchText) { + (0,_shared__WEBPACK_IMPORTED_MODULE_4__.getSingleState)('selectedCategoryEl').classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_1__.CURRENT_CLASS); + } + + // Hide non-relevant elements in the body content + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hideElements)(bodyContentChildren); + + // Update the page title and display relevant elements + (0,___WEBPACK_IMPORTED_MODULE_5__.updatePageTitle)((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Search Result', 'formidable')); + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.showElements)([pageTitle, templatesList, applicationTemplates]); + + // Smoothly display the updated UI elements + bodyContentAnimate.fadeIn(); +} + +/** + * Displays search results based on search outcome. + * + * @param {boolean} foundSomething True if search yielded results. + * @return {void} + */ +function displaySearchElements(foundSomething) { + // Show empty state if no templates found + if (!foundSomething) { + (0,___WEBPACK_IMPORTED_MODULE_5__.showSearchEmptyState)(); + return; + } + + // Hide empty state if currently displayed + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + emptyState = _getElements2.emptyState; + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_2__.isVisible)(emptyState)) { + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + pageTitle = _getElements3.pageTitle; + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hide)(emptyState); + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.show)(pageTitle); + } + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + templatesList = _getElements4.templatesList, + applicationTemplates = _getElements4.applicationTemplates, + applicationTemplatesTitle = _getElements4.applicationTemplatesTitle, + applicationTemplatesList = _getElements4.applicationTemplatesList; + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.showElements)([templatesList, applicationTemplates, applicationTemplatesTitle]); + if (templatesList.offsetHeight === 0) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hideElements)([templatesList, applicationTemplatesTitle]); + } + if ((applicationTemplatesList === null || applicationTemplatesList === void 0 ? void 0 : applicationTemplatesList.offsetHeight) === 0) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hide)(applicationTemplates); + } +} + +/***/ }), + +/***/ "./js/src/form-templates/ui/setupInitialView.js": +/*!******************************************************!*\ + !*** ./js/src/form-templates/ui/setupInitialView.js ***! + \******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_ui__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/ui */ "./js/src/core/ui/index.js"); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); +/** + * External dependencies + */ + + + + + +/** + * Internal dependencies + */ + + + + +/** + * Sets up the initial view, performing any required + * DOM manipulations for proper element presentation. + * + * @return {void} + */ +function setupInitialView() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_4__.getElements)(), + sidebar = _getElements.sidebar, + searchInput = _getElements.searchInput, + bodyContent = _getElements.bodyContent, + twinFeaturedTemplateItems = _getElements.twinFeaturedTemplateItems, + availableTemplatesCategory = _getElements.availableTemplatesCategory, + extraTemplateCountElements = _getElements.extraTemplateCountElements; + var bodyContentAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent); + searchInput.value = ''; + + // Hide the twin featured template items + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)(twinFeaturedTemplateItems); + setupAvailableTemplatesCategory(availableTemplatesCategory); + + // Update extra templates count + extraTemplateCountElements.forEach(function (element) { + return element.textContent = (0,_shared__WEBPACK_IMPORTED_MODULE_5__.getSingleState)('extraTemplatesCount'); + }); + + // Smoothly display the updated UI elements + bodyContent.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); + sidebar.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); + bodyContentAnimate.fadeIn(); + + // Show the "Cancel" button in the header if the 'return_page' query param is present + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hasQueryParam)('return_page')) { + (0,___WEBPACK_IMPORTED_MODULE_6__.showHeaderCancelButton)(); + } +} + +/** + * Sets up the 'Available Templates' category with proper count display + * + * @param {Element} availableTemplatesCategory The Available Templates category element + * @return {void} + */ +function setupAvailableTemplatesCategory(availableTemplatesCategory) { + if (!availableTemplatesCategory) { + return; + } + var availableTemplatesCount = (0,_shared__WEBPACK_IMPORTED_MODULE_5__.getSingleState)('availableTemplatesCount'); + if (!(0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hasQueryParam)('registered-for-free-templates')) { + availableTemplatesCategory.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_3__.PREFIX, "-cat-count")).textContent = availableTemplatesCount; + return; + } + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.removeParamFromHistory)('registered-for-free-templates'); + runAvailableTemplatesEffects(availableTemplatesCategory, availableTemplatesCount); +} + +/** + * Runs effects for the Available Templates category when the + * 'registered-for-free-templates' query parameter is present. + * + * @param {Element} element The Available Templates category element + * @param {number} count The count of available templates + * @return {void} + */ +function runAvailableTemplatesEffects(element, count) { + setTimeout(function () { + element.dispatchEvent(new Event('click', { + bubbles: true + })); + }, 0); + setTimeout(function () { + (0,core_ui__WEBPACK_IMPORTED_MODULE_2__.counter)(element.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_3__.PREFIX, "-cat-count")), count); + }, 150); + setTimeout(function () { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_4__.getElements)(), + availableTemplateItems = _getElements2.availableTemplateItems; + availableTemplateItems.forEach(function (item) { + if (_shared__WEBPACK_IMPORTED_MODULE_5__.FREE_TEMPLATES_IDS.includes(Number(item.dataset.id))) { + return; + } + item.classList.add('frm-background-highlight'); + + // Remove class after animation completes to prevent restart + item.addEventListener('animationend', function handleAnimationEnd(event) { + if (event.animationName === 'backgroundHighlight') { + this.classList.remove('frm-background-highlight'); + this.removeEventListener('animationend', handleAnimationEnd); + } + }); + }); + }, 750); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (setupInitialView); + +/***/ }), + +/***/ "./js/src/form-templates/ui/showEmptyState.js": +/*!****************************************************!*\ + !*** ./js/src/form-templates/ui/showEmptyState.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showAvailableTemplatesEmptyState: () => (/* binding */ showAvailableTemplatesEmptyState), +/* harmony export */ showCustomTemplatesEmptyState: () => (/* binding */ showCustomTemplatesEmptyState), +/* harmony export */ showFavoritesEmptyState: () => (/* binding */ showFavoritesEmptyState), +/* harmony export */ showSearchEmptyState: () => (/* binding */ showSearchEmptyState) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + +/** + * Display the search-empty state. + * + * @return {void} + */ +function showSearchEmptyState() { + var _emptyState$dataset; + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + notEmptySearchText = _getState.notEmptySearchText; + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + pageTitle = _getElements.pageTitle, + emptyState = _getElements.emptyState, + emptyStateButton = _getElements.emptyStateButton, + applicationTemplates = _getElements.applicationTemplates; + + // Toggle visibility and remove attributes based on search status + if (_shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.SEARCH === ((_emptyState$dataset = emptyState.dataset) === null || _emptyState$dataset === void 0 ? void 0 : _emptyState$dataset.view)) { + if (notEmptySearchText) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(emptyState); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, applicationTemplates]); + } else { + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(emptyState); + emptyState.removeAttribute('data-view'); + } + return; + } + + // Assign state attributes + emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.SEARCH); + + // Update text content + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + emptyStateTitle = _getElements2.emptyStateTitle, + emptyStateText = _getElements2.emptyStateText; + emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No templates found', 'formidable'); + emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Sorry, we didn\'t find any templates that match your criteria.', 'formidable'); + emptyStateButton.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Start from Scratch', 'formidable'); + + // Display the empty state + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, applicationTemplates]); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.showElements)([emptyState, emptyStateButton]); +} + +/** + * Display the favorites-empty state. + * + * @return {void} + */ +function showFavoritesEmptyState() { + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + pageTitle = _getElements3.pageTitle, + emptyState = _getElements3.emptyState, + emptyStateButton = _getElements3.emptyStateButton; + + // Assign state attributes + emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.FAVORITES); + + // Update text content + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + emptyStateTitle = _getElements4.emptyStateTitle, + emptyStateText = _getElements4.emptyStateText; + emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No favorites', 'formidable'); + emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You haven\'t added any templates to your favorites yet.', 'formidable'); + + // Display the empty state + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, emptyStateButton]); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(emptyState); +} + +/** + * Display the custom-empty state. + * + * @return {void} + */ +function showCustomTemplatesEmptyState() { + var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + pageTitle = _getElements5.pageTitle, + emptyState = _getElements5.emptyState, + emptyStateButton = _getElements5.emptyStateButton; + + // Assign state attributes + emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.CUSTOM); + + // Update text content + var _getElements6 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + emptyStateTitle = _getElements6.emptyStateTitle, + emptyStateText = _getElements6.emptyStateText; + emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You currently have no templates.', 'formidable'); + emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You haven\'t created any form templates. Begin now to simplify your workflow and save time.', 'formidable'); + emptyStateButton.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Create Template', 'formidable'); + + // Display the empty state + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(pageTitle); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.showElements)([emptyState, emptyStateButton]); +} + +/** + * Display the available-templates-empty state. + * + * @return {void} + */ +function showAvailableTemplatesEmptyState() { + var _getElements7 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + pageTitle = _getElements7.pageTitle, + emptyState = _getElements7.emptyState, + emptyStateButton = _getElements7.emptyStateButton; + + // Assign state attributes + emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.AVAILABLE_TEMPLATES); + + // Update text content + var _getElements8 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + emptyStateTitle = _getElements8.emptyStateTitle, + emptyStateText = _getElements8.emptyStateText; + var _getState2 = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + extraTemplatesCount = _getState2.extraTemplatesCount; + emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No Templates Available', 'formidable'); + emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.sprintf)( + // translators: %s is the number of extra templates available + (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Upgrade to PRO for %s+ options or explore Free Templates.', 'formidable'), extraTemplatesCount); + + // Display the empty state + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, emptyStateButton]); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(emptyState); +} + +/***/ }), + +/***/ "./js/src/form-templates/ui/showError.js": +/*!***********************************************!*\ + !*** ./js/src/form-templates/ui/showError.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showEmailAddressError: () => (/* binding */ showEmailAddressError) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/** + * External dependencies + */ + + +/** + * Displays errors related to the email address field. + * + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @return {void} + */ +var showEmailAddressError = function showEmailAddressError(type) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showFormError)('#frm_leave_email', '#frm_leave_email_error', type); +}; + +/***/ }), + +/***/ "./js/src/form-templates/ui/showHeaderCancelButton.js": +/*!************************************************************!*\ + !*** ./js/src/form-templates/ui/showHeaderCancelButton.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showHeaderCancelButton: () => (/* binding */ showHeaderCancelButton) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +/** + * Display the "Cancel" button in the header. + * + * @return {void} + */ +function showHeaderCancelButton() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + headerCancelButton = _getElements.headerCancelButton; + new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(headerCancelButton).fadeIn(); +} + +/***/ }), + +/***/ "./js/src/form-templates/ui/showModal.js": +/*!***********************************************!*\ + !*** ./js/src/form-templates/ui/showModal.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showCreateTemplateModal: () => (/* binding */ showCreateTemplateModal), +/* harmony export */ showLeaveEmailModal: () => (/* binding */ showLeaveEmailModal), +/* harmony export */ showLockedTemplateModal: () => (/* binding */ showLockedTemplateModal), +/* harmony export */ showRenewAccountModal: () => (/* binding */ showRenewAccountModal), +/* harmony export */ showUpgradeModal: () => (/* binding */ showUpgradeModal) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * WordPress dependencies + */ + + +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + +/** + * Display the locked template modal. + * + * @param {HTMLElement} template The template element. + * @return {void} + */ +function showLockedTemplateModal(template) { + var plan = template.dataset.requiredPlan; + switch (plan) { + case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.BASIC: + case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.PLUS: + case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.BUSINESS: + case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.ELITE: + showUpgradeModal(plan, template); + break; + case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.RENEW: + showRenewAccountModal(); + break; + case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.FREE: + showLeaveEmailModal(); + break; + } +} + +/** + * Base function to show a modal dialog with a customizable pre-open execution step. + * + * @param {Function} executePreOpen The function to be executed before opening the modal dialog. + * @return {Function} A higher-order function that can be invoked to display the modal dialog. + */ +var showModal = function showModal(executePreOpen) { + return /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { + var dialogWidget, + _getElements, + modalItems, + _len, + params, + _key, + _args = arguments; + return _regenerator().w(function (_context) { + while (1) switch (_context.n) { + case 0: + dialogWidget = (0,___WEBPACK_IMPORTED_MODULE_4__.getModalWidget)(); + if (dialogWidget) { + _context.n = 1; + break; + } + return _context.a(2); + case 1: + _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), modalItems = _getElements.modalItems; + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)(modalItems); + dialogWidget.dialog('option', 'width', _shared__WEBPACK_IMPORTED_MODULE_3__.MODAL_SIZES.GENERAL); + for (_len = _args.length, params = new Array(_len), _key = 0; _key < _len; _key++) { + params[_key] = _args[_key]; + } + _context.n = 2; + return executePreOpen === null || executePreOpen === void 0 ? void 0 : executePreOpen.apply(void 0, params); + case 2: + dialogWidget.dialog('open'); + case 3: + return _context.a(2); + } + }, _callee); + })); +}; + +// Mapping each plan to the subsequent plans it can upgrade to +var upgradablePlans = { + basic: ['basic', 'plus', 'business', 'elite'], + plus: ['plus', 'business', 'elite'], + business: ['business', 'elite'], + elite: ['elite'] +}; + +/** + * Display the modal dialog to prompt the user to upgrade their account. + * + * @param {string} plan Current plan name + * @param {HTMLElement} template The template element + * @return {void} + */ +var showUpgradeModal = showModal(function (plan, template) { + var templateName = template.querySelector('.frm-form-template-name').textContent.trim(); + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + upgradeModal = _getElements2.upgradeModal, + upgradeModalTemplateNames = _getElements2.upgradeModalTemplateNames, + upgradeModalPlansIcons = _getElements2.upgradeModalPlansIcons, + upgradeModalLink = _getElements2.upgradeModalLink; + + // Update template names + upgradeModalTemplateNames.forEach(function (element) { + return element.textContent = templateName; + }); + + // Update plan icons and their availability + upgradeModalPlansIcons.forEach(function (icon) { + var planType = icon.dataset.plan; + var shouldDisplayCheck = upgradablePlans[plan].includes(planType); + + // Toggle icon class based on plan availability + icon.classList.toggle('frm_green', shouldDisplayCheck); + + // Update SVG icon + var svg = icon.querySelector('svg > use'); + svg.setAttribute('href', shouldDisplayCheck ? '#frm_checkmark_icon' : '#frm_close_icon'); + }); + + // Append template slug to the upgrade modal link URL + var templateSlug = template.dataset.slug ? "-".concat(template.dataset.slug) : ''; + upgradeModalLink.href = _shared__WEBPACK_IMPORTED_MODULE_3__.upgradeLink + templateSlug; + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(upgradeModal); +}); + +/** + * Display the modal dialog to prompt the user to renew their account. + * + * @return {void} + */ +var showRenewAccountModal = showModal(function () { + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + renewAccountModal = _getElements3.renewAccountModal; + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(renewAccountModal); +}); + +/** + * Display the modal dialog to prompt the user to leave an email. + * + * @return {void} + */ +var showLeaveEmailModal = showModal(function () { + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + leaveEmailModal = _getElements4.leaveEmailModal; + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(leaveEmailModal); +}); + +/** + * Displays a modal dialog prompting the user to create a new template. + * + * @return {void} + */ +var showCreateTemplateModal = showModal(function () { + var dialogWidget = (0,___WEBPACK_IMPORTED_MODULE_4__.getModalWidget)(); + dialogWidget.dialog('option', 'width', _shared__WEBPACK_IMPORTED_MODULE_3__.MODAL_SIZES.CREATE_TEMPLATE); + var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + createTemplateModal = _getElements5.createTemplateModal; + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(createTemplateModal); +}); + +/***/ }), + +/***/ "./js/src/form-templates/ui/showSelectedCategory.js": +/*!**********************************************************!*\ + !*** ./js/src/form-templates/ui/showSelectedCategory.js ***! + \**********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ showAllTemplates: () => (/* binding */ showAllTemplates), +/* harmony export */ showAvailableTemplates: () => (/* binding */ showAvailableTemplates), +/* harmony export */ showCustomTemplates: () => (/* binding */ showCustomTemplates), +/* harmony export */ showFavoriteTemplates: () => (/* binding */ showFavoriteTemplates), +/* harmony export */ showSelectedCategory: () => (/* binding */ showSelectedCategory) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); +/* harmony import */ var _templates__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../templates */ "./js/src/form-templates/templates/index.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); +function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } +function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + + + +/** + * Show templates based on selected category. + * + * @param {string} selectedCategory The selected category to display templates for. + * @return {void} + */ +function showSelectedCategory(selectedCategory) { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + bodyContentChildren = _getElements.bodyContentChildren, + pageTitle = _getElements.pageTitle, + showCreateTemplateModalButton = _getElements.showCreateTemplateModalButton, + templatesList = _getElements.templatesList, + templateItems = _getElements.templateItems, + upsellBanner = _getElements.upsellBanner; + if (core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS !== selectedCategory) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(bodyContentChildren); + } + (0,___WEBPACK_IMPORTED_MODULE_6__.updatePageTitle)(); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(showCreateTemplateModalButton); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.show)(pageTitle); + switch (selectedCategory) { + case core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS: + showAllTemplates(); + break; + case _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.AVAILABLE_TEMPLATES: + showAvailableTemplates(); + break; + case _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.FAVORITES: + showFavoriteTemplates(); + break; + case _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.CUSTOM: + showCustomTemplates(); + break; + default: + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(templateItems); // Clear the view for new content + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([upsellBanner, templatesList].concat(_toConsumableArray(_templates__WEBPACK_IMPORTED_MODULE_5__.categorizedTemplates[selectedCategory]))); + break; + } +} + +/** + * Shows all templates when 'All Templates' is the selected category. + * + * @return {void} + */ +function showAllTemplates() { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + bodyContentChildren = _getElements2.bodyContentChildren, + pageTitleDivider = _getElements2.pageTitleDivider, + templateItems = _getElements2.templateItems, + twinFeaturedTemplateItems = _getElements2.twinFeaturedTemplateItems, + customTemplatesSection = _getElements2.customTemplatesSection, + emptyState = _getElements2.emptyState, + applicationTemplates = _getElements2.applicationTemplates; + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([].concat(_toConsumableArray(bodyContentChildren), _toConsumableArray(templateItems))); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)([pageTitleDivider].concat(_toConsumableArray(twinFeaturedTemplateItems), [customTemplatesSection, emptyState, applicationTemplates])); +} + +/** + * Shows favorite templates. + * + * @return {void} + */ +function showFavoriteTemplates() { + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + favoritesCount = _getState.favoritesCount; + if (0 === favoritesCount.total) { + (0,___WEBPACK_IMPORTED_MODULE_6__.showFavoritesEmptyState)(); + return; + } + var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + bodyContent = _getElements3.bodyContent, + templatesList = _getElements3.templatesList, + templateItems = _getElements3.templateItems, + customTemplatesSection = _getElements3.customTemplatesSection, + customTemplatesTitle = _getElements3.customTemplatesTitle, + customTemplatesList = _getElements3.customTemplatesList, + customTemplateItems = _getElements3.customTemplateItems; + + // Clear the view for new content + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(templateItems); + var elementsToShow = []; + + // Get all favorite items from the DOM and add the elements to show + var favoriteItems = bodyContent.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_3__.PREFIX, "-favorite-item")); + elementsToShow.push.apply(elementsToShow, _toConsumableArray(favoriteItems)); + + // Add default favorites if available + if (favoritesCount.default > 0) { + elementsToShow.push(templatesList); + } + + // Add custom favorites if available + if (favoritesCount.custom > 0) { + var nonFavCustomTemplates = Array.from(customTemplateItems).filter(function (template) { + return !(0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFavoriteTemplate)(template); + }); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(nonFavCustomTemplates); + elementsToShow.push(customTemplatesSection); + elementsToShow.push(customTemplatesList); + if (0 === favoritesCount.default) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(customTemplatesTitle); + } else { + elementsToShow.push(customTemplatesTitle); + } + } + + // Show elements that were selected to be shown + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)(elementsToShow); +} + +/** + * Shows custom templates. + * + * @return {void} + */ +function showCustomTemplates() { + var _getState2 = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + customCount = _getState2.customCount; + if (0 === customCount) { + (0,___WEBPACK_IMPORTED_MODULE_6__.showCustomTemplatesEmptyState)(); + return; + } + var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + showCreateTemplateModalButton = _getElements4.showCreateTemplateModalButton, + pageTitleDivider = _getElements4.pageTitleDivider, + customTemplatesSection = _getElements4.customTemplatesSection, + customTemplatesList = _getElements4.customTemplatesList, + customTemplatesTitle = _getElements4.customTemplatesTitle, + customTemplateItems = _getElements4.customTemplateItems; + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(customTemplatesTitle); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([showCreateTemplateModalButton, pageTitleDivider, customTemplatesSection, customTemplatesList].concat(_toConsumableArray(customTemplateItems))); +} + +/** + * Shows available templates. + * + * @return {void} + */ +function showAvailableTemplates() { + var _getState3 = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), + availableTemplatesCount = _getState3.availableTemplatesCount; + if (0 === availableTemplatesCount) { + (0,___WEBPACK_IMPORTED_MODULE_6__.showAvailableTemplatesEmptyState)(); + return; + } + var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + templatesList = _getElements5.templatesList, + templateItems = _getElements5.templateItems, + availableTemplateItems = _getElements5.availableTemplateItems, + upsellBanner = _getElements5.upsellBanner; + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(templateItems); // Clear the view for new content + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([upsellBanner, templatesList].concat(_toConsumableArray(availableTemplateItems))); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (showSelectedCategory); + +/***/ }), + +/***/ "./js/src/form-templates/utils/index.js": +/*!**********************************************!*\ + !*** ./js/src/form-templates/utils/index.js ***! + \**********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isAllTemplatesCategory: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isAllTemplatesCategory), +/* harmony export */ isCustomCategory: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isCustomCategory), +/* harmony export */ isCustomTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isCustomTemplate), +/* harmony export */ isFavoriteTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isFavoriteTemplate), +/* harmony export */ isFavoritesCategory: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isFavoritesCategory), +/* harmony export */ isFeaturedTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isFeaturedTemplate), +/* harmony export */ isLockedTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isLockedTemplate) +/* harmony export */ }); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validation */ "./js/src/form-templates/utils/validation.js"); + + +/***/ }), + +/***/ "./js/src/form-templates/utils/validation.js": +/*!***************************************************!*\ + !*** ./js/src/form-templates/utils/validation.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isAllTemplatesCategory: () => (/* binding */ isAllTemplatesCategory), +/* harmony export */ isCustomCategory: () => (/* binding */ isCustomCategory), +/* harmony export */ isCustomTemplate: () => (/* binding */ isCustomTemplate), +/* harmony export */ isFavoriteTemplate: () => (/* binding */ isFavoriteTemplate), +/* harmony export */ isFavoritesCategory: () => (/* binding */ isFavoritesCategory), +/* harmony export */ isFeaturedTemplate: () => (/* binding */ isFeaturedTemplate), +/* harmony export */ isLockedTemplate: () => (/* binding */ isLockedTemplate) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + +/** + * Checks if the category is "All Templates". + * + * @param {string} category The category slug. + * @return {boolean} True if the category is "All Templates", otherwise false. + */ +var isAllTemplatesCategory = function isAllTemplatesCategory(category) { + return core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS === category; +}; + +/** + * Checks if the category is "Favorites". + * + * @param {string} category The category slug. + * @return {boolean} True if the category is "Favorites", otherwise false. + */ +var isFavoritesCategory = function isFavoritesCategory(category) { + return _shared__WEBPACK_IMPORTED_MODULE_2__.VIEW_SLUGS.FAVORITES === category; +}; + +/** + * Checks if the category is "Custom". + * + * @param {string} category The category slug. + * @return {boolean} True if the category is "Custom", otherwise false. + */ +var isCustomCategory = function isCustomCategory(category) { + return _shared__WEBPACK_IMPORTED_MODULE_2__.VIEW_SLUGS.CUSTOM === category; +}; + +/** + * Checks if a template is a favorite. + * + * @param {HTMLElement} template The template element. + * @return {boolean} True if the template is a favorite, otherwise false. + */ +var isFavoriteTemplate = function isFavoriteTemplate(template) { + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? template.classList.contains("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-favorite-item")) : false; +}; + +/** + * Checks if a template is custom. + * + * @param {HTMLElement} template The template element. + * @return {boolean} True if the template is custom, otherwise false. + */ +var isCustomTemplate = function isCustomTemplate(template) { + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? template.classList.contains("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-custom-item")) : false; +}; + +/** + * Checks if a template is featured. + * + * @param {HTMLElement} template The template element. + * @return {boolean} True if the template is featured, otherwise false. + */ +var isFeaturedTemplate = function isFeaturedTemplate(template) { + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? _shared__WEBPACK_IMPORTED_MODULE_2__.FEATURED_TEMPLATES_IDS.includes(Number(template.dataset.id)) : false; +}; + +/** + * Checks if a template is locked. + * + * @param {HTMLElement} template The template element. + * @return {boolean} True if the template is locked, otherwise false. + */ +var isLockedTemplate = function isLockedTemplate(template) { + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? template.classList.contains("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-locked-item")) : false; +}; + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. +(() => { +"use strict"; +/*!****************************************!*\ + !*** ./js/src/form-templates/index.js ***! + \****************************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./shared */ "./js/src/form-templates/shared/index.js"); +/* harmony import */ var _initializeFormTemplates__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./initializeFormTemplates */ "./js/src/form-templates/initializeFormTemplates.js"); +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + + +(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__["default"])(function () { + /** + * Entry point for pre-initialization adjustments to the page state. + * + * @param {Object} state Current state of the page. + */ + wp.hooks.doAction('frmFormTemplates.beforeInitialize', { + getState: _shared__WEBPACK_IMPORTED_MODULE_0__.getState, + setState: _shared__WEBPACK_IMPORTED_MODULE_0__.setState + }); + + // Initialize the form templates + (0,_initializeFormTemplates__WEBPACK_IMPORTED_MODULE_1__["default"])(); + + /** + * Entry point for post-initialization custom logic or adjustments to the page state. + * + * @param {Object} state Current state of the page. + */ + wp.hooks.doAction('frmFormTemplates.afterInitialize', { + getState: _shared__WEBPACK_IMPORTED_MODULE_0__.getState, + setState: _shared__WEBPACK_IMPORTED_MODULE_0__.setState + }); + + /** + * Trigger a specific action to interact with the hidden form '#frm-new-template', + * which is used for creating or using a form template. + * + * @param {HTMLElement} $form The jQuery object containing the hidden form element. + */ + wp.hooks.doAction('frm_new_form_modal_form', jQuery('#frm-new-template')); +}); +})(); + +/******/ })() +; +//# sourceMappingURL=form-templates.js.map \ No newline at end of file diff --git a/js/formidable-settings-components.js b/js/formidable-settings-components.js index 7c6275284a..d6a786b727 100644 --- a/js/formidable-settings-components.js +++ b/js/formidable-settings-components.js @@ -1 +1,2931 @@ -(()=>{"use strict";var e=window.frmGlobal,t=(e.url,e.nonce,"frm_hidden"),n="frm_disabled",r=(Promise.resolve(),frmDom),i=(r.div,r.span,r.tag,r.a,r.img,r.svg,frmDom.modal),o=(i.maybeCreateModal,i.footerButton,frmDom.util),a=(o.onClickPreventDefault,o.documentOn);frmDom.ajax.doJsonPost;var l=(new URL(window.location.href).searchParams,function(e){return null==e?void 0:e.classList.remove(t)});function s(e){return s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},s(e)}function c(e,t){for(var n=0;n0&&e.onRadioChange(t)})}))}},{key:"initVisibilityObserver",value:function(e){var t=this;this.observers.has(e)&&this.observers.get(e).disconnect();var n=new MutationObserver(function(){if(function(e){return"none"!==window.getComputedStyle(e).getPropertyValue("display")}(e)){var n=e.querySelector('input[type="radio"]:checked');n&&t.onRadioChange(n)}});this.observers.set(e,n),n.observe(e,{attributes:!0,attributeFilter:["class","style"]});for(var r=e.parentElement,i=0;i<7&&r;i++)n.observe(r,{attributes:!0,attributeFilter:["class","style"]}),r=r.parentElement}},{key:"cleanupObservers",value:function(){this.observers.forEach(function(e){e.disconnect()}),this.observers.clear()}},{key:"hideExtraElements",value:function(){var e=document.querySelectorAll(".frm-element-is-visible");0!==e.length&&e.forEach(function(e){e.classList.remove("frm-element-is-visible"),e.classList.add(t),function(e){null==e||e.classList.add(t)}(e)})}},{key:"moveTracker",value:function(e,t){var n=e.offsetLeft,r=e.offsetWidth,i=t.querySelector(".frm-radio-active-tracker");i.style.left=0,i.style.width="".concat(r,"px"),i.style.transform="translateX(".concat(n,"px)")}}])&&c(e.prototype,n),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,n}();function f(e){return f="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},f(e)}function m(e,t){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:[],r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.loadedByWebComponent=n.length>0,this.sliderElements=n.length>0?n:document.querySelectorAll(".frm-slider-component"),this.settings=r,0!==this.sliderElements.length){this.sliderBulletWidth=16,this.sliderMarginRight=5,this.eventsChange=[];var i=frmDom.util.debounce;this.valueChangeDebouncer=i(function(e){return t.triggerValueChange(e)},25),this.initOptions(),this.init()}}return n=e,r=[{key:"initOptions",value:function(){var e=this;this.options=[],this.sliderElements.forEach(function(t,n){var r=t.classList.contains("frm-has-multiple-values")?t.closest(".frm-style-component"):t,i=e.settings.steps||(t.dataset.steps?JSON.parse(t.dataset.steps):null);e.options.push({dragging:!1,startX:0,translateX:0,maxValue:parseInt(t.dataset.maxValue,10),element:t,index:n,value:0,steps:i,dependentUpdater:r.classList.contains("frm-style-dependent-updater-component")?new h(r):null})})}},{key:"init",value:function(){this.initDraggable(),this.loadedByWebComponent?this.initSlidersPositionInsideWebComponent():this.initSlidersPosition()}},{key:"initDraggable",value:function(){var t=this;this.sliderElements.forEach(function(n,r){t.eventsChange[r]=new Event("change",{bubbles:!0,cancelable:!0});var i=n.querySelector(".frm-slider-bullet"),o=n.querySelector('.frm-slider-value input[type="text"]');o.addEventListener("change",function(e){var i=n.querySelector("select").value;t.getMaxValue(i,r)1&&void 0!==arguments[1]?arguments[1]:null;if(!t.classList.contains("frm-disabled")){var r=null!==n?n:this.getSliderIndex(t),i=t.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth,o=parseInt(t.querySelector('.frm-slider-value input[type="text"]').value,10),a=t.querySelector("select").value,l=this.options[r].steps,s=Math.ceil(o/this.options[r].maxValue*i);"%"===a?s=Math.round(i*o/100):l&&l.length>0&&(s=e.calculateDeltaXFromSteps(o,l,i)),t.querySelector(".frm-slider-active-track").style.width="".concat(s,"px"),this.options[r].translateX=s,this.options[r].value=o+a}}},{key:"initChildSlidersWidth",value:function(e,t,n,r){var i=this;(e.classList.contains("frm-has-independent-fields")||e.classList.contains("frm-has-multiple-values"))&&(e.classList.contains("frm-has-independent-fields")?e.querySelectorAll(".frm-independent-slider-field"):this.getSliderGroupItems(e)).forEach(function(e,o){e.querySelector(".frm-slider-active-track").style.width="".concat(t,"px"),i.options[n+o+1].translateX=t,i.options[n+o+1].value=r})}},{key:"getSliderIndex",value:function(e){return this.options.filter(function(t){return t.element===e})[0].index}},{key:"moveTracker",value:function(t,n){if(this.options[n].dragging){var r=t.clientX-this.options[n].startX,i=this.sliderElements[n],o=i.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth;r=Math.max(r,0),r=Math.min(r,o);var a=i.querySelector("select").value,l=e.calculateValue(o,r,this.getMaxValue(a,n),this.options[n].steps);i.querySelector('.frm-slider-value input[type="text"]').value=l,i.querySelector(".frm-slider-bullet .frm-slider-value-label").innerText=l,i.querySelector(".frm-slider-active-track").style.width="".concat(r,"px"),this.initChildSlidersWidth(i,r,n,l+a),this.options[n].translateX=r,this.options[n].value=l+a,this.options[n].fullValue=this.updateValue(i,this.options[n].value),this.valueChangeDebouncer(n)}}},{key:"getMaxValue",value:function(e,t){return"%"===e?100:this.options[t].maxValue}},{key:"enableDragging",value:function(e,t){e.target.classList.add("frm-dragging"),this.options[t].dragging=!0,this.options[t].startX=e.clientX-this.options[t].translateX}},{key:"disableDragging",value:function(e){!1!==this.options[e].dragging&&(this.sliderElements[e].querySelector(".frm-slider-bullet").classList.remove("frm-dragging"),this.options[e].dragging=!1,this.triggerValueChange(e))}},{key:"triggerValueChange",value:function(e){var t=this;if(null===this.options[e].dependentUpdater){var n=this.sliderElements[e].classList.contains("frm-has-multiple-values")?this.sliderElements[e].closest(".frm-style-component").querySelector('input[type="hidden"]'):this.sliderElements[e].querySelectorAll('.frm-slider-value input[type="hidden"]');n instanceof NodeList?n.forEach(function(n){n.dispatchEvent(t.eventsChange[e])}):n.dispatchEvent(this.eventsChange[e])}else this.options[e].dependentUpdater.updateAllDependentElements(this.options[e].fullValue)}},{key:"updateValue",value:function(e,t){var n=this;if(e.classList.contains("frm-base-font-size")){var r=document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]');r&&(r.value="true")}if(e.classList.contains("frm-has-multiple-values")){var i=e.closest(".frm-style-component").querySelector('input[type="hidden"]'),o=i.value.split(" "),a=e.dataset.type;switch(o[2]||(o[2]="0px"),o[3]||(o[3]="0px"),a){case"vertical":o[0]=t,o[2]=t;break;case"horizontal":o[1]=t,o[3]=t;break;case"top":o[0]=t;break;case"bottom":o[2]=t;break;case"left":o[3]=t;break;case"right":o[1]=t}var l=o.join(" ");return i.value=l,this.getSliderGroupItems(e).forEach(function(e){var r=n.getUnitMeasureFromValue(t);e.querySelector('.frm-slider-value input[type="text"]').value=parseInt(t,10),e.querySelector("select").value=r}),l}if(e.classList.contains("frm-has-independent-fields")){var s=e.querySelectorAll('.frm-slider-value input[type="hidden"]'),c=e.querySelectorAll('.frm-slider-value input[type="text"]');return s.forEach(function(e,n){e.value=t,c[n+1].value=parseInt(t,10)}),t}return e.querySelector('.frm-slider-value input[type="hidden"]').value=t,t}},{key:"getUnitMeasureFromValue",value:function(e){return["%","px","em"].find(function(t){return e.includes(t)})||""}}],i=[{key:"maybeDisableUnitDropdown",value:function(e){var t=e.querySelector("select");t&&1>=Array.from(t.options).filter(function(e){return""!==e.value}).length&&(t.classList.add("frm-single-unit"),t.addEventListener("mousedown",function(e){return e.preventDefault()}))}},{key:"calculateDeltaXFromSteps",value:function(t,n,r){var i=n.indexOf(t);if(-1===i){var o=e.snapToStep(t,n),a=n.indexOf(o);return Math.round(a/(n.length-1)*r)}return Math.round(i/(n.length-1)*r)}},{key:"calculateValue",value:function(e,t,n){var r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null;if(r&&r.length>0){var i=t/e,o=Math.round(i*(r.length-1));return r[Math.max(0,Math.min(o,r.length-1))]}var a=Math.round(t/e*n);return Math.min(a,n)}},{key:"snapToStep",value:function(e,t){for(var n=t[0],r=Math.abs(e-n),i=1;i li"),this.slideTrackLine=this.wrapper.querySelector(".frm-tabs-active-underline"),this.slideTrack=this.wrapper.querySelector(".frm-tabs-slide-track"),this.slides=this.wrapper.querySelectorAll(".frm-tabs-slide-track > div"),this.isRTL="rtl"===document.documentElement.dir||"rtl"===document.body.dir,this.resizeObserver=null,this.init()))},(t=[{key:"init",value:function(){var e=this;null!==this.wrapper&&this.navs.length&&null!==this.slideTrackLine&&null!==this.slideTrack&&this.slides.length&&(this.navs.forEach(function(t,n){t.addEventListener("click",function(t){return e.onNavClick(t,n)}),t.classList.contains("frm-active")&&e.initSlideTrackUnderline(t)}),this.slideTrackLine.style.display="block",this.setupScrollbarObserver(),window.addEventListener("beforeunload",this.cleanupObservers))}},{key:"onNavClick",value:function(e,t){var n=e.currentTarget;e.preventDefault(),this.removeActiveClassnameFromNavs(),n.classList.add("frm-active"),this.initSlideTrackUnderline(n),this.changeSlide(t);var r,i,o=n.querySelector("a");o&&"frm_insert_fields_tab"===o.id&&!o.closest("#frm_adv_info")&&(null===(r=window.frmAdminBuild)||void 0===r||null===(i=r.clearSettingsBox)||void 0===i||i.call(r))}},{key:"initSlideTrackUnderline",value:function(e){var t=void 0!==e?e:this.navs.filter(function(e){return e.classList.contains("frm-active")});this.positionUnderlineIndicator(t)}},{key:"setupScrollbarObserver",value:function(){var e=this,t=document.querySelector(".frm-scrollbar-wrapper, .styling_settings")||document.body;t&&"ResizeObserver"in window&&(this.resizeObserver=new ResizeObserver(function(){var t=e.wrapper.querySelector(".frm-tabs-navs ul > li.frm-active");t&&e.positionUnderlineIndicator(t)}),this.resizeObserver.observe(t))}},{key:"cleanupObservers",value:function(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null)}},{key:"positionUnderlineIndicator",value:function(e){var t=this;requestAnimationFrame(function(){var n=t.isRTL?-(e.parentElement.offsetWidth-e.offsetLeft-e.offsetWidth):e.offsetLeft;t.slideTrackLine.style.transform="translateX(".concat(n,"px)"),t.slideTrackLine.style.width="".concat(e.clientWidth,"px")})}},{key:"changeSlide",value:function(e){this.removeActiveClassnameFromSlides();var t=0==e?"0px":"calc( ( ".concat(100*e,"% + ").concat(parseInt(this.flexboxSlidesGap,10)*e,"px ) * ").concat(this.isRTL?1:-1," )");"0px"!==t?this.slideTrack.style.transform="translateX(".concat(t,")"):this.slideTrack.style.removeProperty("transform"),e in this.slides&&this.slides[e].classList.add("frm-active")}},{key:"removeActiveClassnameFromSlides",value:function(){this.slides.forEach(function(e){return e.classList.remove("frm-active")})}},{key:"removeActiveClassnameFromNavs",value:function(){this.navs.forEach(function(e){return e.classList.remove("frm-active")})}}])&&k(e.prototype,t),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,t}();function q(e){return q="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},q(e)}function L(e,t){for(var n=0;n0))return e.style.paddingLeft="",e.style.paddingTop="",void(e.style.height="");var r=t.offsetHeight;if(Math.max(1,Math.ceil(r/36))>1){var i=function(e){if(!e.length)return 0;var t=0;return e.forEach(function(e){t+=e.offsetWidth}),(t+=4*(e.length-1))+4}(function(e){if(!e.length)return[];var t=Array.from(e),n=-1;t.forEach(function(e){var t=e.getBoundingClientRect().bottom;t>n&&(n=t)});return t.filter(function(e){var t=e.getBoundingClientRect();return Math.abs(t.bottom-n)<=2})}(n));e.style.height="".concat(r,"px"),e.style.paddingTop="".concat(r-36+4,"px"),e.style.paddingLeft=i?"".concat(i+8,"px"):""}else e.style.height="",e.style.paddingTop="",e.style.paddingLeft="".concat(t.offsetWidth-4,"px")}}function F(e,t,n){e&&n&&t&&(n.innerHTML="",z(e).forEach(function(e){return function(e,t){var n=D({className:O,children:[D({text:e,className:P}),D({className:_,child:I({href:"#frm_close_icon"})})]});t.append(n)}(e,n)}),R(t,n),t.focus())}function B(e,t,n){if(!e||!t||!n)return!1;var r=z(t.value);return r.includes(e)?(N(n),!1):(r.push(e),X(t,r),N(n),!0)}function U(e,t,n){if(e&&t&&n){var r=e.querySelector(".".concat(P)).textContent;X(t,z(t.value).filter(function(e){return e!==r})),e.remove(),n.focus()}}function z(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"";return(e=e.trim())?e.split(/\s+/).filter(Boolean):[]}function X(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];e&&(e.value=t.join(" "),jQuery(e).trigger("change"))}function N(e){e&&(e.value="",e.focus())}function G(e){var n=(e?document.getElementById("frm-single-settings-".concat(e)):document.body).querySelectorAll(".".concat("frm-token-input-field"));if(n.length){var r=new Set;n.forEach(function(e){r.has(e.id)||(function(e){var n=function(e){var n=e.closest(".".concat("frm-with-right-icon"));if(n.querySelector(".".concat(T)))return null;n.classList.add(A);var r=D({className:T});n.insertBefore(r,n.firstChild);var i=j("input",{className:V,id:"".concat(e.id,"-proxy-input")});return i.type="text",e.parentNode.insertBefore(i,e.nextSibling),e.classList.add(t),n}(e);if(n){var r=n.querySelector(".".concat(V)),i=n.querySelector(".".concat(T));F(e.value,r,i),function(e,t,n){jQuery(e).on("change",function(){return F(e.value,t,n)}),t.addEventListener("keydown",function(r){return function(e,t,n,r){var i=e.key,o=n.value.trim();switch(i){case"Backspace":o||(e.preventDefault(),U(r.querySelector(".".concat(O,":last-child")),t,n));break;case" ":case",":case"Enter":e.preventDefault(),B(o,t,n)}R(n,r)}(r,e,t,n)}),t.addEventListener("blur",function(){return B(t.value.trim(),e,t)}),n.addEventListener("click",function(n){return function(e,t,n){var r=e.target.closest(".".concat(_));if(r){var i=r.closest(".".concat(O));if(i){var o=i.parentElement;U(i,t,n),R(n,o)}}}(n,e,t)})}(e,r,i)}}(e),r.add(e.id))})}}var J,H="frm-toggle-group",Q="frm_toggle_block",K="data-group-name";function Y(e){var t=e.target,n=t.closest(".".concat(H));n&&Z(t,n)}function Z(e,r){var i,o=(null===(i=r.closest(".".concat("frm-single-settings")))||void 0===i?void 0:i.dataset.fid)||r.dataset.fid,a=e.checked,l=e.getAttribute("data-show");l&&document.querySelectorAll($(l,o)).forEach(function(e){return e.classList.toggle(t,!a)});var s=e.getAttribute("data-disable");s&&document.querySelectorAll($(s,o)).forEach(function(e){e.classList.toggle(n,a),e.querySelectorAll("input, select, textarea").forEach(function(e){return e.disabled=a}),e.querySelectorAll(".frm-show-inline-modal[tabindex]").forEach(function(e){return e.tabIndex=a?-1:0})});var c=e.getAttribute("data-enable");c&&document.querySelectorAll($(c,o)).forEach(function(e){return e.classList.toggle(n,!a)});var u=e.closest(".".concat(Q));Array.from(r.querySelectorAll(".".concat(Q))).filter(function(e){return e!==u}).forEach(function(e){e.classList.toggle(n,a);var t=e.querySelector(".frm_toggle");t.tabIndex=a?-1:0,t.setAttribute("aria-disabled",a)})}function $(e,t){return e.replace(/{id}/g,t)}function ee(e){var t=e.target.closest(".frm-unit-input"),n=t.querySelector(".frm-unit-input-control"),r=t.querySelector("select").value;e.target.matches("select")&&(n.type=""===r?"text":"number");var i=n.value.trim();t.querySelector('input[type="hidden"]').value=""!==i?i+r:""}J=function(){var e,t;new d,new b,new C,null===(t=document.getElementById("frm-form-add-field"))||void 0===t||t.addEventListener("click",function(e){var t;e.preventDefault(),null===(t=document.querySelector(".frm-settings-panel .frm-tabs-navs ul > li:first-child"))||void 0===t||t.click()}),G(),document.addEventListener("frm_added_field",function(e){return G(e.frmField.dataset.fid)}),document.addEventListener("frm_ajax_loaded_field",function(e){return e.frmFields.forEach(function(e){return G(e.id)})}),wp.hooks.addAction("frmShowedFieldSettings","formidable-token-input",M),(e=document.querySelectorAll(".".concat(H))).length&&e.forEach(function(e){var t=e.querySelector("[".concat(K,"]:checked"));t&&Z(t,e)}),a("change",".".concat(H," [").concat(K,"]"),Y),a("change",".frm-unit-input .frm-unit-input-control",ee),a("change",".frm-unit-input select",ee)},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",J):J())})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": +/*!*****************************************************************!*\ + !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ domReady) +/* harmony export */ }); +/** + * @typedef {() => void} Callback + * + * TODO: Remove this typedef and inline `() => void` type. + * + * This typedef is used so that a descriptive type is provided in our + * automatically generated documentation. + * + * An in-line type `() => void` would be preferable, but the generated + * documentation is `null` in that case. + * + * @see https://github.com/WordPress/gutenberg/issues/18045 + */ + +/** + * Specify a function to execute when the DOM is fully loaded. + * + * @param {Callback} callback A function to execute after the DOM is ready. + * + * @example + * ```js + * import domReady from '@wordpress/dom-ready'; + * + * domReady( function() { + * //do something after DOM loads. + * } ); + * ``` + * + * @return {void} + */ +function domReady(callback) { + if (typeof document === 'undefined') { + return; + } + + if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. + document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. + ) { + return void callback(); + } // DOMContentLoaded has not fired yet, delay callback until then. + + + document.addEventListener('DOMContentLoaded', callback); +} +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./js/src/admin/components/dependent-updater-component.js": +/*!****************************************************************!*\ + !*** ./js/src/admin/components/dependent-updater-component.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmStyleDependentUpdaterComponent) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * This component updates the dependent style element's values and triggers a custom change event for each style element, initiating the style preview. + * The names of the elements that will be updated are specified using the "will-change" attribute. + * It is primarily used in components from Style/Quick Settings. + * For instance, when the "FrmPrimaryColorStyleComponent" is changed, it simultaneously updates various style elements like border color, text color, and button backgrounds. + */ +var frmStyleDependentUpdaterComponent = /*#__PURE__*/function () { + /** + * Creates an instance of frmStyleDependentUpdaterComponent. + * + * @param {HTMLElement} component - The component element. + */ + function frmStyleDependentUpdaterComponent(component) { + _classCallCheck(this, frmStyleDependentUpdaterComponent); + this.component = component; + try { + var willChangeData = JSON.parse(this.component.dataset.willChange); + this.data = { + propagateInputs: this.initPropagationList(willChangeData), + changeEvent: new Event('change', { + bubbles: true + }) + }; + } catch (error) { + console.error('Error parsing JSON data from "will-change" attribute.', error); + } + } + + /** + * Initializes the list of inputs to propagate changes to. + * The selection is made by provided input's names list in "will-change" attribute. + * + * @param {string[]} inputNames - The names of the inputs to propagate changes to. + * @return {HTMLElement[]} - The list of inputs to propagate changes to. + */ + return _createClass(frmStyleDependentUpdaterComponent, [{ + key: "initPropagationList", + value: function initPropagationList(inputNames) { + var list = []; + inputNames.forEach(function (name) { + var input = document.querySelector("input[name=\"".concat(name, "\"]")); + if (input) { + list.push(input); + } + }); + return list; + } + + /** + * Updates all dependent elements with the given value. + * + * @param {string} value - The value to update the dependent elements with. + */ + }, { + key: "updateAllDependentElements", + value: function updateAllDependentElements(value) { + this.data.propagateInputs.forEach(function (input) { + input.value = value; + }); + this.data.propagateInputs[0].dispatchEvent(this.data.changeEvent); + } + }]); +}(); + + +/***/ }), + +/***/ "./js/src/components/class-tabs-navigator.js": +/*!***************************************************!*\ + !*** ./js/src/components/class-tabs-navigator.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmTabsNavigator: () => (/* binding */ frmTabsNavigator) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmTabsNavigator = /*#__PURE__*/function () { + function frmTabsNavigator(wrapper) { + _classCallCheck(this, frmTabsNavigator); + if (wrapper === undefined) { + return; + } + this.wrapper = wrapper instanceof Element ? wrapper : document.querySelector(wrapper); + if (null === this.wrapper) { + return; + } + this.flexboxSlidesGap = '16px'; + this.navs = this.wrapper.querySelectorAll('.frm-tabs-navs ul > li'); + this.slideTrackLine = this.wrapper.querySelector('.frm-tabs-active-underline'); + this.slideTrack = this.wrapper.querySelector('.frm-tabs-slide-track'); + this.slides = this.wrapper.querySelectorAll('.frm-tabs-slide-track > div'); + this.isRTL = document.documentElement.dir === 'rtl' || document.body.dir === 'rtl'; + this.resizeObserver = null; + this.init(); + } + return _createClass(frmTabsNavigator, [{ + key: "init", + value: function init() { + var _this = this; + if (null === this.wrapper || !this.navs.length || null === this.slideTrackLine || null === this.slideTrack || !this.slides.length) { + return; + } + this.navs.forEach(function (nav, index) { + nav.addEventListener('click', function (event) { + return _this.onNavClick(event, index); + }); + if (nav.classList.contains('frm-active')) { + _this.initSlideTrackUnderline(nav); + } + }); + this.slideTrackLine.style.display = 'block'; + this.setupScrollbarObserver(); + // Cleanup observers when page unloads to prevent memory leaks + window.addEventListener('beforeunload', this.cleanupObservers); + } + }, { + key: "onNavClick", + value: function onNavClick(event, index) { + var navItem = event.currentTarget; + event.preventDefault(); + this.removeActiveClassnameFromNavs(); + navItem.classList.add('frm-active'); + this.initSlideTrackUnderline(navItem); + this.changeSlide(index); + + // Handle special case for frm_insert_fields_tab + var navLink = navItem.querySelector('a'); + if (navLink && navLink.id === 'frm_insert_fields_tab' && !navLink.closest('#frm_adv_info')) { + var _window$frmAdminBuild, _window$frmAdminBuild2; + (_window$frmAdminBuild = window.frmAdminBuild) === null || _window$frmAdminBuild === void 0 || (_window$frmAdminBuild2 = _window$frmAdminBuild.clearSettingsBox) === null || _window$frmAdminBuild2 === void 0 || _window$frmAdminBuild2.call(_window$frmAdminBuild); + } + } + }, { + key: "initSlideTrackUnderline", + value: function initSlideTrackUnderline(nav) { + var activeNav = nav !== undefined ? nav : this.navs.filter(function (nav) { + return nav.classList.contains('frm-active'); + }); + this.positionUnderlineIndicator(activeNav); + } + + /** + * Sets up a ResizeObserver to watch for scrollbar changes in the parent container. + * Automatically repositions the underline indicator when layout changes occur. + */ + }, { + key: "setupScrollbarObserver", + value: function setupScrollbarObserver() { + var _this2 = this; + var resizeObserverTarget = document.querySelector('.frm-scrollbar-wrapper, .styling_settings') || document.body; + if (!resizeObserverTarget || !('ResizeObserver' in window)) { + return; + } + this.resizeObserver = new ResizeObserver(function () { + var activeNav = _this2.wrapper.querySelector('.frm-tabs-navs ul > li.frm-active'); + if (activeNav) { + _this2.positionUnderlineIndicator(activeNav); + } + }); + this.resizeObserver.observe(resizeObserverTarget); + } + + /** + * Cleans up observers to prevent memory leaks. + */ + }, { + key: "cleanupObservers", + value: function cleanupObservers() { + if (this.resizeObserver) { + this.resizeObserver.disconnect(); + this.resizeObserver = null; + } + } + + /** + * Positions the underline indicator based on the active navigation element. + * + * @param {HTMLElement} activeNav The active navigation element to position the underline under + */ + }, { + key: "positionUnderlineIndicator", + value: function positionUnderlineIndicator(activeNav) { + var _this3 = this; + requestAnimationFrame(function () { + var position = _this3.isRTL ? -(activeNav.parentElement.offsetWidth - activeNav.offsetLeft - activeNav.offsetWidth) : activeNav.offsetLeft; + _this3.slideTrackLine.style.transform = "translateX(".concat(position, "px)"); + _this3.slideTrackLine.style.width = "".concat(activeNav.clientWidth, "px"); + }); + } + }, { + key: "changeSlide", + value: function changeSlide(index) { + this.removeActiveClassnameFromSlides(); + var translate = index == 0 ? '0px' : "calc( ( ".concat(index * 100, "% + ").concat(parseInt(this.flexboxSlidesGap, 10) * index, "px ) * ").concat(this.isRTL ? 1 : -1, " )"); + if ('0px' !== translate) { + this.slideTrack.style.transform = "translateX(".concat(translate, ")"); + } else { + this.slideTrack.style.removeProperty('transform'); + } + if (index in this.slides) { + this.slides[index].classList.add('frm-active'); + } + } + }, { + key: "removeActiveClassnameFromSlides", + value: function removeActiveClassnameFromSlides() { + this.slides.forEach(function (slide) { + return slide.classList.remove('frm-active'); + }); + } + }, { + key: "removeActiveClassnameFromNavs", + value: function removeActiveClassnameFromNavs() { + this.navs.forEach(function (nav) { + return nav.classList.remove('frm-active'); + }); + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }), + +/***/ "./js/src/settings-components/components/index.js": +/*!********************************************************!*\ + !*** ./js/src/settings-components/components/index.js ***! + \********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmRadioComponent: () => (/* reexport safe */ _radio_component__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ frmSliderComponent: () => (/* reexport safe */ _slider_component__WEBPACK_IMPORTED_MODULE_1__["default"]), +/* harmony export */ frmTabsComponent: () => (/* reexport safe */ _tabs_component__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ initToggleGroupComponents: () => (/* reexport safe */ _toggle_group__WEBPACK_IMPORTED_MODULE_4__.initToggleGroupComponents), +/* harmony export */ initTokenInputFields: () => (/* reexport safe */ _token_input__WEBPACK_IMPORTED_MODULE_3__.initTokenInputFields), +/* harmony export */ setupUnitInputHandlers: () => (/* reexport safe */ _unit_input__WEBPACK_IMPORTED_MODULE_5__.setupUnitInputHandlers) +/* harmony export */ }); +/* harmony import */ var _radio_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./radio-component */ "./js/src/settings-components/components/radio-component.js"); +/* harmony import */ var _slider_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./slider-component */ "./js/src/settings-components/components/slider-component.js"); +/* harmony import */ var _tabs_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tabs-component */ "./js/src/settings-components/components/tabs-component.js"); +/* harmony import */ var _token_input__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./token-input */ "./js/src/settings-components/components/token-input/index.js"); +/* harmony import */ var _toggle_group__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./toggle-group */ "./js/src/settings-components/components/toggle-group/index.js"); +/* harmony import */ var _unit_input__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./unit-input */ "./js/src/settings-components/components/unit-input.js"); + + + + + + + +/***/ }), + +/***/ "./js/src/settings-components/components/radio-component.js": +/*!******************************************************************!*\ + !*** ./js/src/settings-components/components/radio-component.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmRadioComponent) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Internal dependencies + */ + + + +/** + * Represents a radio component. + * + * @class + */ +var frmRadioComponent = /*#__PURE__*/function () { + function frmRadioComponent() { + var _this = this; + _classCallCheck(this, frmRadioComponent); + this.radioElements = document.querySelectorAll('.frm-style-component.frm-radio-component'); + this.observers = new Map(); + if (0 < this.radioElements.length) { + this.init(); + } + + /** + * Handles the addition of new fields. + * + * @param {Event} event The frm_added_field event. + * @param {HTMLElement} event.frmField The added field object being destructured from the event. + */ + document.addEventListener('frm_added_field', function (_ref) { + var frmField = _ref.frmField; + return _this.discoverAndInitFieldRadios(frmField.dataset.fid); + }); + + /** + * Handles the addition of new fields via AJAX. + * + * @param {Event} event The frm_ajax_loaded_field event. + * @param {HTMLElement} event.frmFields The added field objects being destructured from the event. + */ + document.addEventListener('frm_ajax_loaded_field', function (_ref2) { + var frmFields = _ref2.frmFields; + return frmFields.forEach(function (field) { + return _this.discoverAndInitFieldRadios(field.id); + }); + }); + + // Cleanup observers when page unloads to prevent memory leaks + window.addEventListener('beforeunload', function () { + return _this.cleanupObservers(); + }); + + // Handle window resize with throttling + this.resizeTimeout = null; + window.addEventListener('resize', function () { + return _this.throttledUpdateAllTrackers(); + }); + } + + /** + * Initializes the radio component. + */ + return _createClass(frmRadioComponent, [{ + key: "init", + value: function init() { + this.initRadio(); + this.initTrackerOnAccordionClick(); + } + + /** + * Discovers and initializes radio components for a specific field. + * + * @param {string|number} fieldId The unique identifier of the field whose radio components should be discovered and initialized + * @throws {Error} Throws an error if the field container is not found in the DOM + */ + }, { + key: "discoverAndInitFieldRadios", + value: function discoverAndInitFieldRadios(fieldId) { + var fieldContainer = document.getElementById("frm-single-settings-".concat(fieldId)); + if (!fieldContainer) { + throw new Error("Field container not found for field ID: ".concat(fieldId)); + } + this.radioElements = fieldContainer.querySelectorAll('.frm-style-component.frm-radio-component'); + this.initRadio(); + } + + /** + * Initializes the radio component. + */ + }, { + key: "initRadio", + value: function initRadio() { + var _this2 = this; + this.radioElements.forEach(function (element) { + _this2.initOnRadioChange(element); + _this2.initVisibilityObserver(element); + }); + } + }, { + key: "initTrackerOnAccordionClick", + value: function initTrackerOnAccordionClick() { + var _this3 = this; + var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); + accordionitems.forEach(function (accordionitem) { + accordionitem.addEventListener('click', function (event) { + var wrapper = event.target.closest('.accordion-section'); + var radioButtons = wrapper.querySelectorAll('.frm-style-component.frm-radio-component input[type="radio"]:checked'); + radioButtons.forEach(function (radio) { + setTimeout(function () { + return _this3.onRadioChange(radio); + }, 200); + }); + }); + }); + } + + /** + * Initializes the onRadioChange event for the given wrapper. + * + * @param {HTMLElement} radioElement - The radio element. + */ + }, { + key: "initOnRadioChange", + value: function initOnRadioChange(radioElement) { + var _this4 = this; + radioElement.querySelectorAll('input[type="radio"]').forEach(function (radio) { + if (radio.checked) { + _this4.onRadioChange(radio); + } + radio.addEventListener('change', function (event) { + _this4.onRadioChange(event.target); + }); + }); + } + + /** + * Handles the onRadioChange event for the given wrapper. + * + * @param {HTMLElement} target - The active radio button. + */ + }, { + key: "onRadioChange", + value: function onRadioChange(target) { + var wrapper = target.closest('.frm-style-component.frm-radio-component'); + var activeItem = wrapper.querySelector('input[type="radio"]:checked + label'); + if (null === activeItem) { + return; + } + this.moveTracker(activeItem, wrapper); + this.hideExtraElements(target); + this.maybeShowExtraElements(target); + } + + /** + * Display additional elements related to the selected radio option. + * + * @param {HTMLElement} radio - The radio button element. + */ + }, { + key: "maybeShowExtraElements", + value: function maybeShowExtraElements(radio) { + var elementAttr = radio.getAttribute('data-frm-show-element'); + if (null === elementAttr) { + return; + } + var elements = document.querySelectorAll("div[data-frm-element=\"".concat(elementAttr, "\"]")); + if (0 === elements.length) { + return; + } + elements.forEach(function (element) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(element); + element.classList.add('frm-element-is-visible'); + }); + } + + /** + * Throttled update of all radio trackers on window resize. + * + * @return {void} + */ + }, { + key: "throttledUpdateAllTrackers", + value: function throttledUpdateAllTrackers() { + var _this5 = this; + if (this.resizeTimeout) { + return; + } + this.resizeTimeout = requestAnimationFrame(function () { + _this5.resizeTimeout = null; + document.querySelectorAll('.frm-radio-component input[type="radio"]:checked').forEach(function (radio) { + var wrapper = radio.closest('.frm-radio-component'); + if (wrapper && wrapper.offsetWidth > 0) { + _this5.onRadioChange(radio); + } + }); + }); + } + + /** + * Initializes visibility observer for the radio component. This handles cases when components are conditionally shown. + * + * @param {HTMLElement} element The radio component element + * @return {void} + */ + }, { + key: "initVisibilityObserver", + value: function initVisibilityObserver(element) { + var _this6 = this; + if (this.observers.has(element)) { + this.observers.get(element).disconnect(); + } + var observer = new MutationObserver(function () { + // Check if element is now visible + if ((0,core_utils__WEBPACK_IMPORTED_MODULE_1__.isVisible)(element)) { + var radio = element.querySelector('input[type="radio"]:checked'); + if (radio) { + _this6.onRadioChange(radio); + } + } + }); + this.observers.set(element, observer); + + // Observe for attribute changes on the component and its ancestors + observer.observe(element, { + attributes: true, + attributeFilter: ['class', 'style'] + }); + + // Also observe parent elements up to a reasonable depth + var parent = element.parentElement; + for (var i = 0; i < 7 && parent; i++) { + observer.observe(parent, { + attributes: true, + attributeFilter: ['class', 'style'] + }); + parent = parent.parentElement; + } + } + + /** + * Cleanup all observers to prevent memory leaks. + */ + }, { + key: "cleanupObservers", + value: function cleanupObservers() { + this.observers.forEach(function (observer) { + observer.disconnect(); + }); + this.observers.clear(); + } + + /** + * Hide the possible opepend extra elements. + */ + }, { + key: "hideExtraElements", + value: function hideExtraElements() { + var elements = document.querySelectorAll('.frm-element-is-visible'); + if (0 === elements.length) { + return; + } + elements.forEach(function (element) { + element.classList.remove('frm-element-is-visible'); + element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(element); + }); + } + + /** + * Moves the tracker to the active item. + * + * @param {HTMLElement} activeItem - The active item element. + * @param {HTMLElement} wrapper - The wrapper element. + */ + }, { + key: "moveTracker", + value: function moveTracker(activeItem, wrapper) { + var offset = activeItem.offsetLeft; + var width = activeItem.offsetWidth; + var tracker = wrapper.querySelector('.frm-radio-active-tracker'); + tracker.style.left = 0; + tracker.style.width = "".concat(width, "px"); + tracker.style.transform = "translateX(".concat(offset, "px)"); + } + }]); +}(); + + +/***/ }), + +/***/ "./js/src/settings-components/components/slider-component.js": +/*!*******************************************************************!*\ + !*** ./js/src/settings-components/components/slider-component.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmSliderComponent) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../admin/components/dependent-updater-component */ "./js/src/admin/components/dependent-updater-component.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Internal dependencies + */ + + + +/** + * Represents a slider component. + * + * @class frmSliderComponent + */ +var frmSliderComponent = /*#__PURE__*/function () { + function frmSliderComponent() { + var _this = this; + var sliderElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; + var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + _classCallCheck(this, frmSliderComponent); + this.loadedByWebComponent = sliderElements.length > 0; + this.sliderElements = sliderElements.length > 0 ? sliderElements : document.querySelectorAll('.frm-slider-component'); + this.settings = settings; + if (0 === this.sliderElements.length) { + return; + } + + // The slider bullet point width in pixels. Used in value calculation on drag event. + this.sliderBulletWidth = 16; + this.sliderMarginRight = 5; + this.eventsChange = []; + var debounce = frmDom.util.debounce; + this.valueChangeDebouncer = debounce(function (index) { + return _this.triggerValueChange(index); + }, 25); + this.initOptions(); + this.init(); + } + + /** + * Initializes the options for the slider component. + */ + return _createClass(frmSliderComponent, [{ + key: "initOptions", + value: function initOptions() { + var _this2 = this; + this.options = []; + this.sliderElements.forEach(function (element, index) { + var parentWrapper = element.classList.contains('frm-has-multiple-values') ? element.closest('.frm-style-component') : element; + var steps = _this2.settings.steps || (element.dataset.steps ? JSON.parse(element.dataset.steps) : null); + _this2.options.push({ + dragging: false, + startX: 0, + translateX: 0, + maxValue: parseInt(element.dataset.maxValue, 10), + element: element, + index: index, + value: 0, + steps: steps, + dependentUpdater: parentWrapper.classList.contains('frm-style-dependent-updater-component') ? new _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__["default"](parentWrapper) : null + }); + }); + } + + /** + * Initializes the slider component. + */ + }, { + key: "init", + value: function init() { + this.initDraggable(); + if (this.loadedByWebComponent) { + this.initSlidersPositionInsideWebComponent(); + return; + } + this.initSlidersPosition(); + } + + /** + * Initializes the draggable functionality for the slider component. + */ + }, { + key: "initDraggable", + value: function initDraggable() { + var _this3 = this; + this.sliderElements.forEach(function (element, index) { + _this3.eventsChange[index] = new Event('change', { + bubbles: true, + cancelable: true + }); + var draggableBullet = element.querySelector('.frm-slider-bullet'); + var valueInput = element.querySelector('.frm-slider-value input[type="text"]'); + valueInput.addEventListener('change', function (event) { + var unit = element.querySelector('select').value; + if (_this3.getMaxValue(unit, index) < parseInt(event.target.value, 10)) { + return; + } + _this3.initSliderWidth(element); + _this3.options[index].fullValue = _this3.updateValue(element, valueInput.value + unit); + _this3.triggerValueChange(index); + }); + _this3.expandSliderGroup(element); + _this3.updateOnUnitChange(element, valueInput, index); + _this3.changeSliderPositionOnClick(element, valueInput, index); + frmSliderComponent.maybeDisableUnitDropdown(element); + draggableBullet.addEventListener('mousedown', function (event) { + event.preventDefault(); + event.stopPropagation(); + if (element.classList.contains('frm-disabled')) { + return; + } + _this3.enableDragging(event, index); + var onMouseMove = function onMouseMove(moveEvent) { + return _this3.moveTracker(moveEvent, index); + }; + var _onMouseUp = function onMouseUp() { + _this3.disableDragging(index); + document.removeEventListener('mousemove', onMouseMove); + document.removeEventListener('mouseup', _onMouseUp); + }; + document.addEventListener('mousemove', onMouseMove); + document.addEventListener('mouseup', _onMouseUp); + }); + }); + } + }, { + key: "expandSliderGroup", + value: function expandSliderGroup(element) { + var svgIcon = element.querySelector('.frmsvg'); + if (element.dataset.displaySliders === undefined || null === svgIcon) { + return; + } + var sliderGroupItems = this.getSliderGroupItems(element); + svgIcon.addEventListener('click', function () { + sliderGroupItems.forEach(function (item) { + item.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); + }); + }); + } + }, { + key: "updateOnUnitChange", + value: function updateOnUnitChange(element, valueInput, index) { + var _this4 = this; + element.querySelector('select').addEventListener('change', function (event) { + var unit = event.target.value.toLowerCase(); + if ('' === unit) { + element.classList.add('frm-disabled', 'frm-empty'); + return; + } + if ('auto' === unit) { + element.classList.add('frm-disabled'); + _this4.updateValue(element, 'auto'); + _this4.triggerValueChange(index); + return; + } + element.classList.remove('frm-disabled', 'frm-empty'); + _this4.options[index].fullValue = valueInput.value + unit; + _this4.updateValue(element, _this4.options[index].fullValue); + _this4.triggerValueChange(index); + }); + } + }, { + key: "changeSliderPositionOnClick", + value: function changeSliderPositionOnClick(element, valueInput, index) { + var _this5 = this; + var frmSlider = element.querySelector('.frm-slider'); + var customEvent = new Event('change', { + bubbles: true, + cancelable: true + }); + frmSlider.addEventListener('click', function (event) { + if (element.classList.contains('frm-disabled')) { + return; + } + event.preventDefault(); + event.stopPropagation(); + if (!event.target.classList.contains('frm-slider') && !event.target.classList.contains('frm-slider-active-track')) { + return; + } + var sliderWidth = frmSlider.offsetWidth - _this5.sliderBulletWidth; + var sliderRect = frmSlider.getBoundingClientRect(); + var deltaX = event.clientX - sliderRect.left - _this5.sliderBulletWidth; + var unit = element.querySelector('select').value; + var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, _this5.getMaxValue(unit, index), _this5.options[index].steps); + if (value < 0) { + return; + } + _this5.options[index].fullValue = _this5.updateValue(element, value + unit); + _this5.initChildSlidersWidth(element, deltaX, index, value + unit); + valueInput.value = value; + valueInput.dispatchEvent(customEvent); + }); + } + + /** + * Disables the unit dropdown if there is only a single unit option. + * + * @param {HTMLElement} element - The slider element. + */ + }, { + key: "getSliderGroupItems", + value: + /** + * Retrieves an array of slider group items based on the provided element. + * + * @param {HTMLElement} element - The element to retrieve slider group items from. + * @return {NodeList} - An array-like object containing the slider group items. + */ + function getSliderGroupItems(element) { + if (element.dataset.displaySliders === undefined) { + return []; + } + var slidersGroup = element.dataset.displaySliders.split(','); + var query = slidersGroup.map(function (item) { + return ".frm-slider-component[data-type=\"".concat(item, "\"]"); + }).join(', '); + return element.closest('.frm-style-component').querySelectorAll(query); + } + }, { + key: "initSlidersPositionInsideWebComponent", + value: function initSlidersPositionInsideWebComponent() { + var _this6 = this; + this.sliderElements.forEach(function (element, index) { + _this6.initSliderWidth(element, index); + }); + } + + /** + * Initializes the position of sliders when a accordion section is opened. + */ + }, { + key: "initSlidersPosition", + value: function initSlidersPosition() { + var _this7 = this; + var emailSettings = document.querySelector('.email_settings'); + if (emailSettings) { + this.initSlidersWidth(emailSettings); + return; + } + var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); + var quickSettings = document.querySelector('.frm-quick-settings'); + var openedAccordion = document.querySelector('.accordion-section.open'); + + // Detect if upload background image upload has triggered and initialize the "Image Opacity" slider width. + wp.hooks.addAction('frm_pro_on_bg_image_upload', 'formidable', function (event) { + var imageBackgroundOpacitySlider = event.closest('.accordion-section-content').querySelector('#frm-bg-image-opacity-slider'); + _this7.initSlidersWidth(imageBackgroundOpacitySlider); + }); + + // init the sliders width from "Quick Settings" page. + if (quickSettings) { + this.initSlidersWidth(quickSettings); + } + + // Init the sliders width in opened accordion section from "Advanced Settings" page. + if (openedAccordion) { + this.initSlidersWidth(openedAccordion); + } + + // init the sliders width everytime when an accordion section is opened from "Advanced Settings" page. + accordionitems.forEach(function (item) { + item.addEventListener('click', function (event) { + _this7.initSlidersWidth(event.target.closest('.accordion-section')); + }); + }); + this.initSliderPositionOnFieldShapeChange(); + } + + /** + * Initializes the width of "Corner Radius" slider that is dynamically is displayed on "Field Shape" option change from "Quick Settings". + * + * @return {void} + */ + }, { + key: "initSliderPositionOnFieldShapeChange", + value: function initSliderPositionOnFieldShapeChange() { + var _this8 = this; + var fieldShapeType = document.querySelector('.frm-style-component.frm-field-shape'); + if (!fieldShapeType) { + return; + } + var radioButtons = fieldShapeType.querySelectorAll('input[type="radio"]'); + radioButtons.forEach(function (radio) { + radio.addEventListener('change', function (event) { + if (event.target.checked && 'rounded-corner' === event.target.value) { + var slider = document.querySelector('div[data-frm-element="field-shape-corner-radius"] .frm-slider-component'); + _this8.initSliderWidth(slider); + } + }); + }); + } + + /** + * Initializes the width of sliders within a given section. + * + * @param {HTMLElement} section - The section containing the sliders. + * @return {void} + */ + }, { + key: "initSlidersWidth", + value: function initSlidersWidth(section) { + var _this9 = this; + var sliders = section.querySelectorAll('.frm-slider-component'); + sliders.forEach(function (slider) { + setTimeout(function () { + _this9.initSliderWidth(slider); + }, 100); + }); + } + + /** + * Initializes the width of a slider. + * + * @param {HTMLElement} slider - The slider element. + * @param {number} sliderIndex - The index of the slider. + * @return {void} + */ + }, { + key: "initSliderWidth", + value: function initSliderWidth(slider) { + var sliderIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + if (slider.classList.contains('frm-disabled')) { + return; + } + var index = sliderIndex !== null ? sliderIndex : this.getSliderIndex(slider); + var sliderWidth = slider.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; + var value = parseInt(slider.querySelector('.frm-slider-value input[type="text"]').value, 10); + var unit = slider.querySelector('select').value; + var steps = this.options[index].steps; + var deltaX = Math.ceil(value / this.options[index].maxValue * sliderWidth); + if ('%' === unit) { + deltaX = Math.round(sliderWidth * value / 100); + } else if (steps && steps.length > 0) { + deltaX = frmSliderComponent.calculateDeltaXFromSteps(value, steps, sliderWidth); + } + slider.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); + this.options[index].translateX = deltaX; + this.options[index].value = value + unit; + } + + /** + * Calculates the deltaX position based on a value and steps array. + * + * @param {number} value - The current value. + * @param {Array} steps - Array of step values. + * @param {number} sliderWidth - The width of the slider. + * @return {number} - The calculated deltaX position. + */ + }, { + key: "initChildSlidersWidth", + value: + /** + * Initializes the width of child sliders. + * + * @param {HTMLElement} slider - The parent slider element. + * @param {number} width - The width to set for the child sliders. + * @param {number} index - The starting index for the child sliders. + * @param {number} value - The value to set for the child sliders. + */ + function initChildSlidersWidth(slider, width, index, value) { + var _this0 = this; + if (!slider.classList.contains('frm-has-independent-fields') && !slider.classList.contains('frm-has-multiple-values')) { + return; + } + var childSliders = slider.classList.contains('frm-has-independent-fields') ? slider.querySelectorAll('.frm-independent-slider-field') : this.getSliderGroupItems(slider); + childSliders.forEach(function (item, childIndex) { + item.querySelector('.frm-slider-active-track').style.width = "".concat(width, "px"); + _this0.options[index + childIndex + 1].translateX = width; + _this0.options[index + childIndex + 1].value = value; + }); + } + + /** + * Returns the index of the specified slider element. + * + * @param {HTMLElement} slider - The slider element. + * @return {number} The index of the slider element. + */ + }, { + key: "getSliderIndex", + value: function getSliderIndex(slider) { + return this.options.filter(function (option) { + return option.element === slider; + })[0].index; + } + + /** + * Handles the movement of the slider tracker. + * + * @param {Event} event - The event object representing the mouse movement. + * @param {number} index - The index of the slider element. + * @return {void} + */ + }, { + key: "moveTracker", + value: function moveTracker(event, index) { + if (!this.options[index].dragging) { + return; + } + var deltaX = event.clientX - this.options[index].startX; + var element = this.sliderElements[index]; + var sliderWidth = element.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; + + // Clamp deltaX within valid range + deltaX = Math.max(deltaX, 0); + deltaX = Math.min(deltaX, sliderWidth); + var unit = element.querySelector('select').value; + var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, this.getMaxValue(unit, index), this.options[index].steps); + element.querySelector('.frm-slider-value input[type="text"]').value = value; + element.querySelector('.frm-slider-bullet .frm-slider-value-label').innerText = value; + element.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); + this.initChildSlidersWidth(element, deltaX, index, value + unit); + this.options[index].translateX = deltaX; + this.options[index].value = value + unit; + this.options[index].fullValue = this.updateValue(element, this.options[index].value); + this.valueChangeDebouncer(index); + } + + /** + * Get the maximum value based on the unit and index. + * + * @param {string} unit - The unit of measurement. + * @param {number} index - The index of the option. + * @return {number} The maximum value. + */ + }, { + key: "getMaxValue", + value: function getMaxValue(unit, index) { + return '%' === unit ? 100 : this.options[index].maxValue; + } + + /** + * Enables dragging for the slider component. + * + * @param {Event} event - The event object. + * @param {number} index - The index of the option being dragged. + */ + }, { + key: "enableDragging", + value: function enableDragging(event, index) { + event.target.classList.add('frm-dragging'); + this.options[index].dragging = true; + this.options[index].startX = event.clientX - this.options[index].translateX; + } + + /** + * Disables dragging for a specific index. + * + * @param {number} index - The index of the option to disable dragging for. + */ + }, { + key: "disableDragging", + value: function disableDragging(index) { + if (false === this.options[index].dragging) { + return; + } + var draggableBullet = this.sliderElements[index].querySelector('.frm-slider-bullet'); + draggableBullet.classList.remove('frm-dragging'); + this.options[index].dragging = false; + this.triggerValueChange(index); + } + + /** + * Triggers a value change for the specified index. + * + * @param {number} index - The index of the value to be changed. + */ + }, { + key: "triggerValueChange", + value: function triggerValueChange(index) { + var _this1 = this; + if (null !== this.options[index].dependentUpdater) { + this.options[index].dependentUpdater.updateAllDependentElements(this.options[index].fullValue); + return; + } + var input = this.sliderElements[index].classList.contains('frm-has-multiple-values') ? this.sliderElements[index].closest('.frm-style-component').querySelector('input[type="hidden"]') : this.sliderElements[index].querySelectorAll('.frm-slider-value input[type="hidden"]'); + if (input instanceof NodeList) { + input.forEach(function (item) { + item.dispatchEvent(_this1.eventsChange[index]); + }); + return; + } + input.dispatchEvent(this.eventsChange[index]); + } + + /** + * Calculates the value based on the width, deltaX, and maxValue. + * + * @param {number} width - The width of the slider. + * @param {number} deltaX - The change in x-coordinate. + * @param {number} maxValue - The maximum value. + * @param {Array|null} steps - Optional array of step values to snap to. + * @return {number} - The calculated value. + */ + }, { + key: "updateValue", + value: + /** + * Updates the value of a slider component. + * + * @param {HTMLElement} element - The slider component element. + * @param {string} value - The new value to be set. + * @return {string} - The updated value. + */ + function updateValue(element, value) { + var _this10 = this; + // When the slider component is used for "Base Font Size", we need to update a hidden input field when change happens to indicate that the "Base Font Size" has been adjusted. + // Used to avoid conflicts with other possible font sizes adjustemnts in "Advanced Settings" when moving from "Quick Settings" when "Base Font Size" is not changed. + if (element.classList.contains('frm-base-font-size')) { + var userBaseFontSizeInput = document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]'); + if (userBaseFontSizeInput) { + userBaseFontSizeInput.value = 'true'; + } + } + if (element.classList.contains('frm-has-multiple-values')) { + var input = element.closest('.frm-style-component').querySelector('input[type="hidden"]'); + var inputValue = input.value.split(' '); + var type = element.dataset.type; + if (!inputValue[2]) { + inputValue[2] = '0px'; + } + if (!inputValue[3]) { + inputValue[3] = '0px'; + } + switch (type) { + case 'vertical': + inputValue[0] = value; + inputValue[2] = value; + break; + case 'horizontal': + inputValue[1] = value; + inputValue[3] = value; + break; + case 'top': + inputValue[0] = value; + break; + case 'bottom': + inputValue[2] = value; + break; + case 'left': + inputValue[3] = value; + break; + case 'right': + inputValue[1] = value; + break; + } + var newValue = inputValue.join(' '); + input.value = newValue; + var childSlidersGroup = this.getSliderGroupItems(element); + childSlidersGroup.forEach(function (slider) { + var unitMeasure = _this10.getUnitMeasureFromValue(value); + slider.querySelector('.frm-slider-value input[type="text"]').value = parseInt(value, 10); + slider.querySelector('select').value = unitMeasure; + }); + return newValue; + } + if (element.classList.contains('frm-has-independent-fields')) { + var inputValues = element.querySelectorAll('.frm-slider-value input[type="hidden"]'); + var visibleValues = element.querySelectorAll('.frm-slider-value input[type="text"]'); + inputValues.forEach(function (input, index) { + input.value = value; + visibleValues[index + 1].value = parseInt(value, 10); + }); + return value; + } + element.querySelector('.frm-slider-value input[type="hidden"]').value = value; + return value; + } + + /** + * Returns the unit of measurement used in the given value. + * + * @param {string} value - The value to check for the unit of measurement. + * @return {string} The unit of measurement ('%', 'px', 'em') found in the value, or an empty string if none is found. + */ + }, { + key: "getUnitMeasureFromValue", + value: function getUnitMeasureFromValue(value) { + return ['%', 'px', 'em'].find(function (unit) { + return value.includes(unit); + }) || ''; + } + }], [{ + key: "maybeDisableUnitDropdown", + value: function maybeDisableUnitDropdown(element) { + var select = element.querySelector('select'); + if (!select) { + return; + } + var options = Array.from(select.options).filter(function (option) { + return '' !== option.value; + }); + if (1 >= options.length) { + select.classList.add('frm-single-unit'); + select.addEventListener('mousedown', function (event) { + return event.preventDefault(); + }); + } + } + }, { + key: "calculateDeltaXFromSteps", + value: function calculateDeltaXFromSteps(value, steps, sliderWidth) { + var stepIndex = steps.indexOf(value); + if (-1 === stepIndex) { + // If value not in steps, find closest and use its position + var closestValue = frmSliderComponent.snapToStep(value, steps); + var closestIndex = steps.indexOf(closestValue); + return Math.round(closestIndex / (steps.length - 1) * sliderWidth); + } + return Math.round(stepIndex / (steps.length - 1) * sliderWidth); + } + }, { + key: "calculateValue", + value: function calculateValue(width, deltaX, maxValue) { + var steps = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; + if (steps && steps.length > 0) { + // For stepped sliders, map position directly to step index + var position = deltaX / width; + var stepIndex = Math.round(position * (steps.length - 1)); + var clampedIndex = Math.max(0, Math.min(stepIndex, steps.length - 1)); + return steps[clampedIndex]; + } + + // Calculate value as a simple proportion of the slider position + var value = Math.round(deltaX / width * maxValue); + return Math.min(value, maxValue); + } + + /** + * Snaps a value to the nearest step in the steps array. + * + * @param {number} value - The value to snap. + * @param {Array} steps - Array of step values to snap to. + * @return {number} - The nearest step value. + */ + }, { + key: "snapToStep", + value: function snapToStep(value, steps) { + var nearest = steps[0]; + var minDiff = Math.abs(value - nearest); + for (var i = 1; i < steps.length; i++) { + var diff = Math.abs(value - steps[i]); + if (diff < minDiff) { + minDiff = diff; + nearest = steps[i]; + } + } + return nearest; + } + }]); +}(); + + +/***/ }), + +/***/ "./js/src/settings-components/components/tabs-component.js": +/*!*****************************************************************!*\ + !*** ./js/src/settings-components/components/tabs-component.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmTabsComponent) +/* harmony export */ }); +/* harmony import */ var _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../components/class-tabs-navigator */ "./js/src/components/class-tabs-navigator.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } + +/** + * Represents a Tabs Component. + * + * @class + */ +var frmTabsComponent = /*#__PURE__*/function () { + function frmTabsComponent() { + _classCallCheck(this, frmTabsComponent); + this.elements = document.querySelectorAll('.frm-style-tabs-wrapper'); + if (0 < this.elements.length) { + this.init(); + } + } + + /** + * Initializes the Tabs Component. + */ + return _createClass(frmTabsComponent, [{ + key: "init", + value: function init() { + this.elements.forEach(function (element) { + new _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__.frmTabsNavigator(element); + }); + } + + /** + * Initializes the component on tab click. + * + * @param {Element} wrapper - The wrapper element. + */ + }, { + key: "initOnTabClick", + value: function initOnTabClick(wrapper) { + var _this = this; + this.initActiveBackgroundWidth(wrapper); + wrapper.querySelectorAll('.frm-tab-item').forEach(function (tab) { + tab.addEventListener('click', function (event) { + _this.onTabClick(event.target.closest('.frm-tabs-wrapper')); + }); + }); + } + }]); +}(); + + +/***/ }), + +/***/ "./js/src/settings-components/components/toggle-group/index.js": +/*!*********************************************************************!*\ + !*** ./js/src/settings-components/components/toggle-group/index.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ initToggleGroupComponents: () => (/* reexport safe */ _toggle_group_js__WEBPACK_IMPORTED_MODULE_0__.initToggleGroupComponents) +/* harmony export */ }); +/* harmony import */ var _toggle_group_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toggle-group.js */ "./js/src/settings-components/components/toggle-group/toggle-group.js"); + + +/***/ }), + +/***/ "./js/src/settings-components/components/toggle-group/toggle-group.js": +/*!****************************************************************************!*\ + !*** ./js/src/settings-components/components/toggle-group/toggle-group.js ***! + \****************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ initToggleGroupComponents: () => (/* binding */ initToggleGroupComponents) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Group Toggle Component + * + * Handles toggling visibility and enabled state of related form elements + */ + +/** + * Internal dependencies + */ + + + +/** + * Class names for group toggle component + * + * @private + */ +var CLASS_NAMES = { + GROUP_TOGGLE: 'frm-toggle-group', + TOGGLE_BLOCK: 'frm_toggle_block' +}; + +/** + * Data attributes for group toggle component + * + * @private + */ +var DATA_ATTRIBUTES = { + GROUP_NAME: 'data-group-name', + SHOW: 'data-show', + DISABLE: 'data-disable', + ENABLE: 'data-enable' +}; + +/** + * Initialize all group toggle components on the page + * + * @return {void} + */ +function initToggleGroupComponents() { + applyInitialState(); + addEventListeners(); +} + +/** + * Apply the initial state for all toggle buttons on the page + * + * @private + * @return {void} + */ +function applyInitialState() { + var toggleGroups = document.querySelectorAll(".".concat(CLASS_NAMES.GROUP_TOGGLE)); + if (!toggleGroups.length) { + return; + } + toggleGroups.forEach(function (toggleGroup) { + var toggleButton = toggleGroup.querySelector("[".concat(DATA_ATTRIBUTES.GROUP_NAME, "]:checked")); + if (!toggleButton) { + return; + } + applyToggleState(toggleButton, toggleGroup); + }); +} + +/** + * Add event listeners to toggle buttons in a group toggle component + * + * @private + * @return {void} + */ +function addEventListeners() { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.documentOn)('change', ".".concat(CLASS_NAMES.GROUP_TOGGLE, " [").concat(DATA_ATTRIBUTES.GROUP_NAME, "]"), handleToggleClick); +} + +/** + * Handle click events on toggle buttons + * + * @private + * @param {Event} event The click event + * @return {void} + */ +function handleToggleClick(event) { + var toggleButton = event.target; + var toggleGroup = toggleButton.closest(".".concat(CLASS_NAMES.GROUP_TOGGLE)); + if (!toggleGroup) { + return; + } + applyToggleState(toggleButton, toggleGroup); +} + +/** + * Apply toggle state based on toggle button settings + * Shared functionality used by both click handler and initial state + * + * @private + * @param {HTMLElement} toggleButton The toggle button element + * @param {HTMLElement} toggleGroup The toggle group container element + * @return {void} + */ +function applyToggleState(toggleButton, toggleGroup) { + var _toggleGroup$closest; + var fieldId = ((_toggleGroup$closest = toggleGroup.closest(".".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.SINGLE_SETTINGS_CLASS))) === null || _toggleGroup$closest === void 0 ? void 0 : _toggleGroup$closest.dataset.fid) || toggleGroup.dataset.fid; + var isChecked = toggleButton.checked; + + // Handle show/hide elements + var showSelectors = toggleButton.getAttribute(DATA_ATTRIBUTES.SHOW); + if (showSelectors) { + document.querySelectorAll(normalizeSelector(showSelectors, fieldId)).forEach(function (element) { + return element.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS, !isChecked); + }); + } + + // Handle disable elements + var disableSelectors = toggleButton.getAttribute(DATA_ATTRIBUTES.DISABLE); + if (disableSelectors) { + document.querySelectorAll(normalizeSelector(disableSelectors, fieldId)).forEach(function (element) { + element.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.DISABLED_CLASS, isChecked); + element.querySelectorAll('input, select, textarea').forEach(function (formElement) { + return formElement.disabled = isChecked; + }); + element.querySelectorAll('.frm-show-inline-modal[tabindex]').forEach(function (inlineModal) { + return inlineModal.tabIndex = isChecked ? -1 : 0; + }); + }); + } + + // Handle enable elements + var enableSelectors = toggleButton.getAttribute(DATA_ATTRIBUTES.ENABLE); + if (enableSelectors) { + document.querySelectorAll(normalizeSelector(enableSelectors, fieldId)).forEach(function (element) { + return element.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.DISABLED_CLASS, !isChecked); + }); + } + + // Toggle disabled state for all other toggle blocks within the group + var currentToggleBlock = toggleButton.closest(".".concat(CLASS_NAMES.TOGGLE_BLOCK)); + Array.from(toggleGroup.querySelectorAll(".".concat(CLASS_NAMES.TOGGLE_BLOCK))).filter(function (toggleBlock) { + return toggleBlock !== currentToggleBlock; + }).forEach(function (toggleBlock) { + toggleBlock.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.DISABLED_CLASS, isChecked); + + // Disable toggle switch + var toggle = toggleBlock.querySelector('.frm_toggle'); + toggle.tabIndex = isChecked ? -1 : 0; + toggle.setAttribute('aria-disabled', isChecked); + }); +} + +/** + * Normalize a selector by replacing {id} placeholders with the actual field ID + * + * @private + * @param {string} selector The selector string with potential {id} placeholders + * @param {string} fieldId The field ID to replace placeholders with + * @return {string} The normalized selector + */ +function normalizeSelector(selector, fieldId) { + return selector.replace(/{id}/g, fieldId); +} + + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/constants.js": +/*!************************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/constants.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CLASS_NAMES: () => (/* binding */ CLASS_NAMES), +/* harmony export */ KEYS: () => (/* binding */ KEYS), +/* harmony export */ PROXY_INPUT_HEIGHT: () => (/* binding */ PROXY_INPUT_HEIGHT), +/* harmony export */ TOKEN_GAP: () => (/* binding */ TOKEN_GAP) +/* harmony export */ }); +/** + * Constants for token input component + * + * Reusable constants for class names and other static values + */ + +var CLASS_NAMES = { + CONTAINER: 'frm-token-container', + TOKENS_WRAPPER: 'frm-tokens', + TOKEN: 'frm-token', + TOKEN_VALUE: 'frm-token-value', + TOKEN_REMOVE: 'frm-token-remove', + TOKEN_INPUT_FIELD: 'frm-token-input-field', + TOKEN_PROXY_INPUT: 'frm-token-proxy-input', + WITH_RIGHT_ICON: 'frm-with-right-icon' +}; +var KEYS = { + SPACE: ' ', + ENTER: 'Enter', + COMMA: ',', + TAB: 'Tab', + BACKSPACE: 'Backspace' +}; +var PROXY_INPUT_HEIGHT = 36; +var TOKEN_GAP = 4; + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/event-handlers.js": +/*!*****************************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/event-handlers.js ***! + \*****************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); +/* harmony import */ var _token_actions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./token-actions */ "./js/src/settings-components/components/token-input/token-actions.js"); +/* harmony import */ var _proxy_input_style__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./proxy-input-style */ "./js/src/settings-components/components/token-input/proxy-input-style.js"); +/** + * Event handlers + * + * Functions for handling token input events + */ + +/** + * Internal dependencies + */ + + + + +/** + * Add event listeners to token input components + * + * @param {HTMLElement} field The original hidden input field + * @param {HTMLElement} proxyInput The proxy input field for interaction + * @param {HTMLElement} tokensWrapper The wrapper for token display + * @return {void} + */ +function addEventListeners(field, proxyInput, tokensWrapper) { + // The jQuery change event is required to catch programmatic updates, as "Add Layout Classes" modifies the field value via jQuery + jQuery(field).on('change', function () { + return (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.synchronizeTokensDisplay)(field.value, proxyInput, tokensWrapper); + }); + proxyInput.addEventListener('keydown', function (event) { + return onProxyInputKeydown(event, field, proxyInput, tokensWrapper); + }); + proxyInput.addEventListener('blur', function () { + return (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.addToken)(proxyInput.value.trim(), field, proxyInput); + }); + tokensWrapper.addEventListener('click', function (event) { + return handleTokenRemoval(event, field, proxyInput); + }); +} + +/** + * Handle keydown events on the proxy input field + * + * @private + * + * @param {Event} event Keydown event + * @param {HTMLElement} field The original hidden input field + * @param {HTMLElement} proxyInput The proxy input field for interaction + * @param {HTMLElement} tokensWrapper The wrapper for token display + * @return {void} + */ +function onProxyInputKeydown(event, field, proxyInput, tokensWrapper) { + var key = event.key; + var value = proxyInput.value.trim(); + switch (key) { + // Remove the last token when backspace is pressed and input field is empty (no text being typed) + case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.BACKSPACE: + if (!value) { + event.preventDefault(); + var lastToken = tokensWrapper.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN, ":last-child")); + (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.removeToken)(lastToken, field, proxyInput); + } + break; + + // Create a token from current input when delimiter keys are pressed + case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.SPACE: + case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.COMMA: + case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.ENTER: + event.preventDefault(); + (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.addToken)(value, field, proxyInput); + break; + } + (0,_proxy_input_style__WEBPACK_IMPORTED_MODULE_2__.adjustProxyInputStyle)(proxyInput, tokensWrapper); +} + +/** + * Handle token removal when clicking the remove button + * + * @private + * + * @param {Event} event Click event + * @param {HTMLElement} field The original hidden input field + * @param {HTMLElement} proxyInput The proxy input field for interaction + * @return {void} + */ +function handleTokenRemoval(event, field, proxyInput) { + var removeButton = event.target.closest(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN_REMOVE)); + if (!removeButton) { + return; + } + var token = removeButton.closest(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN)); + if (!token) { + return; + } + var tokensWrapper = token.parentElement; + (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.removeToken)(token, field, proxyInput); + (0,_proxy_input_style__WEBPACK_IMPORTED_MODULE_2__.adjustProxyInputStyle)(proxyInput, tokensWrapper); +} + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/index.js": +/*!********************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/index.js ***! + \********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ initTokenInputFields: () => (/* reexport safe */ _token_input__WEBPACK_IMPORTED_MODULE_0__.initTokenInputFields) +/* harmony export */ }); +/* harmony import */ var _token_input__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./token-input */ "./js/src/settings-components/components/token-input/token-input.js"); + + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/proxy-input-style.js": +/*!********************************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/proxy-input-style.js ***! + \********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ adjustAllProxyInputStyles: () => (/* binding */ adjustAllProxyInputStyles), +/* harmony export */ adjustProxyInputStyle: () => (/* binding */ adjustProxyInputStyle) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); +/** + * Proxy input style + * + * Functions for adjusting proxy input styling + */ + + + +/** + * Adjust styling for all proxy inputs on the current settings + * + * @return {void} + */ +function adjustAllProxyInputStyles() { + document.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.CONTAINER)).forEach(function (container) { + return adjustProxyInputStyle(container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN_PROXY_INPUT)), container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKENS_WRAPPER))); + }); +} + +/** + * Adjust the styling of the proxy input based on tokens wrapper dimensions + * + * @param {HTMLElement} proxyInput The proxy input field + * @param {HTMLElement} tokensWrapper The wrapper for token display + * @return {void} + */ +function adjustProxyInputStyle(proxyInput, tokensWrapper) { + if (!proxyInput || !tokensWrapper) { + return; + } + var tokens = tokensWrapper.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN)); + var hasTokens = tokens.length > 0; + + // Reset all styles if no tokens + if (!hasTokens) { + proxyInput.style.paddingLeft = ''; + proxyInput.style.paddingTop = ''; + proxyInput.style.height = ''; + return; + } + var tokensWrapperHeight = tokensWrapper.offsetHeight; + + // Calculate number of rows based on wrapper height + var numRows = Math.max(1, Math.ceil(tokensWrapperHeight / _constants__WEBPACK_IMPORTED_MODULE_0__.PROXY_INPUT_HEIGHT)); + if (numRows > 1) { + // For multiple rows, calculate the width of tokens in the last row + var lastRowWidth = calculateLastRowWidth(getLastRowTokens(tokens)); + proxyInput.style.height = "".concat(tokensWrapperHeight, "px"); + proxyInput.style.paddingTop = "".concat(tokensWrapperHeight - _constants__WEBPACK_IMPORTED_MODULE_0__.PROXY_INPUT_HEIGHT + _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP, "px"); + proxyInput.style.paddingLeft = lastRowWidth ? "".concat(lastRowWidth + _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP * 2, "px") : ''; + } else { + // For single row, use the full width of tokens + proxyInput.style.height = ''; + proxyInput.style.paddingTop = ''; + proxyInput.style.paddingLeft = "".concat(tokensWrapper.offsetWidth - _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP, "px"); + } +} + +/** + * Identify tokens in the last row of a multi-row token layout + * + * @param {NodeList} tokens All token elements + * @return {Array} Array of tokens in the last row + */ +function getLastRowTokens(tokens) { + if (!tokens.length) { + return []; + } + var tokensArray = Array.from(tokens); + var lastRowY = -1; + tokensArray.forEach(function (token) { + var tokenRect = token.getBoundingClientRect(); + var tokenBottom = tokenRect.bottom; + if (tokenBottom > lastRowY) { + lastRowY = tokenBottom; + } + }); + var threshold = _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP / 2; + return tokensArray.filter(function (token) { + var tokenRect = token.getBoundingClientRect(); + return Math.abs(tokenRect.bottom - lastRowY) <= threshold; + }); +} + +/** + * Calculate the total width of tokens in the last row + * + * @param {Array} lastRowTokens Array of token elements in the last row + * @return {number} Total width of tokens in the last row + */ +function calculateLastRowWidth(lastRowTokens) { + if (!lastRowTokens.length) { + return 0; + } + var totalWidth = 0; + lastRowTokens.forEach(function (token) { + totalWidth += token.offsetWidth; + }); + totalWidth += (lastRowTokens.length - 1) * _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP; + return totalWidth + _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP; +} + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/token-actions.js": +/*!****************************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/token-actions.js ***! + \****************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToken: () => (/* binding */ addToken), +/* harmony export */ clearProxyInput: () => (/* binding */ clearProxyInput), +/* harmony export */ parseTokens: () => (/* binding */ parseTokens), +/* harmony export */ removeToken: () => (/* binding */ removeToken), +/* harmony export */ synchronizeTokensDisplay: () => (/* binding */ synchronizeTokensDisplay), +/* harmony export */ updateFieldValue: () => (/* binding */ updateFieldValue) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); +/* harmony import */ var _proxy_input_style__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./proxy-input-style */ "./js/src/settings-components/components/token-input/proxy-input-style.js"); +/* harmony import */ var _token_elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./token-elements */ "./js/src/settings-components/components/token-input/token-elements.js"); +/** + * Token actions + * + * Core functions for token operations and management + */ + +/** + * Internal dependencies + */ + + + + +/** + * Synchronize token display with the field value + * + * @param {string} value The field value + * @param {HTMLElement} proxyInput The proxy input field + * @param {HTMLElement} tokensWrapper Wrapper element for tokens + * @return {void} + */ +function synchronizeTokensDisplay(value, proxyInput, tokensWrapper) { + if (!value || !tokensWrapper || !proxyInput) { + return; + } + + // Clear existing tokens display and render new tokens + tokensWrapper.innerHTML = ''; + parseTokens(value).forEach(function (token) { + return (0,_token_elements__WEBPACK_IMPORTED_MODULE_2__.createTokenElement)(token, tokensWrapper); + }); + (0,_proxy_input_style__WEBPACK_IMPORTED_MODULE_1__.adjustProxyInputStyle)(proxyInput, tokensWrapper); + proxyInput.focus(); +} + +/** + * Add a new token to the field + * + * @param {string} tokenValue The token value to add + * @param {HTMLElement} field The original field + * @param {HTMLElement} proxyInput The proxy input + * @return {boolean} Whether a token was added + */ +function addToken(tokenValue, field, proxyInput) { + if (!tokenValue || !field || !proxyInput) { + return false; + } + + // Get current tokens from field value + var tokens = parseTokens(field.value); + + // Skip duplicate tokens + if (tokens.includes(tokenValue)) { + clearProxyInput(proxyInput); + return false; + } + + // Add new token + tokens.push(tokenValue); + updateFieldValue(field, tokens); + clearProxyInput(proxyInput); + return true; +} + +/** + * Remove a specific token from the field + * + * @param {HTMLElement} token The token element to remove + * @param {HTMLElement} field The original field + * @param {HTMLElement} proxyInput The proxy input + * @return {void} + */ +function removeToken(token, field, proxyInput) { + if (!token || !field || !proxyInput) { + return; + } + var value = token.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN_VALUE)).textContent; + + // Filter out the token to remove + var tokens = parseTokens(field.value).filter(function (tokenValue) { + return tokenValue !== value; + }); + updateFieldValue(field, tokens); + + // Remove the token element from DOM + token.remove(); + proxyInput.focus(); +} + +/** + * Parse string input into an array of tokens + * + * @param {string} value Space-separated string + * @return {string[]} Array of tokens + */ +function parseTokens() { + var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + value = value.trim(); + if (!value) { + return []; + } + return value.split(/\s+/).filter(Boolean); +} + +/** + * Update field value with tokens and trigger change event + * + * @param {HTMLElement} field The field to update + * @param {string[]} tokens Array of token values + * @return {void} + */ +function updateFieldValue(field) { + var tokens = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; + if (!field) { + return; + } + field.value = tokens.join(' '); + jQuery(field).trigger('change'); +} + +/** + * Clear proxy input and maintain focus + * + * @param {HTMLElement} proxyInput The proxy input field + * @return {void} + */ +function clearProxyInput(proxyInput) { + if (!proxyInput) { + return; + } + proxyInput.value = ''; + proxyInput.focus(); +} + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/token-elements.js": +/*!*****************************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/token-elements.js ***! + \*****************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createTokenContainerElement: () => (/* binding */ createTokenContainerElement), +/* harmony export */ createTokenElement: () => (/* binding */ createTokenElement) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); +/** + * Token elements + * + * Functions for creating token DOM elements + */ + +/** + * Internal dependencies + */ + + +var _window$frmDom = window.frmDom, + span = _window$frmDom.span, + svg = _window$frmDom.svg, + tag = _window$frmDom.tag; + +/** + * Create token container and input elements + * + * @param {HTMLElement} field Input field for tokenization + * @return {HTMLElement|null} The container element or null if already initialized + */ +function createTokenContainerElement(field) { + // Get the main container (.frm-with-right-icon) to work with Formidable's modal system + var container = field.closest(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.WITH_RIGHT_ICON)); + if (container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKENS_WRAPPER))) { + return null; + } + container.classList.add(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.CONTAINER); + var tokensWrapper = span({ + className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKENS_WRAPPER + }); + container.insertBefore(tokensWrapper, container.firstChild); + var proxyInput = tag('input', { + className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_PROXY_INPUT, + id: "".concat(field.id, "-proxy-input") + }); + proxyInput.type = 'text'; + + // Inserting proxyInput after the field is important to maintain compatibility with Formidable's modal system + field.parentNode.insertBefore(proxyInput, field.nextSibling); + field.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); + return container; +} + +/** + * Create a single token element + * + * @param {string} value Token value + * @param {HTMLElement} tokensWrapper Wrapper element for tokens + * @return {void} + */ +function createTokenElement(value, tokensWrapper) { + var tokenElement = span({ + className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN, + children: [span({ + text: value, + className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_VALUE + }), span({ + className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_REMOVE, + child: svg({ + href: '#frm_close_icon' + }) + })] + }); + tokensWrapper.append(tokenElement); +} + +/***/ }), + +/***/ "./js/src/settings-components/components/token-input/token-input.js": +/*!**************************************************************************!*\ + !*** ./js/src/settings-components/components/token-input/token-input.js ***! + \**************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ initTokenInputFields: () => (/* binding */ initTokenInputFields) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); +/* harmony import */ var _token_elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./token-elements */ "./js/src/settings-components/components/token-input/token-elements.js"); +/* harmony import */ var _token_actions__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./token-actions */ "./js/src/settings-components/components/token-input/token-actions.js"); +/* harmony import */ var _proxy_input_style__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./proxy-input-style */ "./js/src/settings-components/components/token-input/proxy-input-style.js"); +/* harmony import */ var _event_handlers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./event-handlers */ "./js/src/settings-components/components/token-input/event-handlers.js"); +/** + * Token Input Component + * + * Transforms space-separated values in a text input into selectable tokens + */ + +/** + * Internal dependencies + */ + + + + + + + +/** + * Initialize all token input fields on the page + * + * @return {void} + */ +function initTokenInputFields() { + findAndInitializeTokenFields(); + + /** + * Initialize for newly added fields + * + * @param {Event} event The frm_added_field event. + * @param {HTMLElement} event.frmField The added field object being destructured from the event. + */ + document.addEventListener('frm_added_field', function (_ref) { + var frmField = _ref.frmField; + return findAndInitializeTokenFields(frmField.dataset.fid); + }); + + /** + * Initialize for newly added fields via AJAX + * + * @param {Event} event The frm_ajax_loaded_field event. + * @param {HTMLElement} event.frmFields The added field objects being destructured from the event. + */ + document.addEventListener('frm_ajax_loaded_field', function (_ref2) { + var frmFields = _ref2.frmFields; + return frmFields.forEach(function (field) { + return findAndInitializeTokenFields(field.id); + }); + }); + + // Adjust styling for all token inputs when field settings are shown + wp.hooks.addAction(core_constants__WEBPACK_IMPORTED_MODULE_0__.HOOKS.SHOW_FIELD_SETTINGS, 'formidable-token-input', _proxy_input_style__WEBPACK_IMPORTED_MODULE_4__.adjustAllProxyInputStyles); +} + +/** + * Find all token input fields and initialize them + * + * @private + * @param {string|number} fieldId The ID of the field to initialize + * @return {void} + */ +function findAndInitializeTokenFields(fieldId) { + var container = fieldId ? document.getElementById("frm-single-settings-".concat(fieldId)) : document.body; + var tokenInputFields = container.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_INPUT_FIELD)); + if (!tokenInputFields.length) { + return; + } + + // Track processed fields to prevent duplicate initialization + var processedFields = new Set(); + tokenInputFields.forEach(function (field) { + if (!processedFields.has(field.id)) { + setupTokenInput(field); + processedFields.add(field.id); + } + }); +} + +/** + * Set up a token input field with token container + * + * @private + * + * @param {HTMLElement} field Input field for tokenization + */ +function setupTokenInput(field) { + var container = (0,_token_elements__WEBPACK_IMPORTED_MODULE_2__.createTokenContainerElement)(field); + if (!container) { + return; + } + var proxyInput = container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_PROXY_INPUT)); + var tokensWrapper = container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKENS_WRAPPER)); + (0,_token_actions__WEBPACK_IMPORTED_MODULE_3__.synchronizeTokensDisplay)(field.value, proxyInput, tokensWrapper); + (0,_event_handlers__WEBPACK_IMPORTED_MODULE_5__.addEventListeners)(field, proxyInput, tokensWrapper); +} + + +/***/ }), + +/***/ "./js/src/settings-components/components/unit-input.js": +/*!*************************************************************!*\ + !*** ./js/src/settings-components/components/unit-input.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ setupUnitInputHandlers: () => (/* binding */ setupUnitInputHandlers) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Setup unit input handlers + * + * @return {void} + */ +function setupUnitInputHandlers() { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.documentOn)('change', '.frm-unit-input .frm-unit-input-control', onUnitInputChange); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.documentOn)('change', '.frm-unit-input select', onUnitInputChange); +} + +/** + * Handle the change event for the unit input + * + * @private + * @param {Event} event The event object. + * @return {void} + */ +function onUnitInputChange(event) { + var unitInput = event.target.closest('.frm-unit-input'); + var control = unitInput.querySelector('.frm-unit-input-control'); + var unit = unitInput.querySelector('select').value; + + // Update input type when unit changes + if (event.target.matches('select')) { + control.type = '' === unit ? 'text' : 'number'; + } + + // Update the actual field value + var inputValue = control.value.trim(); + unitInput.querySelector('input[type="hidden"]').value = '' !== inputValue ? inputValue + unit : ''; +} + +/***/ }), + +/***/ "./js/src/settings-components/events/add-fields-button-handler.js": +/*!************************************************************************!*\ + !*** ./js/src/settings-components/events/add-fields-button-handler.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Redirects to "Add Fields" tab when the "Add Fields" button is clicked. + * + * When users view the Field Options tab with no fields, they see an "Add Fields" button. + * Clicking this button should take them to the "Add Fields" tab for field selection. + */ + +/** + * Initializes the Add Fields button click handler. + */ +var initAddFieldsButtonHandler = function initAddFieldsButtonHandler() { + var _document$getElementB; + (_document$getElementB = document.getElementById('frm-form-add-field')) === null || _document$getElementB === void 0 || _document$getElementB.addEventListener('click', function (event) { + var _document$querySelect; + event.preventDefault(); + (_document$querySelect = document.querySelector('.frm-settings-panel .frm-tabs-navs ul > li:first-child')) === null || _document$querySelect === void 0 || _document$querySelect.click(); + }); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initAddFieldsButtonHandler); + +/***/ }), + +/***/ "./js/src/settings-components/events/index.js": +/*!****************************************************!*\ + !*** ./js/src/settings-components/events/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ initAddFieldsButtonHandler: () => (/* reexport safe */ _add_fields_button_handler__WEBPACK_IMPORTED_MODULE_0__["default"]) +/* harmony export */ }); +/* harmony import */ var _add_fields_button_handler__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./add-fields-button-handler */ "./js/src/settings-components/events/add-fields-button-handler.js"); + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. +(() => { +/*!*********************************************!*\ + !*** ./js/src/settings-components/index.js ***! + \*********************************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./events */ "./js/src/settings-components/events/index.js"); +/* harmony import */ var _components__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components */ "./js/src/settings-components/components/index.js"); +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + + +(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__["default"])(function () { + new _components__WEBPACK_IMPORTED_MODULE_1__.frmRadioComponent(); + new _components__WEBPACK_IMPORTED_MODULE_1__.frmSliderComponent(); + new _components__WEBPACK_IMPORTED_MODULE_1__.frmTabsComponent(); + (0,_events__WEBPACK_IMPORTED_MODULE_0__.initAddFieldsButtonHandler)(); + (0,_components__WEBPACK_IMPORTED_MODULE_1__.initTokenInputFields)(); + (0,_components__WEBPACK_IMPORTED_MODULE_1__.initToggleGroupComponents)(); + (0,_components__WEBPACK_IMPORTED_MODULE_1__.setupUnitInputHandlers)(); +}); +})(); + +/******/ })() +; +//# sourceMappingURL=formidable-settings-components.js.map \ No newline at end of file diff --git a/js/formidable-web-components.js b/js/formidable-web-components.js index 79d172f226..d0e7d5f6d7 100644 --- a/js/formidable-web-components.js +++ b/js/formidable-web-components.js @@ -1 +1,5835 @@ -(()=>{var e={8616:e=>{e.exports=function(e,t){var r,n,i=0;function o(){var o,a,s=r,l=arguments.length;e:for(;s;){if(s.args.length===arguments.length){for(a=0;a{var n;!function(){"use strict";var i={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function o(e){return function(e,t){var r,n,a,s,l,u,p,c,d,f=1,m=e.length,h="";for(n=0;n=0),s.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,s.width?parseInt(s.width):0);break;case"e":r=s.precision?parseFloat(r).toExponential(s.precision):parseFloat(r).toExponential();break;case"f":r=s.precision?parseFloat(r).toFixed(s.precision):parseFloat(r);break;case"g":r=s.precision?String(Number(r.toPrecision(s.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=s.precision?r.substring(0,s.precision):r;break;case"t":r=String(!!r),r=s.precision?r.substring(0,s.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=s.precision?r.substring(0,s.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=s.precision?r.substring(0,s.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}i.json.test(s.type)?h+=r:(!i.number.test(s.type)||c&&!s.sign?d="":(d=c?"+":"-",r=r.toString().replace(i.sign,"")),u=s.pad_char?"0"===s.pad_char?"0":s.pad_char.charAt(1):" ",p=s.width-(d+r).length,l=s.width&&p>0?u.repeat(p):"",h+=s.align?d+r+l:"0"===u?d+l+r:l+d+r)}return h}(function(e){if(s[e])return s[e];for(var t,r=e,n=[],o=0;r;){if(null!==(t=i.text.exec(r)))n.push(t[0]);else if(null!==(t=i.modulo.exec(r)))n.push("%");else{if(null===(t=i.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){o|=1;var a=[],l=t[2],u=[];if(null===(u=i.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(u[1]);""!==(l=l.substring(u[0].length));)if(null!==(u=i.key_access.exec(l)))a.push(u[1]);else{if(null===(u=i.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(u[1])}t[2]=a}else o|=2;if(3===o)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return s[e]=n}(e),arguments)}function a(e,t){return o.apply(null,[e].concat(t||[]))}var s=Object.create(null);"undefined"!=typeof window&&(window.sprintf=o,window.vsprintf=a,void 0===(n=function(){return{sprintf:o,vsprintf:a}}.call(t,r,t,e))||(e.exports=n))}()}},t={};function r(n){var i=t[n];if(void 0!==i)return i.exports;var o=t[n]={exports:{}};return e[n](o,o.exports,r),o.exports}r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(e,t){for(var r=0;r li"),this.slideTrackLine=this.wrapper.querySelector(".frm-tabs-active-underline"),this.slideTrack=this.wrapper.querySelector(".frm-tabs-slide-track"),this.slides=this.wrapper.querySelectorAll(".frm-tabs-slide-track > div"),this.isRTL="rtl"===document.documentElement.dir||"rtl"===document.body.dir,this.resizeObserver=null,this.init()))},(r=[{key:"init",value:function(){var e=this;null!==this.wrapper&&this.navs.length&&null!==this.slideTrackLine&&null!==this.slideTrack&&this.slides.length&&(this.navs.forEach(function(t,r){t.addEventListener("click",function(t){return e.onNavClick(t,r)}),t.classList.contains("frm-active")&&e.initSlideTrackUnderline(t)}),this.slideTrackLine.style.display="block",this.setupScrollbarObserver(),window.addEventListener("beforeunload",this.cleanupObservers))}},{key:"onNavClick",value:function(e,t){var r=e.currentTarget;e.preventDefault(),this.removeActiveClassnameFromNavs(),r.classList.add("frm-active"),this.initSlideTrackUnderline(r),this.changeSlide(t);var n,i,o=r.querySelector("a");o&&"frm_insert_fields_tab"===o.id&&!o.closest("#frm_adv_info")&&(null===(n=window.frmAdminBuild)||void 0===n||null===(i=n.clearSettingsBox)||void 0===i||i.call(n))}},{key:"initSlideTrackUnderline",value:function(e){var t=void 0!==e?e:this.navs.filter(function(e){return e.classList.contains("frm-active")});this.positionUnderlineIndicator(t)}},{key:"setupScrollbarObserver",value:function(){var e=this,t=document.querySelector(".frm-scrollbar-wrapper, .styling_settings")||document.body;t&&"ResizeObserver"in window&&(this.resizeObserver=new ResizeObserver(function(){var t=e.wrapper.querySelector(".frm-tabs-navs ul > li.frm-active");t&&e.positionUnderlineIndicator(t)}),this.resizeObserver.observe(t))}},{key:"cleanupObservers",value:function(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null)}},{key:"positionUnderlineIndicator",value:function(e){var t=this;requestAnimationFrame(function(){var r=t.isRTL?-(e.parentElement.offsetWidth-e.offsetLeft-e.offsetWidth):e.offsetLeft;t.slideTrackLine.style.transform="translateX(".concat(r,"px)"),t.slideTrackLine.style.width="".concat(e.clientWidth,"px")})}},{key:"changeSlide",value:function(e){this.removeActiveClassnameFromSlides();var t=0==e?"0px":"calc( ( ".concat(100*e,"% + ").concat(parseInt(this.flexboxSlidesGap,10)*e,"px ) * ").concat(this.isRTL?1:-1," )");"0px"!==t?this.slideTrack.style.transform="translateX(".concat(t,")"):this.slideTrack.style.removeProperty("transform"),e in this.slides&&this.slides[e].classList.add("frm-active")}},{key:"removeActiveClassnameFromSlides",value:function(){this.slides.forEach(function(e){return e.classList.remove("frm-active")})}},{key:"removeActiveClassnameFromNavs",value:function(){this.navs.forEach(function(e){return e.classList.remove("frm-active")})}}])&&t(e.prototype,r),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,r}();function o(e){return o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},o(e)}function a(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r0&&(r.disconnect(),requestAnimationFrame(function(){return t()}))})},{threshold:.1});(e.useShadowDom()?e.shadowRoot.host:e)&&r.observe(e)}else requestAnimationFrame(function(){return t()})})}},{key:"frmLabel",set:function(e){this._labelText=e}},{key:"afterViewInit",value:function(e){}},{key:"initView",value:function(){}},{key:"connectedCallback",value:function(){this.initOptions(),this.render()}},{key:"disconnectedCallback",value:function(){}}])&&s(r.prototype,n),Object.defineProperty(r,"prototype",{writable:!1}),r;var r,n}(u(HTMLElement));function m(e){return m="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},m(e)}function h(e,t){for(var r=0;rspan.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-colorpicker-component .wp-picker-container button[type=button]{position:relative;height:36px !important;background-image:none !important;background-color:#fff !important;overflow:hidden}.frm-colorpicker-component .wp-picker-container button[type=button]:after{content:"";width:20px;height:20px;display:block;position:absolute;top:0;right:8px;bottom:0;margin:auto;background:url("--frm-plugin-url/images/style/small-arrow.svg") no-repeat;background-position:center;z-index:10}.frm-colorpicker-component .wp-picker-container button[type=button]:focus{border-color:var(--primary-500) !important}.frm-colorpicker-component .wp-color-result-text{line-height:36px !important;padding:0 12px;border:0}.frm-colorpicker-component .color-alpha{width:20px !important;height:20px !important;border-radius:50% !important;border:1px solid #d0d5dd;top:0;left:0;bottom:0;margin:auto;margin-left:12px}.frm-colorpicker-component .wp-picker-input-wrap input{width:calc(100% - 10px) !important;margin:1px 5px;height:32px;line-height:32px}\n',e.attachInternals(),e}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),Object.defineProperty(e,"prototype",{writable:!1}),t&&O(e,t)}(t,e),r=t,(n=[{key:"initView",value:function(){var e=document.createElement("div");return e.classList.add("frm-colorpicker-component","frm-colorpicker"),e.append(this.getInput()),e}},{key:"getInput",value:function(){var e=this;return this.input.type="text",this.input.classList.add("hex"),null!==this.fieldName&&(this.input.name=this.fieldName),null!==V(z,this)&&(this.input.value=V(z,this)),null!==this.componentId&&(this.input.id=this.componentId),this.input.addEventListener("blur",function(t){return V(A,e).call(e,t,null)}),this.input}},{key:"useShadowDom",value:function(){return!1}},{key:"afterViewInit",value:function(){var e=this,t={defaultColor:V(z,this)};"function"==typeof V(A,this)&&(t.change=function(t,r){return setTimeout(function(){return V(A,e).call(e,t,r)},20)}),jQuery(this.input).wpColorPicker(t)}},{key:"color",get:function(){return jQuery(this.input).wpColorPicker("color")},set:function(e){_(z,this,e),this.input.value=e}},{key:"onChange",set:function(e){if("function"!=typeof e)throw new TypeError("Expected a function, but received ".concat(w(e)));_(A,this,e)}}])&&k(r.prototype,n),Object.defineProperty(r,"prototype",{writable:!1}),r;var r,n}(f);P=M,C=!0,(T=I(T="formAssociated"))in P?Object.defineProperty(P,T,{value:C,enumerable:!0,configurable:!0,writable:!0}):P[T]=C;var D=window.frmColorpickerProComponent?window.frmColorpickerProComponent(M):M,W=window.frmGlobal;function R(e){return R="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},R(e)}function B(e,t){for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:[],n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.loadedByWebComponent=r.length>0,this.sliderElements=r.length>0?r:document.querySelectorAll(".frm-slider-component"),this.settings=n,0!==this.sliderElements.length){this.sliderBulletWidth=16,this.sliderMarginRight=5,this.eventsChange=[];var i=frmDom.util.debounce;this.valueChangeDebouncer=i(function(e){return t.triggerValueChange(e)},25),this.initOptions(),this.init()}}return function(e,t,r){return t&&N(e.prototype,t),r&&N(e,r),Object.defineProperty(e,"prototype",{writable:!1}),e}(e,[{key:"initOptions",value:function(){var e=this;this.options=[],this.sliderElements.forEach(function(t,r){var n=t.classList.contains("frm-has-multiple-values")?t.closest(".frm-style-component"):t,i=e.settings.steps||(t.dataset.steps?JSON.parse(t.dataset.steps):null);e.options.push({dragging:!1,startX:0,translateX:0,maxValue:parseInt(t.dataset.maxValue,10),element:t,index:r,value:0,steps:i,dependentUpdater:n.classList.contains("frm-style-dependent-updater-component")?new q(n):null})})}},{key:"init",value:function(){this.initDraggable(),this.loadedByWebComponent?this.initSlidersPositionInsideWebComponent():this.initSlidersPosition()}},{key:"initDraggable",value:function(){var t=this;this.sliderElements.forEach(function(r,n){t.eventsChange[n]=new Event("change",{bubbles:!0,cancelable:!0});var i=r.querySelector(".frm-slider-bullet"),o=r.querySelector('.frm-slider-value input[type="text"]');o.addEventListener("change",function(e){var i=r.querySelector("select").value;t.getMaxValue(i,n)1&&void 0!==arguments[1]?arguments[1]:null;if(!t.classList.contains("frm-disabled")){var n=null!==r?r:this.getSliderIndex(t),i=t.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth,o=parseInt(t.querySelector('.frm-slider-value input[type="text"]').value,10),a=t.querySelector("select").value,s=this.options[n].steps,l=Math.ceil(o/this.options[n].maxValue*i);"%"===a?l=Math.round(i*o/100):s&&s.length>0&&(l=e.calculateDeltaXFromSteps(o,s,i)),t.querySelector(".frm-slider-active-track").style.width="".concat(l,"px"),this.options[n].translateX=l,this.options[n].value=o+a}}},{key:"initChildSlidersWidth",value:function(e,t,r,n){var i=this;(e.classList.contains("frm-has-independent-fields")||e.classList.contains("frm-has-multiple-values"))&&(e.classList.contains("frm-has-independent-fields")?e.querySelectorAll(".frm-independent-slider-field"):this.getSliderGroupItems(e)).forEach(function(e,o){e.querySelector(".frm-slider-active-track").style.width="".concat(t,"px"),i.options[r+o+1].translateX=t,i.options[r+o+1].value=n})}},{key:"getSliderIndex",value:function(e){return this.options.filter(function(t){return t.element===e})[0].index}},{key:"moveTracker",value:function(t,r){if(this.options[r].dragging){var n=t.clientX-this.options[r].startX,i=this.sliderElements[r],o=i.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth;n=Math.max(n,0),n=Math.min(n,o);var a=i.querySelector("select").value,s=e.calculateValue(o,n,this.getMaxValue(a,r),this.options[r].steps);i.querySelector('.frm-slider-value input[type="text"]').value=s,i.querySelector(".frm-slider-bullet .frm-slider-value-label").innerText=s,i.querySelector(".frm-slider-active-track").style.width="".concat(n,"px"),this.initChildSlidersWidth(i,n,r,s+a),this.options[r].translateX=n,this.options[r].value=s+a,this.options[r].fullValue=this.updateValue(i,this.options[r].value),this.valueChangeDebouncer(r)}}},{key:"getMaxValue",value:function(e,t){return"%"===e?100:this.options[t].maxValue}},{key:"enableDragging",value:function(e,t){e.target.classList.add("frm-dragging"),this.options[t].dragging=!0,this.options[t].startX=e.clientX-this.options[t].translateX}},{key:"disableDragging",value:function(e){!1!==this.options[e].dragging&&(this.sliderElements[e].querySelector(".frm-slider-bullet").classList.remove("frm-dragging"),this.options[e].dragging=!1,this.triggerValueChange(e))}},{key:"triggerValueChange",value:function(e){var t=this;if(null===this.options[e].dependentUpdater){var r=this.sliderElements[e].classList.contains("frm-has-multiple-values")?this.sliderElements[e].closest(".frm-style-component").querySelector('input[type="hidden"]'):this.sliderElements[e].querySelectorAll('.frm-slider-value input[type="hidden"]');r instanceof NodeList?r.forEach(function(r){r.dispatchEvent(t.eventsChange[e])}):r.dispatchEvent(this.eventsChange[e])}else this.options[e].dependentUpdater.updateAllDependentElements(this.options[e].fullValue)}},{key:"updateValue",value:function(e,t){var r=this;if(e.classList.contains("frm-base-font-size")){var n=document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]');n&&(n.value="true")}if(e.classList.contains("frm-has-multiple-values")){var i=e.closest(".frm-style-component").querySelector('input[type="hidden"]'),o=i.value.split(" "),a=e.dataset.type;switch(o[2]||(o[2]="0px"),o[3]||(o[3]="0px"),a){case"vertical":o[0]=t,o[2]=t;break;case"horizontal":o[1]=t,o[3]=t;break;case"top":o[0]=t;break;case"bottom":o[2]=t;break;case"left":o[3]=t;break;case"right":o[1]=t}var s=o.join(" ");return i.value=s,this.getSliderGroupItems(e).forEach(function(e){var n=r.getUnitMeasureFromValue(t);e.querySelector('.frm-slider-value input[type="text"]').value=parseInt(t,10),e.querySelector("select").value=n}),s}if(e.classList.contains("frm-has-independent-fields")){var l=e.querySelectorAll('.frm-slider-value input[type="hidden"]'),u=e.querySelectorAll('.frm-slider-value input[type="text"]');return l.forEach(function(e,r){e.value=t,u[r+1].value=parseInt(t,10)}),t}return e.querySelector('.frm-slider-value input[type="hidden"]').value=t,t}},{key:"getUnitMeasureFromValue",value:function(e){return["%","px","em"].find(function(t){return e.includes(t)})||""}}],[{key:"maybeDisableUnitDropdown",value:function(e){var t=e.querySelector("select");t&&1>=Array.from(t.options).filter(function(e){return""!==e.value}).length&&(t.classList.add("frm-single-unit"),t.addEventListener("mousedown",function(e){return e.preventDefault()}))}},{key:"calculateDeltaXFromSteps",value:function(t,r,n){var i=r.indexOf(t);if(-1===i){var o=e.snapToStep(t,r),a=r.indexOf(o);return Math.round(a/(r.length-1)*n)}return Math.round(i/(r.length-1)*n)}},{key:"calculateValue",value:function(e,t,r){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null;if(n&&n.length>0){var i=t/e,o=Math.round(i*(n.length-1));return n[Math.max(0,Math.min(o,n.length-1))]}var a=Math.round(t/e*r);return Math.min(a,r)}},{key:"snapToStep",value:function(e,t){for(var r=t[0],n=Math.abs(e-r),i=1;i":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},G=["(","?"],$={")":["("],":":["?","?:"]},J=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var te={"!":function(e){return!e},"*":function(e,t){return e*t},"/":function(e,t){return e/t},"%":function(e,t){return e%t},"+":function(e,t){return e+t},"-":function(e,t){return e-t},"<":function(e,t){return e":function(e,t){return e>t},">=":function(e,t){return e>=t},"==":function(e,t){return e===t},"!=":function(e,t){return e!==t},"&&":function(e,t){return e&&t},"||":function(e,t){return e||t},"?:":function(e,t,r){if(e)throw t;return r}};var re={contextDelimiter:"",onMissingKey:null};function ne(e,t){var r;for(r in this.data=e,this.pluralForms={},this.options={},re)this.options[r]=void 0!==t&&r in t?t[r]:re[r]}function ie(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,n)}return r}function oe(e){for(var t=1;t=0||X[i]3&&void 0!==arguments[3]?arguments[3]:10,a=e[t];if(ue(r)&&le(n))if("function"==typeof i)if("number"==typeof o){var s={callback:i,priority:o,namespace:n};if(a[r]){var l,u=a[r].handlers;for(l=u.length;l>0&&!(o>=u[l-1].priority);l--);l===u.length?u[l]=s:u.splice(l,0,s),a.__current.forEach(function(e){e.name===r&&e.currentIndex>=l&&e.currentIndex++})}else a[r]={handlers:[s],runs:0};"hookAdded"!==r&&e.doAction("hookAdded",r,n,i,o)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},ce=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n,i){var o=e[t];if(ue(n)&&(r||le(i))){if(!o[n])return 0;var a=0;if(r)a=o[n].handlers.length,o[n]={runs:o[n].runs,handlers:[]};else for(var s=o[n].handlers,l=function(e){s[e].namespace===i&&(s.splice(e,1),a++,o.__current.forEach(function(t){t.name===n&&t.currentIndex>=e&&t.currentIndex--}))},u=s.length-1;u>=0;u--)l(u);return"hookRemoved"!==n&&e.doAction("hookRemoved",n,i),a}}},de=function(e,t){return function(r,n){var i=e[t];return void 0!==n?r in i&&i[r].handlers.some(function(e){return e.namespace===n}):r in i}},fe=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var i=e[t];i[n]||(i[n]={handlers:[],runs:0}),i[n].runs++;for(var o=i[n].handlers,a=arguments.length,s=new Array(a>1?a-1:0),l=1;l1&&void 0!==arguments[1]?arguments[1]:"default";n.data[t]=oe(oe(oe({},ae),n.data[t]),e),n.data[t][""]=oe(oe({},ae[""]),n.data[t][""])},s=function(e,t){a(e,t),o()},l=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",t=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,i=arguments.length>3?arguments[3]:void 0,o=arguments.length>4?arguments[4]:void 0;return n.data[e]||a(void 0,e),n.dcnpgettext(e,t,r,i,o)},u=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},p=function(e,t,n){var i=l(n,t,e);return r?(i=r.applyFilters("i18n.gettext_with_context",i,e,t,n),r.applyFilters("i18n.gettext_with_context_"+u(n),i,e,t,n)):i};if(r){var c=function(e){se.test(e)&&o()};r.addAction("hookAdded","core/i18n",c),r.addAction("hookRemoved","core/i18n",c)}return{getLocaleData:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[e]},setLocaleData:s,resetLocaleData:function(e,t){n.data={},n.pluralForms={},s(e,t)},subscribe:function(e){return i.add(e),function(){return i.delete(e)}},__:function(e,t){var n=l(t,void 0,e);return r?(n=r.applyFilters("i18n.gettext",n,e,t),r.applyFilters("i18n.gettext_"+u(t),n,e,t)):n},_x:p,_n:function(e,t,n,i){var o=l(i,void 0,e,t,n);return r?(o=r.applyFilters("i18n.ngettext",o,e,t,n,i),r.applyFilters("i18n.ngettext_"+u(i),o,e,t,n,i)):o},_nx:function(e,t,n,i,o){var a=l(o,i,e,t,n);return r?(a=r.applyFilters("i18n.ngettext_with_context",a,e,t,n,i,o),r.applyFilters("i18n.ngettext_with_context_"+u(o),a,e,t,n,i,o)):a},isRTL:function(){return"rtl"===p("ltr","text direction")},hasTranslation:function(e,t,i){var o,a,s=t?t+""+e:e,l=!(null===(o=n.data)||void 0===o||null===(a=o[null!=i?i:"default"])||void 0===a||!a[s]);return r&&(l=r.applyFilters("i18n.has_translation",l,e,t,i),l=r.applyFilters("i18n.has_translation_"+u(i),l,e,t,i)),l}}}(0,0,ye));ge.getLocaleData.bind(ge),ge.setLocaleData.bind(ge),ge.resetLocaleData.bind(ge),ge.subscribe.bind(ge);var ve=ge.__.bind(ge);function xe(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,n)}return r}function we(e){for(var t=1;t2&&void 0!==arguments[2]&&arguments[2],n=document.createElement("option");return n.value=e,n.textContent=t,n.selected=r,n}},{key:"createSvgIcon",value:function(e){var t=document.createElementNS("http://www.w3.org/2000/svg","svg");t.classList.add("frmsvg");var r=document.createElementNS("http://www.w3.org/2000/svg","use");return r.setAttribute("href","#".concat(e)),t.append(r),t}}])}(f),qe={_:0};function Ue(e){return Ue="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Ue(e)}function Ne(e,t){for(var r=0;r\') no-repeat center center;background-size:20px}.frm-border-radius-component .frm-border-radius-container button.frm-active,.frm-border-radius-component .frm-border-radius-container button:hover{background-color:rgba(0,0,0,.05)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper{width:100%;justify-content:space-between;flex-wrap:wrap}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden){display:flex}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span{position:relative;display:block;overflow:hidden;width:calc(50% - 6px);height:36px;border-radius:var(--small-radius);border:1px solid var(--grey-300);margin-top:12px}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input{width:100%;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding:0 12px 0px 20px;box-sizing:border-box;border:none;text-align:right}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus{outline:none}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before{content:"";position:absolute;display:block;width:12px;height:12px;left:12px;top:0;bottom:0;right:auto;margin:auto;background:url(\'data:image/svg+xml,\') center center no-repeat;background-size:12px}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before{transform:rotate(180deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before{transform:rotate(0deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before{transform:rotate(90deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before{transform:rotate(-90deg)}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper{width:calc(100% - 36px - 12px);height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300);overflow:hidden}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper>*{border:none}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input{width:calc(100% - 44px);height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus{outline:none}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus{outline:none}\n',e}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),Object.defineProperty(e,"prototype",{writable:!1}),t&&Et(e,t)}(t,e),function(e,t,r){return t&&vt(e.prototype,t),r&&vt(e,r),Object.defineProperty(e,"prototype",{writable:!1}),e}(t,[{key:"initOptions",value:function(){var e;(function(e,t,r){var n=kt(St(e.prototype),"initOptions",r);return"function"==typeof n?function(e){return n.apply(r,e)}:n})(t,0,this)([]),null===this.componentId&&(this.componentId="frm-border-radius-web-component-".concat(zt._=(e=zt._,++e)))}},{key:"initView",value:function(){return this.wrapper=document.createElement("div"),this.container=document.createElement("div"),this.wrapper.classList.add("frm-border-radius-component"),this.container.classList.add("frm-border-radius-container"),this.container.append(this.getInputWrapper(),this.getButton(),this.getBorderIndividualInputsWrapper()),this.wrapper.append(this.container),this.wrapper}},{key:"parseDefaultValues",value:function(){if(!jt(Tt,this))return{top:{value:0,unit:"px"},bottom:{value:0,unit:"px"},left:{value:0,unit:"px"},right:{value:0,unit:"px"}};var e=jt(Tt,this).split(" ");return{top:t.parseValueUnit(e[0]||"0px"),bottom:t.parseValueUnit(e[2]||e[0]||"0px"),left:t.parseValueUnit(e[3]||e[1]||e[0]||"0px"),right:t.parseValueUnit(e[1]||e[0]||"0px")}}},{key:"getInputWrapper",value:function(){return this.inputWrapper=document.createElement("div"),this.inputWrapper.classList.add("frm-input-wrapper"),this.inputWrapper.append(this.getInputValue(),this.getInputUnit(),this.getHiddenInput()),this.inputWrapper}},{key:"getHiddenInput",value:function(){return this.hiddenInput=document.createElement("input"),this.hiddenInput.type="hidden",this.hiddenInput.value=jt(Pt,this),this.fieldName&&(this.hiddenInput.name=this.fieldName),this.hiddenInput}},{key:"getInputValue",value:function(){var e=this;return this.inputValue=document.createElement("input"),this.inputValue.type="text",this.inputValue.id="".concat(this.componentId,"-value"),this.inputValue.setAttribute("aria-label",ve("Border radius value","formidable")),this.inputValue.classList.add("frm-input-value"),jt(Ct,this)||(this.inputValue.value=parseInt(jt(Tt,this))||0),this.inputValue.addEventListener("change",function(){var t=e.inputValue.value+e.inputUnit.value;e.hiddenInput.value=t,e.borderInputBottom.value=e.inputValue.value,e.borderInputTop.value=e.inputValue.value,e.borderInputLeft.value=e.inputValue.value,e.borderInputRight.value=e.inputValue.value,e.updateValue(t)}),this.inputValue}},{key:"getInputUnit",value:function(){var e=this;return this.inputUnit=document.createElement("select"),this.inputUnit.id="".concat(this.componentId,"-unit"),this.inputUnit.setAttribute("aria-label",ve("Border radius unit","formidable")),this.inputUnit.classList.add("frm-input-unit"),jt(Lt,this).forEach(function(t){var r=document.createElement("option");r.value=t,r.textContent=t,e.inputUnit.append(r)}),this.inputUnit.addEventListener("change",function(){e.hiddenInput.value=e.inputValue.value+e.inputUnit.value}),this.inputUnit}},{key:"getBorderIndividualInputsWrapper",value:function(){return this.borderIndividualInputsWrapper=document.createElement("div"),this.borderIndividualInputsWrapper.classList.add("frm-border-individual-inputs-wrapper"),jt(Ct,this)||this.borderIndividualInputsWrapper.classList.add("frm_hidden"),this.borderIndividualInputsWrapper.append(this.getBorderInputTop(),this.getBorderInputRight(),this.getBorderInputLeft(),this.getBorderInputBottom()),this.borderIndividualInputsWrapper}},{key:"getBorderInputTop",value:function(){var e=this,t=this.parseDefaultValues(),r=document.createElement("span");return r.classList.add("frm-border-input-top"),this.borderInputTop=document.createElement("input"),this.borderInputTop.type="text",this.borderInputTop.id="".concat(this.componentId,"-top"),this.borderInputTop.setAttribute("aria-label",ve("Top border radius","formidable")),this.borderInputTop.value=parseInt(t.top.value),r.append(this.borderInputTop),this.borderInputTop.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),r}},{key:"getBorderInputBottom",value:function(){var e=this,t=this.parseDefaultValues(),r=document.createElement("span");return r.classList.add("frm-border-input-bottom"),this.borderInputBottom=document.createElement("input"),this.borderInputBottom.type="text",this.borderInputBottom.id="".concat(this.componentId,"-bottom"),this.borderInputBottom.setAttribute("aria-label",ve("Bottom border radius","formidable")),this.borderInputBottom.value=parseInt(t.bottom.value),r.append(this.borderInputBottom),this.borderInputBottom.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),r}},{key:"getBorderInputLeft",value:function(){var e=this,t=this.parseDefaultValues(),r=document.createElement("span");return r.classList.add("frm-border-input-left"),this.borderInputLeft=document.createElement("input"),this.borderInputLeft.type="text",this.borderInputLeft.id="".concat(this.componentId,"-left"),this.borderInputLeft.setAttribute("aria-label",ve("Left border radius","formidable")),this.borderInputLeft.value=parseInt(t.left.value),r.append(this.borderInputLeft),this.borderInputLeft.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),r}},{key:"getBorderInputRight",value:function(){var e=this,t=this.parseDefaultValues(),r=document.createElement("span");return r.classList.add("frm-border-input-right"),this.borderInputRight=document.createElement("input"),this.borderInputRight.type="text",this.borderInputRight.id="".concat(this.componentId,"-right"),this.borderInputRight.setAttribute("aria-label",ve("Right border radius","formidable")),this.borderInputRight.value=parseInt(t.right.value),r.append(this.borderInputRight),this.borderInputRight.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),r}},{key:"buildBorderRadiusIndividualValue",value:function(){var e=this.inputUnit.value,t="".concat(parseInt(this.borderInputTop.value,10)).concat(e," ").concat(parseInt(this.borderInputRight.value,10)).concat(e," ").concat(parseInt(this.borderInputBottom.value,10)).concat(e," ").concat(parseInt(this.borderInputLeft.value,10)).concat(e);this.updateValue(t)}},{key:"updateValue",value:function(e){this.hiddenInput.value=e,jt(Vt,this).call(this,e)}},{key:"getButton",value:function(){var e=this;return this.button=document.createElement("button"),this.button.type="button",this.button.textContent=ve("Border Radius","formidable"),jt(Ct,this)&&this.button.classList.add("frm-active"),this.button.addEventListener("click",function(){e.button.classList.toggle("frm-active"),e.borderIndividualInputsWrapper.classList.toggle("frm_hidden")}),this.button}},{key:"onChange",set:function(e){if("function"!=typeof e)throw new TypeError("Expected a function, but received ".concat(gt(e)));It(Vt,this,e)}},{key:"borderRadiusDefaultValue",set:function(e){It(Tt,this,e),It(Ct,this,!/^(\d+)(px|em|%)?$/.test(e)&&""!==e)}}],[{key:"parseValueUnit",value:function(e){var t=e.match(/^(\d+)(px|em|%)?$/);return t?{value:parseInt(t[1],10),unit:t[2]||"px"}:{value:0,unit:"px"}}}])}(f),zt={_:0};customElements.define("frm-tab-navigator-component",x),customElements.define("frm-colorpicker-component",D),customElements.define("frm-range-slider-component",Fe),customElements.define("frm-dropdown-component",et),customElements.define("frm-typography-component",bt),customElements.define("frm-border-radius-component",At)})()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/admin/components/dependent-updater-component.js": +/*!****************************************************************!*\ + !*** ./js/src/admin/components/dependent-updater-component.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmStyleDependentUpdaterComponent) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * This component updates the dependent style element's values and triggers a custom change event for each style element, initiating the style preview. + * The names of the elements that will be updated are specified using the "will-change" attribute. + * It is primarily used in components from Style/Quick Settings. + * For instance, when the "FrmPrimaryColorStyleComponent" is changed, it simultaneously updates various style elements like border color, text color, and button backgrounds. + */ +var frmStyleDependentUpdaterComponent = /*#__PURE__*/function () { + /** + * Creates an instance of frmStyleDependentUpdaterComponent. + * + * @param {HTMLElement} component - The component element. + */ + function frmStyleDependentUpdaterComponent(component) { + _classCallCheck(this, frmStyleDependentUpdaterComponent); + this.component = component; + try { + var willChangeData = JSON.parse(this.component.dataset.willChange); + this.data = { + propagateInputs: this.initPropagationList(willChangeData), + changeEvent: new Event('change', { + bubbles: true + }) + }; + } catch (error) { + console.error('Error parsing JSON data from "will-change" attribute.', error); + } + } + + /** + * Initializes the list of inputs to propagate changes to. + * The selection is made by provided input's names list in "will-change" attribute. + * + * @param {string[]} inputNames - The names of the inputs to propagate changes to. + * @return {HTMLElement[]} - The list of inputs to propagate changes to. + */ + return _createClass(frmStyleDependentUpdaterComponent, [{ + key: "initPropagationList", + value: function initPropagationList(inputNames) { + var list = []; + inputNames.forEach(function (name) { + var input = document.querySelector("input[name=\"".concat(name, "\"]")); + if (input) { + list.push(input); + } + }); + return list; + } + + /** + * Updates all dependent elements with the given value. + * + * @param {string} value - The value to update the dependent elements with. + */ + }, { + key: "updateAllDependentElements", + value: function updateAllDependentElements(value) { + this.data.propagateInputs.forEach(function (input) { + input.value = value; + }); + this.data.propagateInputs[0].dispatchEvent(this.data.changeEvent); + } + }]); +}(); + + +/***/ }), + +/***/ "./js/src/components/class-tabs-navigator.js": +/*!***************************************************!*\ + !*** ./js/src/components/class-tabs-navigator.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmTabsNavigator: () => (/* binding */ frmTabsNavigator) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmTabsNavigator = /*#__PURE__*/function () { + function frmTabsNavigator(wrapper) { + _classCallCheck(this, frmTabsNavigator); + if (wrapper === undefined) { + return; + } + this.wrapper = wrapper instanceof Element ? wrapper : document.querySelector(wrapper); + if (null === this.wrapper) { + return; + } + this.flexboxSlidesGap = '16px'; + this.navs = this.wrapper.querySelectorAll('.frm-tabs-navs ul > li'); + this.slideTrackLine = this.wrapper.querySelector('.frm-tabs-active-underline'); + this.slideTrack = this.wrapper.querySelector('.frm-tabs-slide-track'); + this.slides = this.wrapper.querySelectorAll('.frm-tabs-slide-track > div'); + this.isRTL = document.documentElement.dir === 'rtl' || document.body.dir === 'rtl'; + this.resizeObserver = null; + this.init(); + } + return _createClass(frmTabsNavigator, [{ + key: "init", + value: function init() { + var _this = this; + if (null === this.wrapper || !this.navs.length || null === this.slideTrackLine || null === this.slideTrack || !this.slides.length) { + return; + } + this.navs.forEach(function (nav, index) { + nav.addEventListener('click', function (event) { + return _this.onNavClick(event, index); + }); + if (nav.classList.contains('frm-active')) { + _this.initSlideTrackUnderline(nav); + } + }); + this.slideTrackLine.style.display = 'block'; + this.setupScrollbarObserver(); + // Cleanup observers when page unloads to prevent memory leaks + window.addEventListener('beforeunload', this.cleanupObservers); + } + }, { + key: "onNavClick", + value: function onNavClick(event, index) { + var navItem = event.currentTarget; + event.preventDefault(); + this.removeActiveClassnameFromNavs(); + navItem.classList.add('frm-active'); + this.initSlideTrackUnderline(navItem); + this.changeSlide(index); + + // Handle special case for frm_insert_fields_tab + var navLink = navItem.querySelector('a'); + if (navLink && navLink.id === 'frm_insert_fields_tab' && !navLink.closest('#frm_adv_info')) { + var _window$frmAdminBuild, _window$frmAdminBuild2; + (_window$frmAdminBuild = window.frmAdminBuild) === null || _window$frmAdminBuild === void 0 || (_window$frmAdminBuild2 = _window$frmAdminBuild.clearSettingsBox) === null || _window$frmAdminBuild2 === void 0 || _window$frmAdminBuild2.call(_window$frmAdminBuild); + } + } + }, { + key: "initSlideTrackUnderline", + value: function initSlideTrackUnderline(nav) { + var activeNav = nav !== undefined ? nav : this.navs.filter(function (nav) { + return nav.classList.contains('frm-active'); + }); + this.positionUnderlineIndicator(activeNav); + } + + /** + * Sets up a ResizeObserver to watch for scrollbar changes in the parent container. + * Automatically repositions the underline indicator when layout changes occur. + */ + }, { + key: "setupScrollbarObserver", + value: function setupScrollbarObserver() { + var _this2 = this; + var resizeObserverTarget = document.querySelector('.frm-scrollbar-wrapper, .styling_settings') || document.body; + if (!resizeObserverTarget || !('ResizeObserver' in window)) { + return; + } + this.resizeObserver = new ResizeObserver(function () { + var activeNav = _this2.wrapper.querySelector('.frm-tabs-navs ul > li.frm-active'); + if (activeNav) { + _this2.positionUnderlineIndicator(activeNav); + } + }); + this.resizeObserver.observe(resizeObserverTarget); + } + + /** + * Cleans up observers to prevent memory leaks. + */ + }, { + key: "cleanupObservers", + value: function cleanupObservers() { + if (this.resizeObserver) { + this.resizeObserver.disconnect(); + this.resizeObserver = null; + } + } + + /** + * Positions the underline indicator based on the active navigation element. + * + * @param {HTMLElement} activeNav The active navigation element to position the underline under + */ + }, { + key: "positionUnderlineIndicator", + value: function positionUnderlineIndicator(activeNav) { + var _this3 = this; + requestAnimationFrame(function () { + var position = _this3.isRTL ? -(activeNav.parentElement.offsetWidth - activeNav.offsetLeft - activeNav.offsetWidth) : activeNav.offsetLeft; + _this3.slideTrackLine.style.transform = "translateX(".concat(position, "px)"); + _this3.slideTrackLine.style.width = "".concat(activeNav.clientWidth, "px"); + }); + } + }, { + key: "changeSlide", + value: function changeSlide(index) { + this.removeActiveClassnameFromSlides(); + var translate = index == 0 ? '0px' : "calc( ( ".concat(index * 100, "% + ").concat(parseInt(this.flexboxSlidesGap, 10) * index, "px ) * ").concat(this.isRTL ? 1 : -1, " )"); + if ('0px' !== translate) { + this.slideTrack.style.transform = "translateX(".concat(translate, ")"); + } else { + this.slideTrack.style.removeProperty('transform'); + } + if (index in this.slides) { + this.slides[index].classList.add('frm-active'); + } + } + }, { + key: "removeActiveClassnameFromSlides", + value: function removeActiveClassnameFromSlides() { + this.slides.forEach(function (slide) { + return slide.classList.remove('frm-active'); + }); + } + }, { + key: "removeActiveClassnameFromNavs", + value: function removeActiveClassnameFromNavs() { + this.navs.forEach(function (nav) { + return nav.classList.remove('frm-active'); + }); + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/settings-components/components/slider-component.js": +/*!*******************************************************************!*\ + !*** ./js/src/settings-components/components/slider-component.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmSliderComponent) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../admin/components/dependent-updater-component */ "./js/src/admin/components/dependent-updater-component.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Internal dependencies + */ + + + +/** + * Represents a slider component. + * + * @class frmSliderComponent + */ +var frmSliderComponent = /*#__PURE__*/function () { + function frmSliderComponent() { + var _this = this; + var sliderElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; + var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + _classCallCheck(this, frmSliderComponent); + this.loadedByWebComponent = sliderElements.length > 0; + this.sliderElements = sliderElements.length > 0 ? sliderElements : document.querySelectorAll('.frm-slider-component'); + this.settings = settings; + if (0 === this.sliderElements.length) { + return; + } + + // The slider bullet point width in pixels. Used in value calculation on drag event. + this.sliderBulletWidth = 16; + this.sliderMarginRight = 5; + this.eventsChange = []; + var debounce = frmDom.util.debounce; + this.valueChangeDebouncer = debounce(function (index) { + return _this.triggerValueChange(index); + }, 25); + this.initOptions(); + this.init(); + } + + /** + * Initializes the options for the slider component. + */ + return _createClass(frmSliderComponent, [{ + key: "initOptions", + value: function initOptions() { + var _this2 = this; + this.options = []; + this.sliderElements.forEach(function (element, index) { + var parentWrapper = element.classList.contains('frm-has-multiple-values') ? element.closest('.frm-style-component') : element; + var steps = _this2.settings.steps || (element.dataset.steps ? JSON.parse(element.dataset.steps) : null); + _this2.options.push({ + dragging: false, + startX: 0, + translateX: 0, + maxValue: parseInt(element.dataset.maxValue, 10), + element: element, + index: index, + value: 0, + steps: steps, + dependentUpdater: parentWrapper.classList.contains('frm-style-dependent-updater-component') ? new _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__["default"](parentWrapper) : null + }); + }); + } + + /** + * Initializes the slider component. + */ + }, { + key: "init", + value: function init() { + this.initDraggable(); + if (this.loadedByWebComponent) { + this.initSlidersPositionInsideWebComponent(); + return; + } + this.initSlidersPosition(); + } + + /** + * Initializes the draggable functionality for the slider component. + */ + }, { + key: "initDraggable", + value: function initDraggable() { + var _this3 = this; + this.sliderElements.forEach(function (element, index) { + _this3.eventsChange[index] = new Event('change', { + bubbles: true, + cancelable: true + }); + var draggableBullet = element.querySelector('.frm-slider-bullet'); + var valueInput = element.querySelector('.frm-slider-value input[type="text"]'); + valueInput.addEventListener('change', function (event) { + var unit = element.querySelector('select').value; + if (_this3.getMaxValue(unit, index) < parseInt(event.target.value, 10)) { + return; + } + _this3.initSliderWidth(element); + _this3.options[index].fullValue = _this3.updateValue(element, valueInput.value + unit); + _this3.triggerValueChange(index); + }); + _this3.expandSliderGroup(element); + _this3.updateOnUnitChange(element, valueInput, index); + _this3.changeSliderPositionOnClick(element, valueInput, index); + frmSliderComponent.maybeDisableUnitDropdown(element); + draggableBullet.addEventListener('mousedown', function (event) { + event.preventDefault(); + event.stopPropagation(); + if (element.classList.contains('frm-disabled')) { + return; + } + _this3.enableDragging(event, index); + var onMouseMove = function onMouseMove(moveEvent) { + return _this3.moveTracker(moveEvent, index); + }; + var _onMouseUp = function onMouseUp() { + _this3.disableDragging(index); + document.removeEventListener('mousemove', onMouseMove); + document.removeEventListener('mouseup', _onMouseUp); + }; + document.addEventListener('mousemove', onMouseMove); + document.addEventListener('mouseup', _onMouseUp); + }); + }); + } + }, { + key: "expandSliderGroup", + value: function expandSliderGroup(element) { + var svgIcon = element.querySelector('.frmsvg'); + if (element.dataset.displaySliders === undefined || null === svgIcon) { + return; + } + var sliderGroupItems = this.getSliderGroupItems(element); + svgIcon.addEventListener('click', function () { + sliderGroupItems.forEach(function (item) { + item.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); + }); + }); + } + }, { + key: "updateOnUnitChange", + value: function updateOnUnitChange(element, valueInput, index) { + var _this4 = this; + element.querySelector('select').addEventListener('change', function (event) { + var unit = event.target.value.toLowerCase(); + if ('' === unit) { + element.classList.add('frm-disabled', 'frm-empty'); + return; + } + if ('auto' === unit) { + element.classList.add('frm-disabled'); + _this4.updateValue(element, 'auto'); + _this4.triggerValueChange(index); + return; + } + element.classList.remove('frm-disabled', 'frm-empty'); + _this4.options[index].fullValue = valueInput.value + unit; + _this4.updateValue(element, _this4.options[index].fullValue); + _this4.triggerValueChange(index); + }); + } + }, { + key: "changeSliderPositionOnClick", + value: function changeSliderPositionOnClick(element, valueInput, index) { + var _this5 = this; + var frmSlider = element.querySelector('.frm-slider'); + var customEvent = new Event('change', { + bubbles: true, + cancelable: true + }); + frmSlider.addEventListener('click', function (event) { + if (element.classList.contains('frm-disabled')) { + return; + } + event.preventDefault(); + event.stopPropagation(); + if (!event.target.classList.contains('frm-slider') && !event.target.classList.contains('frm-slider-active-track')) { + return; + } + var sliderWidth = frmSlider.offsetWidth - _this5.sliderBulletWidth; + var sliderRect = frmSlider.getBoundingClientRect(); + var deltaX = event.clientX - sliderRect.left - _this5.sliderBulletWidth; + var unit = element.querySelector('select').value; + var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, _this5.getMaxValue(unit, index), _this5.options[index].steps); + if (value < 0) { + return; + } + _this5.options[index].fullValue = _this5.updateValue(element, value + unit); + _this5.initChildSlidersWidth(element, deltaX, index, value + unit); + valueInput.value = value; + valueInput.dispatchEvent(customEvent); + }); + } + + /** + * Disables the unit dropdown if there is only a single unit option. + * + * @param {HTMLElement} element - The slider element. + */ + }, { + key: "getSliderGroupItems", + value: + /** + * Retrieves an array of slider group items based on the provided element. + * + * @param {HTMLElement} element - The element to retrieve slider group items from. + * @return {NodeList} - An array-like object containing the slider group items. + */ + function getSliderGroupItems(element) { + if (element.dataset.displaySliders === undefined) { + return []; + } + var slidersGroup = element.dataset.displaySliders.split(','); + var query = slidersGroup.map(function (item) { + return ".frm-slider-component[data-type=\"".concat(item, "\"]"); + }).join(', '); + return element.closest('.frm-style-component').querySelectorAll(query); + } + }, { + key: "initSlidersPositionInsideWebComponent", + value: function initSlidersPositionInsideWebComponent() { + var _this6 = this; + this.sliderElements.forEach(function (element, index) { + _this6.initSliderWidth(element, index); + }); + } + + /** + * Initializes the position of sliders when a accordion section is opened. + */ + }, { + key: "initSlidersPosition", + value: function initSlidersPosition() { + var _this7 = this; + var emailSettings = document.querySelector('.email_settings'); + if (emailSettings) { + this.initSlidersWidth(emailSettings); + return; + } + var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); + var quickSettings = document.querySelector('.frm-quick-settings'); + var openedAccordion = document.querySelector('.accordion-section.open'); + + // Detect if upload background image upload has triggered and initialize the "Image Opacity" slider width. + wp.hooks.addAction('frm_pro_on_bg_image_upload', 'formidable', function (event) { + var imageBackgroundOpacitySlider = event.closest('.accordion-section-content').querySelector('#frm-bg-image-opacity-slider'); + _this7.initSlidersWidth(imageBackgroundOpacitySlider); + }); + + // init the sliders width from "Quick Settings" page. + if (quickSettings) { + this.initSlidersWidth(quickSettings); + } + + // Init the sliders width in opened accordion section from "Advanced Settings" page. + if (openedAccordion) { + this.initSlidersWidth(openedAccordion); + } + + // init the sliders width everytime when an accordion section is opened from "Advanced Settings" page. + accordionitems.forEach(function (item) { + item.addEventListener('click', function (event) { + _this7.initSlidersWidth(event.target.closest('.accordion-section')); + }); + }); + this.initSliderPositionOnFieldShapeChange(); + } + + /** + * Initializes the width of "Corner Radius" slider that is dynamically is displayed on "Field Shape" option change from "Quick Settings". + * + * @return {void} + */ + }, { + key: "initSliderPositionOnFieldShapeChange", + value: function initSliderPositionOnFieldShapeChange() { + var _this8 = this; + var fieldShapeType = document.querySelector('.frm-style-component.frm-field-shape'); + if (!fieldShapeType) { + return; + } + var radioButtons = fieldShapeType.querySelectorAll('input[type="radio"]'); + radioButtons.forEach(function (radio) { + radio.addEventListener('change', function (event) { + if (event.target.checked && 'rounded-corner' === event.target.value) { + var slider = document.querySelector('div[data-frm-element="field-shape-corner-radius"] .frm-slider-component'); + _this8.initSliderWidth(slider); + } + }); + }); + } + + /** + * Initializes the width of sliders within a given section. + * + * @param {HTMLElement} section - The section containing the sliders. + * @return {void} + */ + }, { + key: "initSlidersWidth", + value: function initSlidersWidth(section) { + var _this9 = this; + var sliders = section.querySelectorAll('.frm-slider-component'); + sliders.forEach(function (slider) { + setTimeout(function () { + _this9.initSliderWidth(slider); + }, 100); + }); + } + + /** + * Initializes the width of a slider. + * + * @param {HTMLElement} slider - The slider element. + * @param {number} sliderIndex - The index of the slider. + * @return {void} + */ + }, { + key: "initSliderWidth", + value: function initSliderWidth(slider) { + var sliderIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + if (slider.classList.contains('frm-disabled')) { + return; + } + var index = sliderIndex !== null ? sliderIndex : this.getSliderIndex(slider); + var sliderWidth = slider.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; + var value = parseInt(slider.querySelector('.frm-slider-value input[type="text"]').value, 10); + var unit = slider.querySelector('select').value; + var steps = this.options[index].steps; + var deltaX = Math.ceil(value / this.options[index].maxValue * sliderWidth); + if ('%' === unit) { + deltaX = Math.round(sliderWidth * value / 100); + } else if (steps && steps.length > 0) { + deltaX = frmSliderComponent.calculateDeltaXFromSteps(value, steps, sliderWidth); + } + slider.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); + this.options[index].translateX = deltaX; + this.options[index].value = value + unit; + } + + /** + * Calculates the deltaX position based on a value and steps array. + * + * @param {number} value - The current value. + * @param {Array} steps - Array of step values. + * @param {number} sliderWidth - The width of the slider. + * @return {number} - The calculated deltaX position. + */ + }, { + key: "initChildSlidersWidth", + value: + /** + * Initializes the width of child sliders. + * + * @param {HTMLElement} slider - The parent slider element. + * @param {number} width - The width to set for the child sliders. + * @param {number} index - The starting index for the child sliders. + * @param {number} value - The value to set for the child sliders. + */ + function initChildSlidersWidth(slider, width, index, value) { + var _this0 = this; + if (!slider.classList.contains('frm-has-independent-fields') && !slider.classList.contains('frm-has-multiple-values')) { + return; + } + var childSliders = slider.classList.contains('frm-has-independent-fields') ? slider.querySelectorAll('.frm-independent-slider-field') : this.getSliderGroupItems(slider); + childSliders.forEach(function (item, childIndex) { + item.querySelector('.frm-slider-active-track').style.width = "".concat(width, "px"); + _this0.options[index + childIndex + 1].translateX = width; + _this0.options[index + childIndex + 1].value = value; + }); + } + + /** + * Returns the index of the specified slider element. + * + * @param {HTMLElement} slider - The slider element. + * @return {number} The index of the slider element. + */ + }, { + key: "getSliderIndex", + value: function getSliderIndex(slider) { + return this.options.filter(function (option) { + return option.element === slider; + })[0].index; + } + + /** + * Handles the movement of the slider tracker. + * + * @param {Event} event - The event object representing the mouse movement. + * @param {number} index - The index of the slider element. + * @return {void} + */ + }, { + key: "moveTracker", + value: function moveTracker(event, index) { + if (!this.options[index].dragging) { + return; + } + var deltaX = event.clientX - this.options[index].startX; + var element = this.sliderElements[index]; + var sliderWidth = element.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; + + // Clamp deltaX within valid range + deltaX = Math.max(deltaX, 0); + deltaX = Math.min(deltaX, sliderWidth); + var unit = element.querySelector('select').value; + var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, this.getMaxValue(unit, index), this.options[index].steps); + element.querySelector('.frm-slider-value input[type="text"]').value = value; + element.querySelector('.frm-slider-bullet .frm-slider-value-label').innerText = value; + element.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); + this.initChildSlidersWidth(element, deltaX, index, value + unit); + this.options[index].translateX = deltaX; + this.options[index].value = value + unit; + this.options[index].fullValue = this.updateValue(element, this.options[index].value); + this.valueChangeDebouncer(index); + } + + /** + * Get the maximum value based on the unit and index. + * + * @param {string} unit - The unit of measurement. + * @param {number} index - The index of the option. + * @return {number} The maximum value. + */ + }, { + key: "getMaxValue", + value: function getMaxValue(unit, index) { + return '%' === unit ? 100 : this.options[index].maxValue; + } + + /** + * Enables dragging for the slider component. + * + * @param {Event} event - The event object. + * @param {number} index - The index of the option being dragged. + */ + }, { + key: "enableDragging", + value: function enableDragging(event, index) { + event.target.classList.add('frm-dragging'); + this.options[index].dragging = true; + this.options[index].startX = event.clientX - this.options[index].translateX; + } + + /** + * Disables dragging for a specific index. + * + * @param {number} index - The index of the option to disable dragging for. + */ + }, { + key: "disableDragging", + value: function disableDragging(index) { + if (false === this.options[index].dragging) { + return; + } + var draggableBullet = this.sliderElements[index].querySelector('.frm-slider-bullet'); + draggableBullet.classList.remove('frm-dragging'); + this.options[index].dragging = false; + this.triggerValueChange(index); + } + + /** + * Triggers a value change for the specified index. + * + * @param {number} index - The index of the value to be changed. + */ + }, { + key: "triggerValueChange", + value: function triggerValueChange(index) { + var _this1 = this; + if (null !== this.options[index].dependentUpdater) { + this.options[index].dependentUpdater.updateAllDependentElements(this.options[index].fullValue); + return; + } + var input = this.sliderElements[index].classList.contains('frm-has-multiple-values') ? this.sliderElements[index].closest('.frm-style-component').querySelector('input[type="hidden"]') : this.sliderElements[index].querySelectorAll('.frm-slider-value input[type="hidden"]'); + if (input instanceof NodeList) { + input.forEach(function (item) { + item.dispatchEvent(_this1.eventsChange[index]); + }); + return; + } + input.dispatchEvent(this.eventsChange[index]); + } + + /** + * Calculates the value based on the width, deltaX, and maxValue. + * + * @param {number} width - The width of the slider. + * @param {number} deltaX - The change in x-coordinate. + * @param {number} maxValue - The maximum value. + * @param {Array|null} steps - Optional array of step values to snap to. + * @return {number} - The calculated value. + */ + }, { + key: "updateValue", + value: + /** + * Updates the value of a slider component. + * + * @param {HTMLElement} element - The slider component element. + * @param {string} value - The new value to be set. + * @return {string} - The updated value. + */ + function updateValue(element, value) { + var _this10 = this; + // When the slider component is used for "Base Font Size", we need to update a hidden input field when change happens to indicate that the "Base Font Size" has been adjusted. + // Used to avoid conflicts with other possible font sizes adjustemnts in "Advanced Settings" when moving from "Quick Settings" when "Base Font Size" is not changed. + if (element.classList.contains('frm-base-font-size')) { + var userBaseFontSizeInput = document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]'); + if (userBaseFontSizeInput) { + userBaseFontSizeInput.value = 'true'; + } + } + if (element.classList.contains('frm-has-multiple-values')) { + var input = element.closest('.frm-style-component').querySelector('input[type="hidden"]'); + var inputValue = input.value.split(' '); + var type = element.dataset.type; + if (!inputValue[2]) { + inputValue[2] = '0px'; + } + if (!inputValue[3]) { + inputValue[3] = '0px'; + } + switch (type) { + case 'vertical': + inputValue[0] = value; + inputValue[2] = value; + break; + case 'horizontal': + inputValue[1] = value; + inputValue[3] = value; + break; + case 'top': + inputValue[0] = value; + break; + case 'bottom': + inputValue[2] = value; + break; + case 'left': + inputValue[3] = value; + break; + case 'right': + inputValue[1] = value; + break; + } + var newValue = inputValue.join(' '); + input.value = newValue; + var childSlidersGroup = this.getSliderGroupItems(element); + childSlidersGroup.forEach(function (slider) { + var unitMeasure = _this10.getUnitMeasureFromValue(value); + slider.querySelector('.frm-slider-value input[type="text"]').value = parseInt(value, 10); + slider.querySelector('select').value = unitMeasure; + }); + return newValue; + } + if (element.classList.contains('frm-has-independent-fields')) { + var inputValues = element.querySelectorAll('.frm-slider-value input[type="hidden"]'); + var visibleValues = element.querySelectorAll('.frm-slider-value input[type="text"]'); + inputValues.forEach(function (input, index) { + input.value = value; + visibleValues[index + 1].value = parseInt(value, 10); + }); + return value; + } + element.querySelector('.frm-slider-value input[type="hidden"]').value = value; + return value; + } + + /** + * Returns the unit of measurement used in the given value. + * + * @param {string} value - The value to check for the unit of measurement. + * @return {string} The unit of measurement ('%', 'px', 'em') found in the value, or an empty string if none is found. + */ + }, { + key: "getUnitMeasureFromValue", + value: function getUnitMeasureFromValue(value) { + return ['%', 'px', 'em'].find(function (unit) { + return value.includes(unit); + }) || ''; + } + }], [{ + key: "maybeDisableUnitDropdown", + value: function maybeDisableUnitDropdown(element) { + var select = element.querySelector('select'); + if (!select) { + return; + } + var options = Array.from(select.options).filter(function (option) { + return '' !== option.value; + }); + if (1 >= options.length) { + select.classList.add('frm-single-unit'); + select.addEventListener('mousedown', function (event) { + return event.preventDefault(); + }); + } + } + }, { + key: "calculateDeltaXFromSteps", + value: function calculateDeltaXFromSteps(value, steps, sliderWidth) { + var stepIndex = steps.indexOf(value); + if (-1 === stepIndex) { + // If value not in steps, find closest and use its position + var closestValue = frmSliderComponent.snapToStep(value, steps); + var closestIndex = steps.indexOf(closestValue); + return Math.round(closestIndex / (steps.length - 1) * sliderWidth); + } + return Math.round(stepIndex / (steps.length - 1) * sliderWidth); + } + }, { + key: "calculateValue", + value: function calculateValue(width, deltaX, maxValue) { + var steps = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; + if (steps && steps.length > 0) { + // For stepped sliders, map position directly to step index + var position = deltaX / width; + var stepIndex = Math.round(position * (steps.length - 1)); + var clampedIndex = Math.max(0, Math.min(stepIndex, steps.length - 1)); + return steps[clampedIndex]; + } + + // Calculate value as a simple proportion of the slider position + var value = Math.round(deltaX / width * maxValue); + return Math.min(value, maxValue); + } + + /** + * Snaps a value to the nearest step in the steps array. + * + * @param {number} value - The value to snap. + * @param {Array} steps - Array of step values to snap to. + * @return {number} - The nearest step value. + */ + }, { + key: "snapToStep", + value: function snapToStep(value, steps) { + var nearest = steps[0]; + var minDiff = Math.abs(value - nearest); + for (var i = 1; i < steps.length; i++) { + var diff = Math.abs(value - steps[i]); + if (diff < minDiff) { + minDiff = diff; + nearest = steps[i]; + } + } + return nearest; + } + }]); +}(); + + +/***/ }), + +/***/ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.js": +/*!******************************************************************************************!*\ + !*** ./js/src/web-components/frm-border-radius-component/frm-border-radius-component.js ***! + \******************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmBorderRadiusComponent: () => (/* binding */ frmBorderRadiusComponent) +/* harmony export */ }); +/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var _frm_border_radius_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-border-radius-component.css */ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.css"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _superPropGet(t, o, e, r) { var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } +function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } +function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } +function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } +function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } +function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } +function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } + + + +var _onChange = /*#__PURE__*/new WeakMap(); +var _unitTypeOptions = /*#__PURE__*/new WeakMap(); +var _value = /*#__PURE__*/new WeakMap(); +var _defaultValue = /*#__PURE__*/new WeakMap(); +var _usesMultipleValues = /*#__PURE__*/new WeakMap(); +var frmBorderRadiusComponent = /*#__PURE__*/function (_frmWebComponent) { + function frmBorderRadiusComponent() { + var _this; + _classCallCheck(this, frmBorderRadiusComponent); + _this = _callSuper(this, frmBorderRadiusComponent); + _classPrivateFieldInitSpec(_this, _onChange, function () {}); + _classPrivateFieldInitSpec(_this, _unitTypeOptions, ['px', 'em', '%']); + _classPrivateFieldInitSpec(_this, _value, '0px'); + _classPrivateFieldInitSpec(_this, _defaultValue, '0px'); + _classPrivateFieldInitSpec(_this, _usesMultipleValues, false); + _this.componentStyle = _frm_border_radius_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; + return _this; + } + _inherits(frmBorderRadiusComponent, _frmWebComponent); + return _createClass(frmBorderRadiusComponent, [{ + key: "initOptions", + value: function initOptions() { + _superPropGet(frmBorderRadiusComponent, "initOptions", this, 3)([]); + if (null === this.componentId) { + var _frmBorderRadiusCompo; + this.componentId = "frm-border-radius-web-component-".concat(_instanceCount._ = (_frmBorderRadiusCompo = _instanceCount._, ++_frmBorderRadiusCompo)); + } + } + }, { + key: "initView", + value: function initView() { + this.wrapper = document.createElement('div'); + this.container = document.createElement('div'); + this.wrapper.classList.add('frm-border-radius-component'); + this.container.classList.add('frm-border-radius-container'); + this.container.append(this.getInputWrapper(), this.getButton(), this.getBorderIndividualInputsWrapper()); + this.wrapper.append(this.container); + return this.wrapper; + } + }, { + key: "parseDefaultValues", + value: function parseDefaultValues() { + if (!_classPrivateFieldGet(_defaultValue, this)) { + return { + top: { + value: 0, + unit: 'px' + }, + bottom: { + value: 0, + unit: 'px' + }, + left: { + value: 0, + unit: 'px' + }, + right: { + value: 0, + unit: 'px' + } + }; + } + var parts = _classPrivateFieldGet(_defaultValue, this).split(' '); + return { + top: frmBorderRadiusComponent.parseValueUnit(parts[0] || '0px'), + bottom: frmBorderRadiusComponent.parseValueUnit(parts[2] || parts[0] || '0px'), + left: frmBorderRadiusComponent.parseValueUnit(parts[3] || parts[1] || parts[0] || '0px'), + right: frmBorderRadiusComponent.parseValueUnit(parts[1] || parts[0] || '0px') + }; + } + }, { + key: "getInputWrapper", + value: function getInputWrapper() { + this.inputWrapper = document.createElement('div'); + this.inputWrapper.classList.add('frm-input-wrapper'); + this.inputWrapper.append(this.getInputValue(), this.getInputUnit(), this.getHiddenInput()); + return this.inputWrapper; + } + }, { + key: "getHiddenInput", + value: function getHiddenInput() { + this.hiddenInput = document.createElement('input'); + this.hiddenInput.type = 'hidden'; + this.hiddenInput.value = _classPrivateFieldGet(_value, this); + if (this.fieldName) { + this.hiddenInput.name = this.fieldName; + } + return this.hiddenInput; + } + }, { + key: "getInputValue", + value: function getInputValue() { + var _this2 = this; + this.inputValue = document.createElement('input'); + this.inputValue.type = 'text'; + this.inputValue.id = "".concat(this.componentId, "-value"); + this.inputValue.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Border radius value', 'formidable')); + this.inputValue.classList.add('frm-input-value'); + if (!_classPrivateFieldGet(_usesMultipleValues, this)) { + this.inputValue.value = parseInt(_classPrivateFieldGet(_defaultValue, this)) || 0; + } + this.inputValue.addEventListener('change', function () { + var value = _this2.inputValue.value + _this2.inputUnit.value; + _this2.hiddenInput.value = value; + _this2.borderInputBottom.value = _this2.inputValue.value; + _this2.borderInputTop.value = _this2.inputValue.value; + _this2.borderInputLeft.value = _this2.inputValue.value; + _this2.borderInputRight.value = _this2.inputValue.value; + _this2.updateValue(value); + }); + return this.inputValue; + } + }, { + key: "getInputUnit", + value: function getInputUnit() { + var _this3 = this; + this.inputUnit = document.createElement('select'); + this.inputUnit.id = "".concat(this.componentId, "-unit"); + this.inputUnit.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Border radius unit', 'formidable')); + this.inputUnit.classList.add('frm-input-unit'); + _classPrivateFieldGet(_unitTypeOptions, this).forEach(function (option) { + var opt = document.createElement('option'); + opt.value = option; + opt.textContent = option; + _this3.inputUnit.append(opt); + }); + this.inputUnit.addEventListener('change', function () { + _this3.hiddenInput.value = _this3.inputValue.value + _this3.inputUnit.value; + }); + return this.inputUnit; + } + }, { + key: "getBorderIndividualInputsWrapper", + value: function getBorderIndividualInputsWrapper() { + this.borderIndividualInputsWrapper = document.createElement('div'); + this.borderIndividualInputsWrapper.classList.add('frm-border-individual-inputs-wrapper'); + if (!_classPrivateFieldGet(_usesMultipleValues, this)) { + this.borderIndividualInputsWrapper.classList.add('frm_hidden'); + } + this.borderIndividualInputsWrapper.append(this.getBorderInputTop(), this.getBorderInputRight(), this.getBorderInputLeft(), this.getBorderInputBottom()); + return this.borderIndividualInputsWrapper; + } + }, { + key: "getBorderInputTop", + value: function getBorderInputTop() { + var _this4 = this; + var defaultValues = this.parseDefaultValues(); + var span = document.createElement('span'); + span.classList.add('frm-border-input-top'); + this.borderInputTop = document.createElement('input'); + this.borderInputTop.type = 'text'; + this.borderInputTop.id = "".concat(this.componentId, "-top"); + this.borderInputTop.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Top border radius', 'formidable')); + this.borderInputTop.value = parseInt(defaultValues.top.value); + span.append(this.borderInputTop); + this.borderInputTop.addEventListener('change', function () { + return _this4.buildBorderRadiusIndividualValue(); + }); + return span; + } + }, { + key: "getBorderInputBottom", + value: function getBorderInputBottom() { + var _this5 = this; + var defaultValues = this.parseDefaultValues(); + var span = document.createElement('span'); + span.classList.add('frm-border-input-bottom'); + this.borderInputBottom = document.createElement('input'); + this.borderInputBottom.type = 'text'; + this.borderInputBottom.id = "".concat(this.componentId, "-bottom"); + this.borderInputBottom.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Bottom border radius', 'formidable')); + this.borderInputBottom.value = parseInt(defaultValues.bottom.value); + span.append(this.borderInputBottom); + this.borderInputBottom.addEventListener('change', function () { + return _this5.buildBorderRadiusIndividualValue(); + }); + return span; + } + }, { + key: "getBorderInputLeft", + value: function getBorderInputLeft() { + var _this6 = this; + var defaultValues = this.parseDefaultValues(); + var span = document.createElement('span'); + span.classList.add('frm-border-input-left'); + this.borderInputLeft = document.createElement('input'); + this.borderInputLeft.type = 'text'; + this.borderInputLeft.id = "".concat(this.componentId, "-left"); + this.borderInputLeft.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Left border radius', 'formidable')); + this.borderInputLeft.value = parseInt(defaultValues.left.value); + span.append(this.borderInputLeft); + this.borderInputLeft.addEventListener('change', function () { + return _this6.buildBorderRadiusIndividualValue(); + }); + return span; + } + }, { + key: "getBorderInputRight", + value: function getBorderInputRight() { + var _this7 = this; + var defaultValues = this.parseDefaultValues(); + var span = document.createElement('span'); + span.classList.add('frm-border-input-right'); + this.borderInputRight = document.createElement('input'); + this.borderInputRight.type = 'text'; + this.borderInputRight.id = "".concat(this.componentId, "-right"); + this.borderInputRight.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Right border radius', 'formidable')); + this.borderInputRight.value = parseInt(defaultValues.right.value); + span.append(this.borderInputRight); + this.borderInputRight.addEventListener('change', function () { + return _this7.buildBorderRadiusIndividualValue(); + }); + return span; + } + }, { + key: "buildBorderRadiusIndividualValue", + value: function buildBorderRadiusIndividualValue() { + var unit = this.inputUnit.value; + var value = "".concat(parseInt(this.borderInputTop.value, 10)).concat(unit, " ").concat(parseInt(this.borderInputRight.value, 10)).concat(unit, " ").concat(parseInt(this.borderInputBottom.value, 10)).concat(unit, " ").concat(parseInt(this.borderInputLeft.value, 10)).concat(unit); + this.updateValue(value); + } + }, { + key: "updateValue", + value: function updateValue(value) { + this.hiddenInput.value = value; + _classPrivateFieldGet(_onChange, this).call(this, value); + } + }, { + key: "getButton", + value: function getButton() { + var _this8 = this; + this.button = document.createElement('button'); + this.button.type = 'button'; + this.button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Border Radius', 'formidable'); + if (_classPrivateFieldGet(_usesMultipleValues, this)) { + this.button.classList.add('frm-active'); + } + this.button.addEventListener('click', function () { + _this8.button.classList.toggle('frm-active'); + _this8.borderIndividualInputsWrapper.classList.toggle('frm_hidden'); + }); + return this.button; + } + }, { + key: "onChange", + set: function set(callback) { + if ('function' !== typeof callback) { + throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); + } + _classPrivateFieldSet(_onChange, this, callback); + } + }, { + key: "borderRadiusDefaultValue", + set: function set(value) { + _classPrivateFieldSet(_defaultValue, this, value); + _classPrivateFieldSet(_usesMultipleValues, this, !/^(\d+)(px|em|%)?$/.test(value) && '' !== value); + } + }], [{ + key: "parseValueUnit", + value: function parseValueUnit(valueStr) { + var match = valueStr.match(/^(\d+)(px|em|%)?$/); + if (!match) { + return { + value: 0, + unit: 'px' + }; + } + return { + value: parseInt(match[1], 10), + unit: match[2] || 'px' + }; + } + }]); +}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); +var _instanceCount = { + _: 0 +}; + +/***/ }), + +/***/ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.js": +/*!**************************************************************************************!*\ + !*** ./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.js ***! + \**************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmColorpickerComponent: () => (/* binding */ frmColorpickerComponent) +/* harmony export */ }); +/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); +/* harmony import */ var _frm_colorpicker_component_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frm-colorpicker-component.css */ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } +function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } +function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } +function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } +function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } + + +var _onChange = /*#__PURE__*/new WeakMap(); +var _defaultValue = /*#__PURE__*/new WeakMap(); +var frmColorpickerLiteComponent = /*#__PURE__*/function (_frmWebComponent) { + function frmColorpickerLiteComponent() { + var _this; + _classCallCheck(this, frmColorpickerLiteComponent); + _this = _callSuper(this, frmColorpickerLiteComponent); + _classPrivateFieldInitSpec(_this, _onChange, function () {}); + _classPrivateFieldInitSpec(_this, _defaultValue, '#ffffff'); + _this.input = document.createElement('input'); + _this.componentStyle = _frm_colorpicker_component_css__WEBPACK_IMPORTED_MODULE_1__["default"]; + _this.attachInternals(); + return _this; + } + _inherits(frmColorpickerLiteComponent, _frmWebComponent); + return _createClass(frmColorpickerLiteComponent, [{ + key: "initView", + value: function initView() { + var wrapper = document.createElement('div'); + wrapper.classList.add('frm-colorpicker-component', 'frm-colorpicker'); + wrapper.append(this.getInput()); + return wrapper; + } + }, { + key: "getInput", + value: function getInput() { + var _this2 = this; + this.input.type = 'text'; + this.input.classList.add('hex'); + if (null !== this.fieldName) { + this.input.name = this.fieldName; + } + if (null !== _classPrivateFieldGet(_defaultValue, this)) { + this.input.value = _classPrivateFieldGet(_defaultValue, this); + } + if (null !== this.componentId) { + this.input.id = this.componentId; + } + this.input.addEventListener('blur', function (event) { + return _classPrivateFieldGet(_onChange, _this2).call(_this2, event, null); + }); + return this.input; + } + }, { + key: "useShadowDom", + value: function useShadowDom() { + return false; + } + }, { + key: "afterViewInit", + value: function afterViewInit() { + var _this3 = this; + var colorPickerOptions = { + defaultColor: _classPrivateFieldGet(_defaultValue, this) + }; + if ('function' === typeof _classPrivateFieldGet(_onChange, this)) { + // Use the setTimeout when calling the callback for onChange to make sure the latest color is fetched. + colorPickerOptions.change = function (event, ui) { + return setTimeout(function () { + return _classPrivateFieldGet(_onChange, _this3).call(_this3, event, ui); + }, 20); + }; + } + jQuery(this.input).wpColorPicker(colorPickerOptions); + } + + /** + * A method to get the color value. + * + * @return {string} - The color value. + */ + }, { + key: "color", + get: function get() { + return jQuery(this.input).wpColorPicker('color'); + } + + /** + * A method to set the color value. + * + * @param {string} value - The value to set the color value for. + * @return {void} + */, + set: function set(value) { + _classPrivateFieldSet(_defaultValue, this, value); + this.input.value = value; + } + + /** + * A method to set the change event listener for the color picker component. + * + * @param {Function} callback - The callback function to call when the color picker component is changed. + * @return {void} + */ + }, { + key: "onChange", + set: function set(callback) { + if ('function' !== typeof callback) { + throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); + } + _classPrivateFieldSet(_onChange, this, callback); + } + }]); +}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); // The color picker component that may be a mixin of the color picker pro component. +_defineProperty(frmColorpickerLiteComponent, "formAssociated", true); +var frmColorpickerComponent = window.frmColorpickerProComponent ? window.frmColorpickerProComponent(frmColorpickerLiteComponent) : frmColorpickerLiteComponent; + +/***/ }), + +/***/ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.js": +/*!********************************************************************************!*\ + !*** ./js/src/web-components/frm-dropdown-component/frm-dropdown-component.js ***! + \********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmDropdownComponent: () => (/* binding */ frmDropdownComponent) +/* harmony export */ }); +/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); +/* harmony import */ var _frm_dropdown_component_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frm-dropdown-component.css */ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.css"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } +function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } +function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } +function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } +function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } + + +var _onChange = /*#__PURE__*/new WeakMap(); +var _select = /*#__PURE__*/new WeakMap(); +var frmDropdownComponent = /*#__PURE__*/function (_frmWebComponent) { + function frmDropdownComponent() { + var _this; + _classCallCheck(this, frmDropdownComponent); + _this = _callSuper(this, frmDropdownComponent); + _classPrivateFieldInitSpec(_this, _onChange, function () {}); + _classPrivateFieldInitSpec(_this, _select, document.createElement('select')); + _this.componentStyle = _frm_dropdown_component_css__WEBPACK_IMPORTED_MODULE_1__["default"]; + _this.attachInternals(); + return _this; + } + + /** + * Initializes the view. Called when the component is rendered. + * + * @return {Element} - The wrapper element. + */ + _inherits(frmDropdownComponent, _frmWebComponent); + return _createClass(frmDropdownComponent, [{ + key: "initView", + value: function initView() { + this.wrapper = document.createElement('div'); + this.wrapper.classList.add('frm-dropdown-component'); + this.wrapper.append(this.getSelect()); + return this.wrapper; + } + + /** + * Gets the select element. + * + * @return {Element} - The select element. + */ + }, { + key: "getSelect", + value: function getSelect() { + if (this.componentId) { + _classPrivateFieldGet(_select, this).id = this.componentId; + } + if (this.fieldName) { + _classPrivateFieldGet(_select, this).name = this.fieldName; + } + return _classPrivateFieldGet(_select, this); + } + + /** + * Determines if the component should use shadow DOM. The dropdown component can utilize shadow DOM as it does not require external functional dependencies. + * + * @return {boolean} - True if the component should use shadow DOM, false otherwise. + */ + }, { + key: "useShadowDom", + value: function useShadowDom() { + return true; + } + + /** + * Initializes the select options. It will retrieve the all the options from the component and create new option elements. + * + * @return {void} + */ + }, { + key: "initSelectOptions", + value: function initSelectOptions() { + var _this2 = this; + var optionsNodes = this.querySelectorAll('option'); + optionsNodes.forEach(function (option) { + var opt = document.createElement('option'); + opt.value = option.value; + opt.textContent = option.textContent; + option.remove(); + _classPrivateFieldGet(_select, _this2).append(opt); + }); + } + + /** + * Called when the component is visible in the viewport. + * + * @return {void} + */ + }, { + key: "afterViewInit", + value: function afterViewInit() { + var _this3 = this; + this.initSelectOptions(); + _classPrivateFieldGet(_select, this).addEventListener('change', function () { + _classPrivateFieldGet(_onChange, _this3).call(_this3, _classPrivateFieldGet(_select, _this3).value); + }); + } + + /** + * A method to add options dynamically to the select element. + * + * @param {Array} options - The options to add. + * @return {void} + */ + }, { + key: "addOptions", + set: function set(options) { + var _this4 = this; + options.forEach(function (option) { + var opt = document.createElement('option'); + opt.value = option.value; + opt.textContent = option.label; + opt.selected = option.selected; + _classPrivateFieldGet(_select, _this4).append(opt); + }); + } + + /** + * A method to set the disabled state of the select element. + * + * @param {boolean} value - The value to set. + * @return {void} + */ + }, { + key: "disabled", + set: function set(value) { + _classPrivateFieldGet(_select, this).disabled = value; + } + + /** + * A method to set the change event listener for the select element. + * + * @param {Function} callback - The callback function to call when the select element is changed. + * @return {void} + */ + }, { + key: "onChange", + set: function set(callback) { + if ('function' !== typeof callback) { + throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); + } + _classPrivateFieldSet(_onChange, this, callback); + } + + /** + * A method to set the selected value of the select element. + * + * @param {string} value - The value to set. + * @return {void} + */ + }, { + key: "selectedValue", + set: function set(value) { + var option = Array.from(_classPrivateFieldGet(_select, this).options).find(function (option) { + return option.value === value; + }); + if (option) { + option.selected = true; + } + } + }]); +}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); + +// A shorthand function to create a dropdown component. +_defineProperty(frmDropdownComponent, "formAssociated", true); +window.frmDropdownComponent = function (id, options, onChangeCallback) { + var dropdown = document.createElement('frm-dropdown-component'); + dropdown.id = id; + dropdown.addOptions = options; + dropdown.onChange = onChangeCallback; + return dropdown; +}; + +/***/ }), + +/***/ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.js": +/*!****************************************************************************************!*\ + !*** ./js/src/web-components/frm-range-slider-component/frm-range-slider-component.js ***! + \****************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmRangeSliderComponent: () => (/* binding */ frmRangeSliderComponent) +/* harmony export */ }); +/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); +/* harmony import */ var _settings_components_components_slider_component_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../settings-components/components/slider-component.js */ "./js/src/settings-components/components/slider-component.js"); +/* harmony import */ var _frm_range_slider_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-range-slider-component.css */ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.css"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _superPropGet(t, o, e, r) { var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } +function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } +function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } +function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } +function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } +function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } +function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } + + + + +var _onChange = /*#__PURE__*/new WeakMap(); +var _sliderDefaultValue = /*#__PURE__*/new WeakMap(); +var _sliderDefaultMultipleValues = /*#__PURE__*/new WeakMap(); +var _hasMultipleValues = /*#__PURE__*/new WeakMap(); +var _sliderAvailableUnits = /*#__PURE__*/new WeakMap(); +var _sliderMaxValue = /*#__PURE__*/new WeakMap(); +var _sliderSteps = /*#__PURE__*/new WeakMap(); +var frmRangeSliderComponent = /*#__PURE__*/function (_frmWebComponent) { + function frmRangeSliderComponent() { + var _this; + _classCallCheck(this, frmRangeSliderComponent); + _this = _callSuper(this, frmRangeSliderComponent); + _classPrivateFieldInitSpec(_this, _onChange, function () {}); + _classPrivateFieldInitSpec(_this, _sliderDefaultValue, '0px'); + _classPrivateFieldInitSpec(_this, _sliderDefaultMultipleValues, { + vertical: { + value: 0, + unit: 'px' + }, + top: { + value: 0, + unit: 'px' + }, + bottom: { + value: 0, + unit: 'px' + }, + horizontal: { + value: 0, + unit: 'px' + }, + left: { + value: 0, + unit: 'px' + }, + right: { + value: 0, + unit: 'px' + } + }); + _classPrivateFieldInitSpec(_this, _hasMultipleValues, false); + _classPrivateFieldInitSpec(_this, _sliderAvailableUnits, ['px', 'em', '%']); + _classPrivateFieldInitSpec(_this, _sliderMaxValue, 100); + _classPrivateFieldInitSpec(_this, _sliderSteps, null); + _this.componentStyle = _frm_range_slider_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; + return _this; + } + _inherits(frmRangeSliderComponent, _frmWebComponent); + return _createClass(frmRangeSliderComponent, [{ + key: "initOptions", + value: function initOptions() { + _superPropGet(frmRangeSliderComponent, "initOptions", this, 3)([]); + if (null === this.componentId) { + var _frmRangeSliderCompon; + this.componentId = "frm-range-slider-web-component-".concat(_instanceCount._ = (_frmRangeSliderCompon = _instanceCount._, ++_frmRangeSliderCompon)); + } + } + + /** + * A method to set the change event listener for the slider component. + * + * @param {Function} callback - The callback function to call when the slider component is changed. + * @return {void} + */ + }, { + key: "onChange", + set: function set(callback) { + if ('function' !== typeof callback) { + throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); + } + _classPrivateFieldSet(_onChange, this, callback); + } + + /** + * A method to set the has multiple values flag. This flag is used to determine if the slider component should display multiple values. + * + * @param {boolean} value - The value to set. + * @return {void} + */ + }, { + key: "hasMultipleValues", + set: function set(value) { + _classPrivateFieldSet(_hasMultipleValues, this, value); + } + + /** + * A method to set the default multiple values. This values are used to determine the default values for the slider component. + * + * @param {Object} value - The value to set. + * @return {void} + */ + }, { + key: "sliderDefaultMultipleValues", + set: function set(value) { + _classPrivateFieldSet(_sliderDefaultMultipleValues, this, value); + } + + /** + * A method to set the default value for the single slider component. This value is used to determine the default value for the single slider component. + * + * @param {string|number} value - The value to set. + * @return {void} + */ + }, { + key: "sliderDefaultValue", + set: function set(value) { + _classPrivateFieldSet(_sliderDefaultValue, this, String(value)); + } + + /** + * A method to set the available units for the slider component. This units are used to determine the available units for the slider component. + * + * @param {Array} value - The value to set. + * @return {void} + */ + }, { + key: "sliderAvailableUnits", + set: function set(value) { + _classPrivateFieldSet(_sliderAvailableUnits, this, value); + } + + /** + * A method to set the max value that the slider can take. + * + * @param {string|number} value - The value to set. + * @return {void} + */ + }, { + key: "sliderMaxValue", + set: function set(value) { + _classPrivateFieldSet(_sliderMaxValue, this, value.toString()); + } + }, { + key: "steps", + set: function set(value) { + _classPrivateFieldSet(_sliderSteps, this, value); + } + }, { + key: "useShadowDom", + value: function useShadowDom() { + return false; + } + }, { + key: "initView", + value: function initView() { + this.wrapper = document.createElement('div'); + this.slidersContainer = document.createElement('div'); + this.slidersContainer.classList.add('frm-sliders-container'); + this.wrapper.classList.add('frm-style-component'); + var config = { + maxValue: parseInt(this.getAttribute('data-max-value') || _classPrivateFieldGet(_sliderMaxValue, this), 10), + units: this.getAvailableUnits(), + componentClass: this.getAttribute('data-component-class') || '', + componentId: this.componentId, + fieldName: this.fieldName ? "name=\"".concat(this.fieldName, "\"") : '', + fieldValue: this.defaultValue || _classPrivateFieldGet(_sliderDefaultValue, this) + }; + if (this.hasMultipleSliderValues()) { + this.createMultipleValuesSlider(this.slidersContainer, _objectSpread(_objectSpread({}, config), {}, { + defaultValues: this.parseDefaultMultipleValues() + })); + this.wrapper.append(this.slidersContainer); + return this.wrapper; + } + this.slidersContainer.append(this.createSlider({ + maxValue: config.maxValue, + units: config.units, + value: frmRangeSliderComponent.parseValueUnit(config.fieldValue), + addHiddenInputValue: true + })); + this.wrapper.append(this.slidersContainer); + return this.wrapper; + } + + /** + * A method to get the available units for the slider component. It will checke the data-units attribute first and if it is not set, it will return the default available units. + * + * @return {Array} - The available units. + */ + }, { + key: "getAvailableUnits", + value: function getAvailableUnits() { + var attr = this.getAttribute('data-units'); + if (!attr) { + return _classPrivateFieldGet(_sliderAvailableUnits, this); + } + return attr.split(',').map(function (u) { + return u.trim(); + }); + } + + /** + * A method to parse the default values for the multiple values slider component. It will check the data-values attribute first and if it is not set, it will return the default values. + * If the values haven't been set via data-values attribute or dynamically via this._sliderDefaultMultipleValues it will return the default values. + * + * @return {Object} - The default values. + */ + }, { + key: "parseDefaultMultipleValues", + value: function parseDefaultMultipleValues() { + var valuesAttr = this.getAttribute('data-values') || _classPrivateFieldGet(_sliderDefaultMultipleValues, this); + var parts = valuesAttr.split(' '); + var getPart = function getPart(id, fallbackId) { + return parts[id] || parts[fallbackId] || '0px'; + }; + return { + vertical: frmRangeSliderComponent.parseValueUnit(getPart(0)), + top: frmRangeSliderComponent.parseValueUnit(getPart(0)), + bottom: frmRangeSliderComponent.parseValueUnit(getPart(2, 0)), + horizontal: frmRangeSliderComponent.parseValueUnit(getPart(1, 0)), + left: frmRangeSliderComponent.parseValueUnit(getPart(3, 1)), + right: frmRangeSliderComponent.parseValueUnit(getPart(1, 0)) + }; + } + + /** + * A method to parse the value and unit for the slider component. + * + * @param {string} valueStr - The value string to parse. + * @return {Object} - The value and unit object. + */ + }, { + key: "hasMultipleSliderValues", + value: + /** + * A method to check if the slider component has multiple values. It will check the data-has-multiple-values attribute first and if it is not set, it will return the default value. + * + * @return {boolean} - The has multiple values flag. + */ + function hasMultipleSliderValues() { + return this.getAttribute('data-has-multiple-values') === 'true' || _classPrivateFieldGet(_hasMultipleValues, this); + } + + /** + * A method to create the multiple values slider. + * + * @param {Element} wrapper - The wrapper element. + * @param {Object} options - The options for the slider. + * @return {void} + */ + }, { + key: "createMultipleValuesSlider", + value: function createMultipleValuesSlider(wrapper, options) { + var _this2 = this; + var maxValue = options.maxValue, + units = options.units, + componentClass = options.componentClass, + fieldValue = options.fieldValue, + defaultValues = options.defaultValues; + var groups = [{ + type: 'vertical', + displaySliders: 'top,bottom', + iconSvgId: 'frm-margin-top-bottom', + ariaLabel: 'Vertical value', + defaultValues: defaultValues.vertical + }, { + type: 'horizontal', + displaySliders: 'left,right', + iconSvgId: 'frm-margin-left-right', + ariaLabel: 'Horizontal value', + defaultValues: defaultValues.horizontal + }]; + if (componentClass) { + wrapper.className = componentClass; + } + groups.forEach(function (group) { + wrapper.append(_this2.createSliderGroup({ + type: group.type, + displaySliders: group.displaySliders, + maxValue: maxValue, + units: units, + value: group.defaultValues, + iconSvgId: group.iconSvgId, + ariaLabel: group.ariaLabel, + defaultValues: defaultValues, + addHiddenInputValue: false + })); + }); + if (fieldValue) { + wrapper.append(this.createSliderHiddenInputValue(fieldValue)); + } + } + + /** + * A method to create the hidden input value for the slider component. This hidden input value is used to store the value of the slider component. + * + * @param {string} fieldValue - The field value to set. + * @return {Element} - The hidden input value element. + */ + }, { + key: "createSliderHiddenInputValue", + value: function createSliderHiddenInputValue(fieldValue) { + var _this3 = this; + if (!fieldValue) { + return null; + } + var input = document.createElement('input'); + Object.assign(input, { + type: 'hidden', + value: fieldValue + }); + if (this.fieldName) { + input.setAttribute('name', this.fieldName); + } + if (this.componentId) { + input.id = this.componentId; + } + if (_classPrivateFieldGet(_onChange, this)) { + input.addEventListener('change', function () { + _classPrivateFieldGet(_onChange, _this3).call(_this3, input.value); + }); + } + return input; + } + + /** + * A method to create the slider group. This method is used to create the slider group. + * + * @param {Object} options - The options for the slider. + * @return {Element} - The slider group element. + */ + }, { + key: "createSliderGroup", + value: function createSliderGroup(options) { + var _this4 = this; + var slider = this.createSlider(options); + slider.classList.add('frm-group-sliders', 'frm-has-multiple-values'); + slider.setAttribute('data-display-sliders', options.displaySliders); + var slidersGroupItems = options.displaySliders.split(','); + slidersGroupItems.forEach(function (item) { + slider.append(_this4.createSlider({ + type: item, + maxValue: options.maxValue, + units: options.units, + value: options.defaultValues[item], + iconSvgId: "frm-margin-".concat(item), + ariaLabel: "".concat(item, " value"), + hidden: true, + addHiddenInputValue: false + })); + }); + return slider; + } + + /** + * A method to create the slider track. This method is used to create the slider track. + * + * @param {Object} value - The value of the slider. + * @return {Element} - The slider track element. + */ + }, { + key: "createSlider", + value: + /** + * A method to create the slider. This method is used to create the slider. + * + * @param {Object} options - The options for the slider. + * @return {Element} - The slider element. + */ + function createSlider(options) { + var type = options.type, + maxValue = options.maxValue, + units = options.units, + value = options.value, + iconSvgId = options.iconSvgId, + ariaLabel = options.ariaLabel, + hidden = options.hidden, + addHiddenInputValue = options.addHiddenInputValue; + var sliderWrapper = document.createElement('div'); + sliderWrapper.classList.add('frm-slider-component'); + sliderWrapper.setAttribute('data-max-value', maxValue.toString()); + if (hidden) { + sliderWrapper.classList.add('frm_hidden'); + } + if (type) { + sliderWrapper.setAttribute('data-type', type); + } + var flexContainer = document.createElement('div'); + flexContainer.classList.add('frm-flex-justify'); + + // Slider container + var sliderContainer = document.createElement('div'); + sliderContainer.classList.add('frm-slider-container'); + + // Icon + if (iconSvgId) { + sliderContainer.append(frmRangeSliderComponent.createSvgIcon(iconSvgId)); + } + + // Slider track + sliderContainer.append(frmRangeSliderComponent.createSliderTrack(value)); + flexContainer.append(sliderContainer); + + // Value input and unit select + var baseId = "".concat(this.componentId).concat(type ? "-".concat(type) : ''); + var valueContainer = frmRangeSliderComponent.createSliderValueAndUnitSelection(value, ariaLabel, units, baseId); + if (addHiddenInputValue) { + valueContainer.append(this.createSliderHiddenInputValue(options)); + } + flexContainer.append(valueContainer); + sliderWrapper.append(flexContainer); + return sliderWrapper; + } + }, { + key: "afterViewInit", + value: function afterViewInit() { + var defaultValues = this.hasMultipleSliderValues() ? this.parseDefaultMultipleValues() : frmRangeSliderComponent.parseValueUnit(this.defaultValue); + var options = Object.assign({ + defaultValues: defaultValues + }, { + steps: _classPrivateFieldGet(_sliderSteps, this) + }); + new _settings_components_components_slider_component_js__WEBPACK_IMPORTED_MODULE_1__["default"](this.wrapper.querySelectorAll('.frm-slider-component'), options); + } + }], [{ + key: "parseValueUnit", + value: function parseValueUnit(valueStr) { + var defaultValue = { + value: 0, + unit: 'px' + }; + if (!valueStr) { + return defaultValue; + } + var match = valueStr.match(/^(\d+)(px|em|%|\s)?$/); + if (!match) { + return defaultValue; + } + return { + value: parseInt(match[1], 10), + unit: match[2] || 'px' + }; + } + }, { + key: "createSliderTrack", + value: function createSliderTrack(value) { + var slider = document.createElement('span'); + slider.classList.add('frm-slider'); + slider.setAttribute('tabindex', '0'); + var activeTrack = document.createElement('span'); + activeTrack.classList.add('frm-slider-active-track'); + var bullet = document.createElement('span'); + bullet.classList.add('frm-slider-bullet'); + var valueLabel = document.createElement('span'); + valueLabel.classList.add('frm-slider-value-label'); + valueLabel.textContent = value.value.toString(); + bullet.append(valueLabel); + activeTrack.append(bullet); + slider.append(activeTrack); + return slider; + } + + /** + * A method to create the value and unit selection. This method is used to create the value and unit selection. + * + * @param {Object} value - The value of the slider. + * @param {string} ariaLabel - The aria label of the slider. + * @param {Array} units - The units of the slider. + * @param {string} baseId - The base ID for the form elements. + * @return {Element} - The value and unit selection element. + */ + }, { + key: "createSliderValueAndUnitSelection", + value: function createSliderValueAndUnitSelection(value, ariaLabel, units, baseId) { + var valueContainer = document.createElement('div'); + valueContainer.classList.add('frm-slider-value'); + var valueInput = document.createElement('input'); + valueInput.type = 'text'; + valueInput.value = value.value.toString(); + if (ariaLabel) { + valueInput.setAttribute('aria-label', ariaLabel); + } + var unitSelect = document.createElement('select'); + unitSelect.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_3__.__)('Value unit', 'formidable')); + if (baseId) { + valueInput.id = "".concat(baseId, "-value"); + unitSelect.id = "".concat(baseId, "-unit"); + } + units.forEach(function (unit) { + return unitSelect.append(frmRangeSliderComponent.createDropdownOption(unit, unit, value.unit === unit)); + }); + valueContainer.append(valueInput, unitSelect); + return valueContainer; + } + + /** + * A method to create the dropdown option. This method is used to create the dropdown option. + * + * @param {string} value - The value of the option. + * @param {string} label - The label of the option. + * @param {boolean} selected - Whether the option is selected. + * @return {Element} - The dropdown option element. + */ + }, { + key: "createDropdownOption", + value: function createDropdownOption(value, label) { + var selected = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + var option = document.createElement('option'); + option.value = value; + option.textContent = label; + option.selected = selected; + return option; + } + + /** + * A method to create the SVG icon. This method is used to create the SVG icon. + * + * @param {string} iconSvgId - The ID of the SVG icon. + * @return {Element} - The SVG icon element. + */ + }, { + key: "createSvgIcon", + value: function createSvgIcon(iconSvgId) { + var svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg'); + svg.classList.add('frmsvg'); + var use = document.createElementNS('http://www.w3.org/2000/svg', 'use'); + use.setAttribute('href', "#".concat(iconSvgId)); + svg.append(use); + return svg; + } + }]); +}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); +var _instanceCount = { + _: 0 +}; + +/***/ }), + +/***/ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.js": +/*!******************************************************************************************!*\ + !*** ./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.js ***! + \******************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmTabNavigatorComponent: () => (/* binding */ frmTabNavigatorComponent) +/* harmony export */ }); +/* harmony import */ var _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../components/class-tabs-navigator */ "./js/src/components/class-tabs-navigator.js"); +/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); +/* harmony import */ var _frm_tab_navigator_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-tab-navigator-component.css */ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } + + + +var frmTabNavigatorComponent = /*#__PURE__*/function (_frmWebComponent) { + function frmTabNavigatorComponent() { + var _this; + _classCallCheck(this, frmTabNavigatorComponent); + _this = _callSuper(this, frmTabNavigatorComponent); + _this.componentStyle = _frm_tab_navigator_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; + return _this; + } + + /** + * Initializes the view. + * + * @return {Element} - The wrapper element. + */ + _inherits(frmTabNavigatorComponent, _frmWebComponent); + return _createClass(frmTabNavigatorComponent, [{ + key: "initView", + value: function initView() { + this.tabs = this.querySelectorAll('.frm-tab'); + if (0 === this.tabs.length) { + return null; + } + var wrapper = document.createElement('div'); + wrapper.classList.add('frm-tabs-wrapper'); + wrapper.append(this.getTabDelimiter()); + wrapper.append(this.getTabs()); + wrapper.append(this.getTabContainer()); + return wrapper; + } + }, { + key: "afterViewInit", + value: function afterViewInit(wrapper) { + this.tabsNavigator = new _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__.frmTabsNavigator(wrapper); + } + + /** + * Gets the tab delimiter. + * + * @return {string} - The tab delimiter. + */ + }, { + key: "getTabDelimiter", + value: function getTabDelimiter() { + var delimiter = document.createElement('div'); + var underline = document.createElement('span'); + underline.classList.add('frm-tabs-active-underline'); + delimiter.className = 'frm-tabs-delimiter'; + delimiter.append(underline); + return delimiter; + } + + /** + * Gets the tab headings. + * + * @return {string} - The tab headings. + */ + }, { + key: "getTabs", + value: function getTabs() { + var _this2 = this; + var tabHeadings = document.createElement('div'); + var ul = document.createElement('ul'); + tabHeadings.className = 'frm-tabs-navs'; + tabHeadings.append(ul); + Array.from(this.tabs).forEach(function (tab, index) { + ul.append(_this2.createTabHeading(tab, index)); + }); + return tabHeadings; + } + + /** + * Gets the tab container. + * + * @return {string} - The tab container. + */ + }, { + key: "getTabContainer", + value: function getTabContainer() { + var _this3 = this; + var tabContainer = document.createElement('div'); + var slideTrack = document.createElement('div'); + tabContainer.className = 'frm-tabs-container'; + slideTrack.className = 'frm-tabs-slide-track frm-flex-box'; + tabContainer.append(slideTrack); + Array.from(this.tabs).forEach(function (tab, index) { + slideTrack.append(_this3.createTabContainer(tab, index)); + }); + return tabContainer; + } + + /** + * Creates a tab heading. + * + * @param {Element} tab - The tab element. + * @param {number} index - The index of the tab. + * @return {string} - The tab heading. + */ + }, { + key: "createTabHeading", + value: function createTabHeading(tab, index) { + var className = index === 0 ? 'frm-active' : ''; + var li = document.createElement('li'); + li.className = className; + li.innerText = tab.getAttribute('data-tab-title'); + return li; + } + + /** + * Creates a tab container. + * + * @param {Element} tab - The tab element. + * @param {number} index - The index of the tab. + * @return {string} - The tab container. + */ + }, { + key: "createTabContainer", + value: function createTabContainer(tab, index) { + var className = index === 0 ? 'frm-active' : ''; + var container = document.createElement('div'); + container.className = "frm-tab-container ".concat(className); + Array.from(tab.children).forEach(function (child) { + container.append(child); + }); + return container; + } + + /** + * Gets the tab underline. + * + * @return {Element} - The tab underline. + */ + }, { + key: "getTabUnderline", + value: function getTabUnderline() { + return this.shadowRoot.querySelector('.frm-tabs-active-underline'); + } + }, { + key: "getLabelText", + value: function getLabelText() { + return null; + } + }]); +}(_frm_web_component__WEBPACK_IMPORTED_MODULE_1__.frmWebComponent); + +/***/ }), + +/***/ "./js/src/web-components/frm-typography-component/frm-typography-component.js": +/*!************************************************************************************!*\ + !*** ./js/src/web-components/frm-typography-component/frm-typography-component.js ***! + \************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmTypographyComponent: () => (/* binding */ frmTypographyComponent) +/* harmony export */ }); +/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var _frm_typography_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-typography-component.css */ "./js/src/web-components/frm-typography-component/frm-typography-component.css"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _superPropGet(t, o, e, r) { var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } +function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } +function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } +function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } +function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } +function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } +function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } + + + +var _onChange = /*#__PURE__*/new WeakMap(); +var _defaultOptions = /*#__PURE__*/new WeakMap(); +var _unitTypeOptions = /*#__PURE__*/new WeakMap(); +var _defaultValue = /*#__PURE__*/new WeakMap(); +var frmTypographyComponent = /*#__PURE__*/function (_frmWebComponent) { + function frmTypographyComponent() { + var _this; + _classCallCheck(this, frmTypographyComponent); + _this = _callSuper(this, frmTypographyComponent); + _classPrivateFieldInitSpec(_this, _onChange, function () {}); + _classPrivateFieldInitSpec(_this, _defaultOptions, [{ + value: '21px', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Default', 'formidable') + }]); + _classPrivateFieldInitSpec(_this, _unitTypeOptions, ['px', 'em', '%']); + _classPrivateFieldInitSpec(_this, _defaultValue, '21px'); + _this.componentStyle = _frm_typography_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; + _classPrivateFieldSet(_defaultOptions, _this, [{ + value: '', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Default', 'formidable') + }, { + value: '18px', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Small', 'formidable') + }, { + value: '21px', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Regular', 'formidable') + }, { + value: '26px', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Large', 'formidable') + }, { + value: '32px', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Larger', 'formidable') + }, { + value: 'custom', + label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Custom', 'formidable') + }]); + return _this; + } + _inherits(frmTypographyComponent, _frmWebComponent); + return _createClass(frmTypographyComponent, [{ + key: "initOptions", + value: function initOptions() { + _superPropGet(frmTypographyComponent, "initOptions", this, 3)([]); + if (null === this.componentId) { + var _frmTypographyCompone; + this.componentId = "frm-typography-web-component-".concat(_instanceCount._ = (_frmTypographyCompone = _instanceCount._, ++_frmTypographyCompone)); + } + } + }, { + key: "initView", + value: function initView() { + this.wrapper = document.createElement('div'); + this.container = document.createElement('div'); + this.wrapper.classList.add('frm-typography-component', 'frm-typography'); + this.container.classList.add('frm-typography-container'); + this.container.append(this.getSelect(), this.getUnitValueWrapper(), this.getHiddenInput()); + this.wrapper.append(this.container); + return this.wrapper; + } + + /** + * A method to get the select element. + * + * @return {Element} - The select element. + */ + }, { + key: "getSelect", + value: function getSelect() { + this.select = document.createElement('select'); + this.select.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Font size', 'formidable')); + if (null !== this.componentId) { + this.select.id = this.componentId; + } + if (null !== this.fieldName) { + this.select.name = "".concat(this.fieldName, "[size]"); + } + this.getDefaultOptions(this.select); + return this.select; + } + + /** + * A method to get the default options for the select element. + * + * @param {Element} select - The select element. + * @return {void} + */ + }, { + key: "getDefaultOptions", + value: function getDefaultOptions(select) { + var _this2 = this; + _classPrivateFieldGet(_defaultOptions, this).forEach(function (option) { + var opt = document.createElement('option'); + opt.value = option.value; + opt.textContent = option.label; + opt.selected = option.value === 'custom' && frmTypographyComponent.isCustomFonSize(_classPrivateFieldGet(_defaultValue, _this2)) || option.value === _classPrivateFieldGet(_defaultValue, _this2); + select.append(opt); + }); + } + + /** + * A method to check if the value is a custom font size. + * + * @param {string} value - The value to check if it is a custom font size. + * @return {boolean} - True if the value is a custom font size, false otherwise. + */ + }, { + key: "changeSelectValue", + value: + /** + * A method to change the select value. + * + * @param {string} value - The value to change the select value for. + * @return {void} + */ + function changeSelectValue(value) { + var isCustomFonSize = frmTypographyComponent.isCustomFonSize(value); + Array.from(this.select.options).forEach(function (option) { + option.selected = option.value === 'custom' && isCustomFonSize || option.value === value; + }); + } + + /** + * A method to get the unit value wrapper element. + * + * @return {Element} - The unit value wrapper element. + */ + }, { + key: "getUnitValueWrapper", + value: function getUnitValueWrapper() { + this.unitValueWrapper = document.createElement('div'); + this.unitValueWrapper.classList.add('frm-unit-value'); + this.unitValueWrapper.append(this.getUnitValueInput()); + this.unitValueWrapper.append(this.getUnitTypeSelect()); + return this.unitValueWrapper; + } + + /** + * A method to get the unit value input element. + * + * @return {Element} - The unit value input element. + */ + }, { + key: "getUnitValueInput", + value: function getUnitValueInput() { + var _this3 = this; + this.unitValueInput = document.createElement('input'); + this.unitValueInput.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Font size value', 'formidable')); + if (null !== this.componentId) { + this.unitValueInput.id = "".concat(this.componentId, "-unit"); + } + if (null !== this.fieldName) { + this.unitValueInput.name = "".concat(this.fieldName, "[unit]"); + } + this.unitValueInput.type = 'text'; + this.unitValueInput.value = '' !== _classPrivateFieldGet(_defaultValue, this) ? "".concat(parseInt(_classPrivateFieldGet(_defaultValue, this), 10)) : ''; + this.unitValueInput.addEventListener('change', function (event) { + var value = '' !== event.target.value ? event.target.value + _this3.unitTypeSelect.value : ''; + _this3.changeSelectValue(value); + _classPrivateFieldGet(_onChange, _this3).call(_this3, value); + }); + return this.unitValueInput; + } + + /** + * A method to get the unit type select element. + * + * @return {Element} - The unit type select element. + */ + }, { + key: "getUnitTypeSelect", + value: function getUnitTypeSelect() { + var _this4 = this; + this.unitTypeSelect = document.createElement('select'); + this.unitTypeSelect.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Font size unit', 'formidable')); + if (null !== this.componentId) { + this.unitTypeSelect.id = "".concat(this.componentId, "-unit-type"); + } + if (null !== this.fieldName) { + this.unitTypeSelect.name = "".concat(this.fieldName, "[unit-type]"); + } + _classPrivateFieldGet(_unitTypeOptions, this).forEach(function (option) { + var opt = document.createElement('option'); + opt.value = option; + opt.textContent = option; + _this4.unitTypeSelect.append(opt); + }); + return this.unitTypeSelect; + } + + /** + * A method to get the hidden input element. + * + * @return {Element} - The hidden input element. + */ + }, { + key: "getHiddenInput", + value: function getHiddenInput() { + this.hiddenInput = document.createElement('input'); + this.hiddenInput.type = 'hidden'; + if (null !== this.fieldName) { + this.hiddenInput.name = "".concat(this.fieldName, "[value]"); + } + this.hiddenInput.value = _classPrivateFieldGet(_defaultValue, this); + return this.hiddenInput; + } + + /** + * A method to set the change event listener for the select element. + * + * @return {void} - The unit value. + */ + }, { + key: "afterViewInit", + value: function afterViewInit() { + var _this5 = this; + this.select.addEventListener('change', function () { + var value = frmTypographyComponent.getUnitValue(_this5.select.value); + _this5.unitValueInput.value = value.value; + _this5.hiddenInput.value = value.value + value.unit; + _classPrivateFieldGet(_onChange, _this5).call(_this5, _this5.hiddenInput.value); + _this5.unitTypeSelect.value = value.unit; + }); + } + + /** + * A method to get the unit value. + * + * @param {string} value - The value to get the unit value for. + * @return {Object} - The unit value. + */ + }, { + key: "onChange", + set: + /** + * A method to set the change event listener for the select element. + * + * @param {Function} callback - The callback function to call when the select element is changed. + * @return {void} + */ + function set(callback) { + if ('function' !== typeof callback) { + throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); + } + _classPrivateFieldSet(_onChange, this, callback); + } + + /** + * A method to set dynamically the default value for the typography component. + * + * @param {string} value - The value to set dynamically the default value for. + * @return {void} + */ + }, { + key: "typographyDefaultValue", + set: function set(value) { + _classPrivateFieldSet(_defaultValue, this, value); + } + }], [{ + key: "isCustomFonSize", + value: function isCustomFonSize(value) { + return !['', '18px', '21px', '26px', '32px'].includes(value); + } + }, { + key: "getUnitValue", + value: function getUnitValue(value) { + var defaultValue = { + value: '', + unit: '' + }; + if (!value) { + return defaultValue; + } + var match = value.match(/^([\d.]+)(px|em|%)?$/); + if (!match) { + return defaultValue; + } + return { + value: parseInt(value, 10), + unit: match[2] || 'px' + }; + } + }]); +}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); +var _instanceCount = { + _: 0 +}; + +/***/ }), + +/***/ "./js/src/web-components/frm-web-component.js": +/*!****************************************************!*\ + !*** ./js/src/web-components/frm-web-component.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmWebComponent: () => (/* binding */ frmWebComponent) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } +function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _wrapNativeSuper(t) { var r = "function" == typeof Map ? new Map() : void 0; return _wrapNativeSuper = function _wrapNativeSuper(t) { if (null === t || !_isNativeFunction(t)) return t; if ("function" != typeof t) throw new TypeError("Super expression must either be null or a function"); if (void 0 !== r) { if (r.has(t)) return r.get(t); r.set(t, Wrapper); } function Wrapper() { return _construct(t, arguments, _getPrototypeOf(this).constructor); } return Wrapper.prototype = Object.create(t.prototype, { constructor: { value: Wrapper, enumerable: !1, writable: !0, configurable: !0 } }), _setPrototypeOf(Wrapper, t); }, _wrapNativeSuper(t); } +function _construct(t, e, r) { if (_isNativeReflectConstruct()) return Reflect.construct.apply(null, arguments); var o = [null]; o.push.apply(o, e); var p = new (t.bind.apply(t, o))(); return r && _setPrototypeOf(p, r.prototype), p; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _isNativeFunction(t) { try { return -1 !== Function.toString.call(t).indexOf("[native code]"); } catch (n) { return "function" == typeof t; } } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +var frmWebComponent = /*#__PURE__*/function (_HTMLElement) { + function frmWebComponent() { + var _this; + _classCallCheck(this, frmWebComponent); + if ((this instanceof frmWebComponent ? this.constructor : void 0) === frmWebComponent) { + throw new Error('frmWebComponent is an abstract class and cannot be instantiated directly'); + } + _this = _callSuper(this, frmWebComponent); + if (_this.useShadowDom()) { + _this.attachShadow({ + mode: 'open' + }); + } + return _this; + } + _inherits(frmWebComponent, _HTMLElement); + return _createClass(frmWebComponent, [{ + key: "initOptions", + value: function initOptions() { + this.fieldName = this.getAttribute('name') || null; + this.defaultValue = this.getAttribute('value') || null; + this.componentId = this.getAttribute('id') || null; + } + }, { + key: "getLabelText", + value: function getLabelText() { + if (this._labelText) { + return this._labelText; + } + var label = this.querySelector('span.frm-component-label'); + if (null === label) { + return null; + } + return label.innerText; + } + }, { + key: "useShadowDom", + value: function useShadowDom() { + return 'false' !== this.getAttribute('data-shadow-dom'); + } + + /* + * Load the component style. + * @return string + */ + }, { + key: "loadStyle", + value: function loadStyle() { + var _frmGlobal; + var style = document.createElement('style'); + this.componentStyle = this.componentStyle.replace('--frm-plugin-url', ((_frmGlobal = frmGlobal) === null || _frmGlobal === void 0 ? void 0 : _frmGlobal.url) || ''); + style.textContent += this.componentStyle; + return style; + } + }, { + key: "getWrapper", + value: function getWrapper() { + return this.useShadowDom() ? this.shadowRoot : this; + } + + /* + * Render the component inside the shadow root. + * @return void + */ + }, { + key: "render", + value: function render() { + var _this2 = this; + var view = this.initView(); + if (!view) { + return; + } + var wrapper = this.getWrapper(); + wrapper.innerHTML = ''; + view.classList.add('frm-component'); + wrapper.append.apply(wrapper, _toConsumableArray(this.getViewItems(view))); + this.addLabelToView(view); + this.whenElementBecomesVisible().then(function () { + return _this2.afterViewInit(_this2); + }); + } + }, { + key: "addLabelToView", + value: function addLabelToView(view) { + var labelText = this.getLabelText(); + if (null === labelText || null === view) { + return; + } + var label = document.createElement('span'); + label.classList.add('frm-component-label'); + label.textContent = labelText; + view.prepend(label); + } + }, { + key: "getViewItems", + value: function getViewItems(view) { + return [this.loadStyle(), view].filter(function (item) { + return item !== null; + }); + } + + /** + * Waits for the element to become visible in the viewport. + * + * @return {Promise} - A promise that resolves when the element is visible. + */ + }, { + key: "whenElementBecomesVisible", + value: function whenElementBecomesVisible() { + var _this3 = this; + return new Promise(function (resolve) { + if (window.IntersectionObserver === undefined) { + requestAnimationFrame(function () { + return resolve(); + }); + return; + } + var observer = new IntersectionObserver(function (entries) { + entries.forEach(function (entry) { + // The element is in viewport and its visibility is greater than 0. + if (entry.isIntersecting && entry.intersectionRatio > 0) { + observer.disconnect(); + requestAnimationFrame(function () { + return resolve(); + }); + } + }); + }, { + threshold: 0.1 + }); + var element = _this3.useShadowDom() ? _this3.shadowRoot.host : _this3; + if (element) { + observer.observe(_this3); + } + }); + } + }, { + key: "frmLabel", + set: function set(text) { + this._labelText = text; + } + + /** + * After the view is initialized and the element/wrapper is visible in the viewport. + * + * @param {Element} wrapper - The wrapper element. + */ + }, { + key: "afterViewInit", + value: function afterViewInit(wrapper) { + // Override in child class. + } + + /** + * Constructs the view in the DOM. + * return {Element} - The wrapper element. + */ + }, { + key: "initView", + value: function initView() { + // Override in child class. + } + + /* + * Called by browser when the component is rendered to the DOM. + * @return void + */ + }, { + key: "connectedCallback", + value: function connectedCallback() { + this.initOptions(); + this.render(); + } + + /* + * Called by browser when the component is removed from the DOM. + * @return void + */ + }, { + key: "disconnectedCallback", + value: function disconnectedCallback() {} + }]); +}(/*#__PURE__*/_wrapNativeSuper(HTMLElement)); + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.css": +/*!*******************************************************************************************!*\ + !*** ./js/src/web-components/frm-border-radius-component/frm-border-radius-component.css ***! + \*******************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!********************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-border-radius-component/frm-border-radius-component.scss ***!\n \\********************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-border-radius-component .frm-border-radius-container {\n width: 100%;\n display: flex;\n justify-content: space-between;\n flex-wrap: wrap;\n}\n.frm-border-radius-component .frm-border-radius-container button {\n overflow: hidden;\n text-indent: -9999px;\n cursor: pointer;\n width: 36px;\n height: 36px;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n background: white;\n display: flex;\n justify-content: center;\n align-items: center;\n box-sizing: border-box;\n background: url('data:image/svg+xml,') no-repeat center center;\n background-size: 20px;\n}\n.frm-border-radius-component .frm-border-radius-container button.frm-active, .frm-border-radius-component .frm-border-radius-container button:hover {\n background-color: rgba(0, 0, 0, 0.05);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper {\n width: 100%;\n justify-content: space-between;\n flex-wrap: wrap;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden) {\n display: flex;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span {\n position: relative;\n display: block;\n overflow: hidden;\n width: calc(50% - 6px);\n height: 36px;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n margin-top: 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input {\n width: 100%;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding: 0 12px 0px 20px;\n box-sizing: border-box;\n border: none;\n text-align: right;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus {\n outline: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before {\n content: \"\";\n position: absolute;\n display: block;\n width: 12px;\n height: 12px;\n left: 12px;\n top: 0;\n bottom: 0;\n right: auto;\n margin: auto;\n background: url('data:image/svg+xml,') center center no-repeat;\n background-size: 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before {\n transform: rotate(180deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before {\n transform: rotate(0deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before {\n transform: rotate(90deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before {\n transform: rotate(-90deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper {\n width: calc(100% - 36px - 12px);\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n overflow: hidden;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper > * {\n border: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input {\n width: calc(100% - 44px);\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 12px;\n box-sizing: border-box;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus {\n outline: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select {\n text-align: right;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 44px;\n background: url(\"../../images/style/small-arrow.svg\") no-repeat;\n background-position: center right 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus {\n outline: none;\n}\n\n/*# sourceMappingURL=frm-border-radius-component.css.map*/"); + +/***/ }), + +/***/ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css": +/*!***************************************************************************************!*\ + !*** ./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css ***! + \***************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!****************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.scss ***!\n \\****************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-colorpicker-component .wp-picker-container button[type=button] {\n position: relative;\n height: 36px !important;\n background-image: none !important;\n background-color: #fff !important;\n overflow: hidden;\n}\n.frm-colorpicker-component .wp-picker-container button[type=button]:after {\n content: \"\";\n width: 20px;\n height: 20px;\n display: block;\n position: absolute;\n top: 0;\n right: 8px;\n bottom: 0;\n margin: auto;\n background: url(\"--frm-plugin-url/images/style/small-arrow.svg\") no-repeat;\n background-position: center;\n z-index: 10;\n}\n.frm-colorpicker-component .wp-picker-container button[type=button]:focus {\n border-color: var(--primary-500) !important;\n}\n.frm-colorpicker-component .wp-color-result-text {\n line-height: 36px !important;\n padding: 0 12px;\n border: 0;\n}\n.frm-colorpicker-component .color-alpha {\n width: 20px !important;\n height: 20px !important;\n border-radius: 50% !important;\n border: 1px solid rgb(208, 213, 221);\n top: 0;\n left: 0;\n bottom: 0;\n margin: auto;\n margin-left: 12px;\n}\n.frm-colorpicker-component .wp-picker-input-wrap input {\n width: calc(100% - 10px) !important;\n margin: 1px 5px;\n height: 32px;\n line-height: 32px;\n}\n\n/*# sourceMappingURL=frm-colorpicker-component.css.map*/"); + +/***/ }), + +/***/ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.css": +/*!*********************************************************************************!*\ + !*** ./js/src/web-components/frm-dropdown-component/frm-dropdown-component.css ***! + \*********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!**********************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-dropdown-component/frm-dropdown-component.scss ***!\n \\**********************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-dropdown-component select {\n width: 100%;\n outline: 0;\n box-shadow: var(--box-shadow-xs);\n border-radius: var(--small-radius);\n padding: 5px var(--gap-lg) 5px 14px;\n border-color: var(--grey-300);\n color: var(--grey-800);\n font-size: var(--text-md);\n margin: 0;\n line-height: var(--leading);\n border-width: 1px;\n border-style: solid;\n background-position: center 5px;\n background: transparent url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E\") no-repeat right 8px top 50%;\n background-color: #fff;\n appearance: none;\n -webkit-appearance: none;\n -moz-appearance: none;\n}\n.frm-dropdown-component select:focus {\n border-color: var(--primary-500);\n box-shadow: none;\n}\n\n/*# sourceMappingURL=frm-dropdown-component.css.map*/"); + +/***/ }), + +/***/ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.css": +/*!*****************************************************************************************!*\ + !*** ./js/src/web-components/frm-range-slider-component/frm-range-slider-component.css ***! + \*****************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!******************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-range-slider-component/frm-range-slider-component.scss ***!\n \\******************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Sliders component styles\n */\n.frm-style-component .frm-slider-container {\n width: calc(100% - 91px);\n display: flex;\n align-items: center;\n color: rgb(29, 41, 57);\n}\n.frm-style-component .frm-slider-container svg.frmsvg {\n color: currentColor;\n margin-right: 8px;\n margin-left: -5px;\n position: relative;\n z-index: 15;\n}\n\n.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover {\n color: rgb(65, 153, 253);\n cursor: pointer;\n}\n\n.frm-style-component .frm-slider-container .frm-slider-active-track {\n display: block;\n height: 100%;\n width: 0;\n position: relative;\n border-radius: 200px;\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track,\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet {\n background: rgb(65, 153, 253);\n box-shadow: 0 1.88px 4px -1px rgba(16, 24, 40, 0.03), 0 6px 8px -2px rgba(16, 24, 40, 0.08);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet {\n position: absolute;\n display: block;\n width: 16px;\n height: 16px;\n border-radius: 50%;\n transform: translateX(15px);\n cursor: grab;\n right: 0;\n top: 0;\n bottom: 0;\n margin: auto;\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label {\n position: absolute;\n display: block;\n width: 48px;\n height: 36px;\n background: rgb(16, 24, 40);\n color: white;\n font-weight: 400;\n font-size: var(--text-sm);\n line-height: 36px;\n border-radius: var(--small-radius);\n transform: translate(-18px, -42px) scale3d(0.7, 1, 1);\n opacity: 0;\n z-index: -2;\n pointer-events: none;\n text-align: center;\n user-select: none;\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label {\n z-index: 12;\n transform: translate(-18px, -42px) scale3d(1, 1, 1);\n opacity: 1;\n transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before {\n content: \"\";\n display: block;\n position: absolute;\n width: 18px;\n height: 18px;\n border-radius: 50%;\n left: 0;\n top: 0;\n transform: translate(-5px, -5px) scale3d(0.7, 0.7, 1);\n border: 4px solid rgb(65, 153, 253);\n opacity: 0;\n transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before {\n opacity: 0.5;\n transform: translate(-5px, -5px) scale3d(1, 1, 1);\n transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after {\n content: \"\";\n position: absolute;\n display: block;\n width: 180%;\n height: 200%;\n border-radius: 50%;\n left: 0;\n top: 0;\n transform: translate(-24%, -24%);\n}\n\n.frm-style-component .frm-slider-value {\n width: 86px;\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n}\n.frm-style-component .frm-slider-value > * {\n border: none;\n}\n.frm-style-component .frm-slider-value input {\n width: 40px;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 12px;\n box-sizing: border-box;\n}\n.frm-style-component .frm-slider-value select {\n text-align: right;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 44px;\n background: url(\"../../images/style/small-arrow.svg\") no-repeat;\n background-position: center right 12px;\n padding-right: 24px !important;\n}\n.frm-style-component .frm-slider-value select.frm-single-unit {\n pointer-events: none;\n background-image: none;\n padding-right: 12px !important;\n}\n.frm-style-component .frm-slider {\n display: block;\n width: calc(100% - 5px);\n height: 4px;\n background: rgb(234, 236, 240);\n border-radius: 200px;\n cursor: pointer;\n}\n\n.frm-slider-component .frm-independent-slider-field {\n margin-top: 10px;\n}\n.frm-slider-component.frm-disabled .frm-slider-container {\n pointer-events: none;\n opacity: 0.5;\n}\n.frm-slider-component.frm-disabled .frm-slider-value input[type=text] {\n width: 28px;\n}\n.frm-slider-component.frm-disabled .frm-slider-value select {\n width: 56px;\n}\n.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text] {\n width: 56px;\n}\n.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select {\n width: 28px;\n}\n\n.frm-style-component .frm-slider-component.frm-has-multiple-values {\n margin-bottom: 10px;\n}\n\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-component .frmsvg {\n width: 18px;\n height: 18px;\n}\n.frm-component .frm-sliders-container {\n width: 100%;\n}\n.frm-component .frm-group-sliders .frm-slider-component {\n margin-top: 5px;\n}\n\n/*# sourceMappingURL=frm-range-slider-component.css.map*/"); + +/***/ }), + +/***/ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css": +/*!*******************************************************************************************!*\ + !*** ./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css ***! + \*******************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!********************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.scss ***!\n \\********************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-tabs-wrapper {\n position: relative;\n overflow: hidden;\n}\n.frm-tabs-wrapper .frm-tabs-navigator {\n margin: 0;\n padding: 0;\n display: flex;\n gap: var(--gap-xs);\n justify-content: space-between;\n align-items: center;\n background: rgb(242, 244, 247);\n border-radius: var(--small-radius);\n box-sizing: border-box;\n height: 44px;\n position: relative;\n z-index: 2;\n}\n.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item {\n flex: 1;\n text-align: center;\n cursor: pointer;\n}\n.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background {\n display: block;\n height: 100%;\n background: white;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 1;\n}\n\n.frm-tabs-navs {\n padding: 0;\n min-height: 44px;\n}\n.frm-tabs-navs ul {\n margin: 0;\n height: var(--h-md);\n position: relative;\n display: flex;\n justify-content: space-between;\n list-style-type: none;\n padding: 0px;\n}\n.frm-tabs-navs ul li,\n.frm-tabs-navs ul li a {\n color: var(--grey-500);\n font-weight: 500;\n font-size: var(--text-sm);\n line-height: 28px;\n}\n.frm-tabs-navs ul li {\n flex: 1;\n height: 28px;\n text-align: center;\n margin-top: var(--gap-xs);\n margin-bottom: 0;\n cursor: pointer;\n}\n\n.frm-tabs-navs ul li.frm-active, .frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a {\n color: var(--grey-900);\n}\n\n.frm-tabs-navs ul li:first-child {\n margin-left: var(--gap-xs);\n}\n\n.frm-tabs-navs ul li:last-child {\n margin-right: var(--gap-xs);\n}\n\n.frm-tabs-delimiter {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n background: rgb(242, 244, 247);\n height: 44px;\n margin: 0;\n border-radius: var(--small-radius);\n}\n.frm-tabs-delimiter .frm-tabs-active-underline {\n height: 28px;\n background: white;\n position: absolute;\n left: 0;\n bottom: 8px;\n transition: 0.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n border-radius: var(--small-radius);\n box-shadow: var(--button-shadow);\n display: none;\n}\n\n.frm-tabs-container {\n position: relative;\n overflow: hidden;\n margin-top: var(--gap-md);\n height: 100%;\n}\n\n.frm-tabs-container .frm-tabs-slide-track {\n display: flex;\n transition: 0.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.frm-tabs-slide-track > div {\n flex: 0 0 100%;\n opacity: 0;\n transition: 0.25s opacity linear;\n position: relative;\n height: auto;\n max-height: unset;\n overflow: hidden;\n box-sizing: border-box;\n}\n\n.frm-tabs-slide-track > div > div {\n overflow: auto;\n position: relative;\n width: 100%;\n padding: 0;\n box-sizing: border-box;\n}\n\n.frm-tabs-slide-track > div > div:first-child {\n height: 100%;\n}\n\n.frm-tabs-slide-track > div.frm-active {\n opacity: 1;\n transition: 0.35s opacity linear;\n}\n\n/*# sourceMappingURL=frm-tab-navigator-component.css.map*/"); + +/***/ }), + +/***/ "./js/src/web-components/frm-typography-component/frm-typography-component.css": +/*!*************************************************************************************!*\ + !*** ./js/src/web-components/frm-typography-component/frm-typography-component.css ***! + \*************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!**************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-typography-component/frm-typography-component.scss ***!\n \\**************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-typography-component .frm-typography-container {\n display: flex;\n justify-content: space-between;\n width: 100%;\n}\n.frm-typography-component .frm-typography-container select {\n width: calc(70% - 6px);\n outline: 0;\n box-shadow: var(--box-shadow-xs);\n border-radius: var(--small-radius);\n padding: 5px 14px;\n border-color: var(--grey-300);\n color: var(--grey-800);\n font-size: var(--text-md);\n margin: 0;\n background-color: #fff;\n line-height: var(--leading);\n border-width: 1px;\n border-style: solid;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value {\n width: 28%;\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n overflow: hidden;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value > * {\n border: none;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value input {\n width: 32px;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 8px;\n box-sizing: border-box;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value input:focus {\n outline: none;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value select {\n text-align: left;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 36px;\n background: url(\"../../images/style/small-arrow.svg\") no-repeat;\n background-position: center right 12px;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value select:focus {\n outline: none;\n}\n\n/*# sourceMappingURL=frm-typography-component.css.map*/"); + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. +(() => { +"use strict"; +/*!****************************************!*\ + !*** ./js/src/web-components/index.js ***! + \****************************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _frm_tab_navigator_component_frm_tab_navigator_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frm-tab-navigator-component/frm-tab-navigator-component */ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.js"); +/* harmony import */ var _frm_colorpicker_component_frm_colorpicker_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frm-colorpicker-component/frm-colorpicker-component */ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.js"); +/* harmony import */ var _frm_range_slider_component_frm_range_slider_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-range-slider-component/frm-range-slider-component */ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.js"); +/* harmony import */ var _frm_dropdown_component_frm_dropdown_component__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./frm-dropdown-component/frm-dropdown-component */ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.js"); +/* harmony import */ var _frm_typography_component_frm_typography_component__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./frm-typography-component/frm-typography-component */ "./js/src/web-components/frm-typography-component/frm-typography-component.js"); +/* harmony import */ var _frm_border_radius_component_frm_border_radius_component__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./frm-border-radius-component/frm-border-radius-component */ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.js"); + + + + + + +customElements.define('frm-tab-navigator-component', _frm_tab_navigator_component_frm_tab_navigator_component__WEBPACK_IMPORTED_MODULE_0__.frmTabNavigatorComponent); +customElements.define('frm-colorpicker-component', _frm_colorpicker_component_frm_colorpicker_component__WEBPACK_IMPORTED_MODULE_1__.frmColorpickerComponent); +customElements.define('frm-range-slider-component', _frm_range_slider_component_frm_range_slider_component__WEBPACK_IMPORTED_MODULE_2__.frmRangeSliderComponent); +customElements.define('frm-dropdown-component', _frm_dropdown_component_frm_dropdown_component__WEBPACK_IMPORTED_MODULE_3__.frmDropdownComponent); +customElements.define('frm-typography-component', _frm_typography_component_frm_typography_component__WEBPACK_IMPORTED_MODULE_4__.frmTypographyComponent); +customElements.define('frm-border-radius-component', _frm_border_radius_component_frm_border_radius_component__WEBPACK_IMPORTED_MODULE_5__.frmBorderRadiusComponent); +})(); + +/******/ })() +; +//# sourceMappingURL=formidable-web-components.js.map \ No newline at end of file diff --git a/js/formidable_admin.js b/js/formidable_admin.js index 6fc69e80f0..dbaa0bdc98 100644 --- a/js/formidable_admin.js +++ b/js/formidable_admin.js @@ -1 +1,13300 @@ -(()=>{var e={65:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(8793),o=r(1323);function i(e){var t=(0,n.A)(e);return function(e){return(0,o.A)(t,e)}}},1323:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n={"!":function(e){return!e},"*":function(e,t){return e*t},"/":function(e,t){return e/t},"%":function(e,t){return e%t},"+":function(e,t){return e+t},"-":function(e,t){return e-t},"<":function(e,t){return e":function(e,t){return e>t},">=":function(e,t){return e>=t},"==":function(e,t){return e===t},"!=":function(e,t){return e!==t},"&&":function(e,t){return e&&t},"||":function(e,t){return e||t},"?:":function(e,t,r){if(e)throw t;return r}};function o(e,t){var r,o,i,a,l,s,c=[];for(r=0;r{"use strict";r.d(t,{A:()=>o});var n=r(65);function o(e){var t=(0,n.A)(e);return function(e){return+t({n:e})}}},8793:(e,t,r)=>{"use strict";var n,o,i,a;function l(e){for(var t,r,l,s,c=[],d=[];t=e.match(a);){for(r=t[0],(l=e.substr(0,t.index).trim())&&c.push(l);s=d.pop();){if(i[r]){if(i[r][0]===s){r=i[r][1]||r;break}}else if(o.indexOf(s)>=0||n[s]l}),n={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},o=["(","?"],i={")":["("],":":["?","?:"]},a=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/},7521:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(6956),o=r(7395);const i=function(e,t){return function(r,i,a){var l=arguments.length>3&&void 0!==arguments[3]?arguments[3]:10,s=e[t];if((0,o.A)(r)&&(0,n.A)(i))if("function"==typeof a)if("number"==typeof l){var c={callback:a,priority:l,namespace:i};if(s[r]){var d,f=s[r].handlers;for(d=f.length;d>0&&!(l>=f[d-1].priority);d--);d===f.length?f[d]=c:f.splice(d,0,c),s.__current.forEach(function(e){e.name===r&&e.currentIndex>=d&&e.currentIndex++})}else s[r]={handlers:[c],runs:0};"hookAdded"!==r&&e.doAction("hookAdded",r,i,a,l)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}}},11:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(){var r,n,o=e[t];return null!==(r=null===(n=o.__current[o.__current.length-1])||void 0===n?void 0:n.name)&&void 0!==r?r:null}}},5375:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(7395);const o=function(e,t){return function(r){var o=e[t];if((0,n.A)(r))return o[r]&&o[r].runs?o[r].runs:0}}},3561:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r){var n=e[t];return void 0===r?void 0!==n.__current[0]:!!n.__current[0]&&r===n.__current[0].name}}},8830:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r,n){var o=e[t];return void 0!==n?r in o&&o[r].handlers.some(function(e){return e.namespace===n}):r in o}}},7765:(e,t,r)=>{"use strict";r.d(t,{A:()=>u});var n=r(3029),o=r(7521),i=r(4194),a=r(8830),l=r(6763),s=r(11),c=r(3561),d=r(5375),f=function e(){(0,n.A)(this,e),this.actions=Object.create(null),this.actions.__current=[],this.filters=Object.create(null),this.filters.__current=[],this.addAction=(0,o.A)(this,"actions"),this.addFilter=(0,o.A)(this,"filters"),this.removeAction=(0,i.A)(this,"actions"),this.removeFilter=(0,i.A)(this,"filters"),this.hasAction=(0,a.A)(this,"actions"),this.hasFilter=(0,a.A)(this,"filters"),this.removeAllActions=(0,i.A)(this,"actions",!0),this.removeAllFilters=(0,i.A)(this,"filters",!0),this.doAction=(0,l.A)(this,"actions"),this.applyFilters=(0,l.A)(this,"filters",!0),this.currentAction=(0,s.A)(this,"actions"),this.currentFilter=(0,s.A)(this,"filters"),this.doingAction=(0,c.A)(this,"actions"),this.doingFilter=(0,c.A)(this,"filters"),this.didAction=(0,d.A)(this,"actions"),this.didFilter=(0,d.A)(this,"filters")};const u=function(){return new f}},4194:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(6956),o=r(7395);const i=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(i,a){var l=e[t];if((0,o.A)(i)&&(r||(0,n.A)(a))){if(!l[i])return 0;var s=0;if(r)s=l[i].handlers.length,l[i]={runs:l[i].runs,handlers:[]};else for(var c=l[i].handlers,d=function(e){c[e].namespace===a&&(c.splice(e,1),s++,l.__current.forEach(function(t){t.name===i&&t.currentIndex>=e&&t.currentIndex--}))},f=c.length-1;f>=0;f--)d(f);return"hookRemoved"!==i&&e.doAction("hookRemoved",i,a),s}}}},6763:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var o=e[t];o[n]||(o[n]={handlers:[],runs:0}),o[n].runs++;for(var i=o[n].handlers,a=arguments.length,l=new Array(a>1?a-1:0),s=1;s{"use strict";r.d(t,{se:()=>n});var n=(0,r(7765).A)();n.addAction,n.addFilter,n.removeAction,n.removeFilter,n.hasAction,n.hasFilter,n.removeAllActions,n.removeAllFilters,n.doAction,n.applyFilters,n.currentAction,n.currentFilter,n.doingAction,n.doingFilter,n.didAction,n.didFilter,n.actions,n.filters},7395:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The hook name must be a non-empty string."),!1):/^__/.test(e)?(console.error("The hook name cannot begin with `__`."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(e)||(console.error("The hook name can only contain numbers, letters, dashes, periods and underscores."),!1)}},6956:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The namespace must be a non-empty string."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(e)||(console.error("The namespace can only contain numbers, letters, dashes, periods, underscores and slashes."),!1)}},772:(e,t,r)=>{"use strict";r.d(t,{h:()=>c});var n=r(4467),o=r(5397);function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,n)}return r}function a(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:"default";n.data[t]=a(a(a({},l),n.data[t]),e),n.data[t][""]=a(a({},l[""]),n.data[t][""])},f=function(e,t){d(e,t),c()},u=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",t=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;return n.data[e]||d(void 0,e),n.dcnpgettext(e,t,r,o,i)},m=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},_=function(e,t,n){var o=u(n,t,e);return r?(o=r.applyFilters("i18n.gettext_with_context",o,e,t,n),r.applyFilters("i18n.gettext_with_context_"+m(n),o,e,t,n)):o};if(e&&f(e,t),r){var p=function(e){s.test(e)&&c()};r.addAction("hookAdded","core/i18n",p),r.addAction("hookRemoved","core/i18n",p)}return{getLocaleData:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[e]},setLocaleData:f,resetLocaleData:function(e,t){n.data={},n.pluralForms={},f(e,t)},subscribe:function(e){return i.add(e),function(){return i.delete(e)}},__:function(e,t){var n=u(t,void 0,e);return r?(n=r.applyFilters("i18n.gettext",n,e,t),r.applyFilters("i18n.gettext_"+m(t),n,e,t)):n},_x:_,_n:function(e,t,n,o){var i=u(o,void 0,e,t,n);return r?(i=r.applyFilters("i18n.ngettext",i,e,t,n,o),r.applyFilters("i18n.ngettext_"+m(o),i,e,t,n,o)):i},_nx:function(e,t,n,o,i){var a=u(i,o,e,t,n);return r?(a=r.applyFilters("i18n.ngettext_with_context",a,e,t,n,o,i),r.applyFilters("i18n.ngettext_with_context_"+m(i),a,e,t,n,o,i)):a},isRTL:function(){return"rtl"===_("ltr","text direction")},hasTranslation:function(e,t,o){var i,a,l=t?t+""+e:e,s=!(null===(i=n.data)||void 0===i||null===(a=i[null!=o?o:"default"])||void 0===a||!a[l]);return r&&(s=r.applyFilters("i18n.has_translation",s,e,t,o),s=r.applyFilters("i18n.has_translation_"+m(o),s,e,t,o)),s}}}},5839:(e,t,r)=>{"use strict";r.d(t,{__:()=>a});var n=r(772),o=r(2133),i=(0,n.h)(void 0,void 0,o.se),a=(i.getLocaleData.bind(i),i.setLocaleData.bind(i),i.resetLocaleData.bind(i),i.subscribe.bind(i),i.__.bind(i));i._x.bind(i),i._n.bind(i),i._nx.bind(i),i.isRTL.bind(i),i.hasTranslation.bind(i)},9575:(e,t,r)=>{"use strict";r.d(t,{__:()=>n.__}),r(181),r(772);var n=r(5839)},181:(e,t,r)=>{"use strict";var n=r(8616),o=r.n(n);r(7604),o()(console.error)},1105:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addonError:()=>u,afterAddonInstall:()=>f,extractErrorFromAddOnResponse:()=>d,toggleAddonState:()=>c});var n=r(9575);function o(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,i,a,l=[],s=!0,c=!1;try{if(i=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;s=!1}else for(;!(s=(n=i.call(r)).done)&&(l.push(n.value),l.length!==t);s=!0);}catch(e){c=!0,o=e}finally{try{if(!s&&null!=r.return&&(a=r.return(),Object(a)!==a))return}finally{if(c)throw o}}return l}}(e,t)||function(e,t){if(e){if("string"==typeof e)return i(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?i(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r5&&void 0!==arguments[5]?arguments[5]:"frm_activate_addon",d=frm_admin_js,f=document.querySelectorAll(".frm-addon-status");f.forEach(function(t){t.textContent=e,t.style.display="block"}),t.css({opacity:"0"}),document.querySelectorAll(".frm-oneclick").forEach(function(e){e.style.display="none"}),function(){var e=document.getElementById("frm_upgrade_modal");if(e){e.classList.add("frm-success");var t=e.querySelector(".frm-upgrade-message");if(t){var r=t.querySelector("img");t.replaceChildren((0,n.__)("Great! Everything's ready to go!","formidable"),document.createElement("br"),(0,n.__)("You just need to refresh the builder so the new field becomes available.","formidable")),r&&t.append(r)}var o=document.querySelector(".frm-addon-status");o&&(o.textContent="");var i,a=e.querySelector(".frm-circled-icon");if(a)a.classList.add("frm-circled-icon-green"),null===(i=a.querySelector("svg"))||void 0===i||i.replaceWith(s({href:"#frm_checkmark_icon"}))}}();var u={frm_activate_addon:{class:"frm-addon-active",message:d.active},frm_deactivate_addon:{class:"frm-addon-installed",message:d.installed},frm_uninstall_addon:{class:"frm-addon-not-installed",message:d.not_installed}};u.frm_install_addon=u.frm_activate_addon;var _=o(r,1)[0];_&&(_.textContent=u[c].message);var p=o(i,1)[0].parentElement;p.classList.remove("frm-addon-not-installed","frm-addon-installed","frm-addon-active"),p.classList.add(u[c].class),o(t,1)[0].classList.remove("frm_loading_button"),document.querySelectorAll(".frm-admin-page-import, #frm-admin-smtp, #frm-welcome").length>0?window.location.reload():["settings","form_builder"].includes(a)&&f.forEach(function(e){var t=null!==e.closest("#frm_upgrade_modal");e.append(function(e,t){var r,o=[m(e)];return t&&o.push(((r=document.createElement("a")).setAttribute("href","#"),r.classList.add("button","button-secondary","frm-button-secondary","dismiss"),r.textContent=(0,n.__)("Not Now","formidable"),r)),l({className:"frm-save-and-reload-options",children:o})}(a,t))})}function u(e,t,r){e.form?(jQuery(".frm-inline-error").remove(),r.closest(".frm-card").html(e.form).css({padding:5}).find("#upgrade").attr("rel",r.attr("rel")).on("click",_)):(t.append('

'.concat(e.message,"

")),r.removeClass("frm_loading_button"),jQuery(".frm-addon-error").delay(4e3).fadeOut())}function m(e){var t=document.createElement("button");return t.classList.add("frm-save-and-reload","button","button-primary","frm-button-primary"),t.textContent=(0,n.__)("Save and Reload","formidable"),t.addEventListener("click",function(){var t;"form_builder"===e?((t=document.getElementById("frm_submit_side_top")).classList.contains("frm_submit_ajax")&&t.setAttribute("data-new-addon-installed",!0),t.click()):"settings"===e&&function(){var e=document.getElementById("form_settings_page");if(e){var t=e.querySelector("form.frm_form_settings");null!==t&&(wp.hooks.doAction("frm_reset_fields_updated"),t.submit())}}()}),t}function _(e){e.preventDefault();var t=jQuery(this),r=t.parent().parent(),n=t.attr("rel");t.addClass("frm_loading_button"),jQuery.ajax({url:ajaxurl,type:"POST",async:!0,cache:!1,dataType:"json",data:{action:"frm_install_addon",nonce:frmAdminJs.nonce,plugin:n,hostname:r.find("#hostname").val(),username:r.find("#username").val(),password:r.find("#password").val()},success:function(e){var n,o,i=d(e=null!==(n=null===(o=e)||void 0===o?void 0:o.data)&&void 0!==n?n:e);i?u(i,r,t):f(e,t,message,r)},error:function(){t.removeClass("frm_loading_button")}})}},4260:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addOneClick:()=>i,initModal:()=>a,initUpgradeModal:()=>l});var n=r(9575),o=frmDom.svg;function i(e,t,r){var i;if("modal"===t)i=document.getElementById("frm_upgrade_modal");else{if("tab"!==t)return;i=document.getElementById(e.getAttribute("href").substr(1))}var a,l=i.querySelector(".frm-oneclick"),s=i.querySelector(".frm-upgrade-message"),c=i.querySelector(".frm-upgrade-link"),d=i.querySelector(".frm-oneclick-button"),f=i.querySelector(".frm-addon-status"),u=e.getAttribute("data-oneclick"),m=e.getAttribute("data-message"),_="block",p="block",g="none",y=i.querySelector(".frm-circled-icon");y&&(y.classList.remove("frm-circled-icon-green"),null===(a=y.querySelector("svg"))||void 0===a||a.replaceWith(o({href:"#frm_filled_lock_icon"})));var v=i.querySelector(".frm-learn-more");if(v&&(v.href=e.dataset.learnMore),null!==l&&null!==d&&void 0!==u&&u){null===m&&(p="none"),_="none",g="block",u=JSON.parse(u),d.className=d.className.replace(" frm-install-addon","").replace(" frm-activate-addon",""),d.className="".concat(d.className," ").concat(u.class),d.rel=u.url,l.textContent=(0,n.__)("This plugin is not activated. Would you like to activate it now?","formidable"),d.textContent=(0,n.__)("Activate","formidable");var h=e.querySelector("use");h&&(null==y||y.querySelector("svg").replaceWith(o({href:h.getAttribute("href")||h.getAttribute("xlink:href"),classList:["frm_svg32"]})))}m||(m=s.getAttribute("data-default")),void 0!==r&&(m=m.replace('',r)),s.innerHTML=m,e.dataset.upsellImage&&s.append(frmDom.img({src:e.dataset.upsellImage,alt:e.dataset.upgrade})),c.href=function(e,t){var r=e.getAttribute("data-link");return null!=r&&""!==r||(r=t.getAttribute("data-default")),r}(e,c),f.style.display="none",l&&(l.style.display=g),d&&(d.style.display="block"===g?"inline-block":g),s.style.display=p,c.style.display="block"===_?"inline-block":_;var b=c.closest(".frm-upgrade-modal-actions");b&&(b.style.display="block"===_?"flex":_)}function a(e,t){var r=jQuery(e);if(!r.length)return!1;void 0===t&&(t="552px");var n={dialogClass:"frm-dialog",modal:!0,autoOpen:!1,closeOnEscape:!0,width:t,resizable:!1,draggable:!1,open:function(){var e,t;jQuery(".ui-dialog-titlebar").addClass("frm_hidden").removeClass("ui-helper-clearfix"),jQuery("#wpwrap").addClass("frm_overlay"),jQuery(".frm-dialog").removeClass("ui-widget ui-widget-content ui-corner-all"),r.removeClass("ui-dialog-content ui-widget-content"),e=r,t=function(){e.dialog("close")},jQuery(".ui-widget-overlay").on("click",t),e.on("click","a.dismiss",t)},close:function(){jQuery("#wpwrap").removeClass("frm_overlay"),jQuery(".spinner").css("visibility","hidden"),this.removeAttribute("data-option-type");var e=document.getElementById("bulk-option-type");e&&(e.value="")}};return r.dialog(n),r}function l(){var e=a("#frm_upgrade_modal");function t(t){var r,o,a;if((r=t.target).classList){var l=r.classList.contains("frm_show_expired_modal")||null!==r.querySelector(".frm_show_expired_modal")||r.closest(".frm_show_expired_modal");if("change"===t.type&&r.classList.contains("frm_select_with_upgrade")){var s=r.options[r.selectedIndex];s&&s.dataset.upgrade&&(r=s)}if(!r.dataset.upgrade){var c=r.closest("[data-upgrade]");if(!c){if(!(c=r.closest(".frm_field_box")))return;r.dataset.upgrade=""}r=c}if(l)wp.hooks.doAction("frm_show_expired_modal",r);else{var d=r.dataset.upgrade;if(d&&!r.classList.contains("frm_show_upgrade_tab")){t.preventDefault();var f=e.get(0);f.classList.remove("frm-success");var u=f.querySelector(".frm_lock_icon");u&&(u.style.display="block",u.classList.remove("frm_lock_open_icon"),u.querySelector("use").setAttribute("href","#frm_lock_icon"));var m="frm_upgrade_modal_image",_=document.getElementById(m);_&&_.remove(),r.dataset.image&&u&&(u.style.display="none",u.parentNode.insertBefore(frmDom.img({id:m,src:"".concat(frmGlobal.url,"/images/").concat(r.dataset.image)}),u));var p=f.querySelector(".license-level");p&&(p.textContent=function(e){return e.dataset.requires?e.dataset.requires:"Pro"}(r)),i(r,"modal",d);var g=f.querySelector(".frm_are_not_installed");g.style.display=r.dataset.image||r.dataset.oneclick?"none":"inline-block",g.textContent=g.dataset.default,f.querySelector(".frm-upgrade-modal-title-prefix").style.display=r.dataset.oneclick?"inline":"none",f.querySelector(".frm_feature_label").textContent=d,f.querySelector(".frm-upgrade-modal-title-suffix").style.display="none",f.querySelector("h2").style.display="block",e.dialog("open");var y=f.querySelector(".button-primary:not(.frm-oneclick-button)");o=y.getAttribute("href").replace(/(medium=)[a-z_-]+/gi,"$1".concat(r.getAttribute("data-medium"))),null===(a=r.getAttribute("data-content"))&&(a=""),o=o.replace(/(content=)[a-z_-]+/gi,"$1".concat(a)),y.setAttribute("href",o),r.classList.contains("frm_show_update")&&function(e){var t=e.querySelector(".frm-upgrade-modal-title-prefix");t&&(t.style.display="none");var r=e.querySelector(".frm_are_not_installed");r&&(r.textContent=(0,n.__)("require an update","formidable"),r.style.display="");var o=e.querySelector(".frm-oneclick");o&&(o.style.display="none");var i=e.querySelector(".frm-oneclick-button");i&&(i.textContent=(0,n.__)("Update Now","formidable"))}(f)}}}}!1!==e&&(document.addEventListener("click",t),frmDom.util.documentOn("change","select.frm_select_with_upgrade",t))}},8616:e=>{e.exports=function(e,t){var r,n,o=0;function i(){var i,a,l=r,s=arguments.length;e:for(;l;){if(l.args.length===arguments.length){for(a=0;a{var n;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function i(e){return function(e,t){var r,n,a,l,s,c,d,f,u,m=1,_=e.length,p="";for(n=0;n<_;n++)if("string"==typeof e[n])p+=e[n];else if("object"==typeof e[n]){if((l=e[n]).keys)for(r=t[m],a=0;a=0),l.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,l.width?parseInt(l.width):0);break;case"e":r=l.precision?parseFloat(r).toExponential(l.precision):parseFloat(r).toExponential();break;case"f":r=l.precision?parseFloat(r).toFixed(l.precision):parseFloat(r);break;case"g":r=l.precision?String(Number(r.toPrecision(l.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=l.precision?r.substring(0,l.precision):r;break;case"t":r=String(!!r),r=l.precision?r.substring(0,l.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=l.precision?r.substring(0,l.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=l.precision?r.substring(0,l.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}o.json.test(l.type)?p+=r:(!o.number.test(l.type)||f&&!l.sign?u="":(u=f?"+":"-",r=r.toString().replace(o.sign,"")),c=l.pad_char?"0"===l.pad_char?"0":l.pad_char.charAt(1):" ",d=l.width-(u+r).length,s=l.width&&d>0?c.repeat(d):"",p+=l.align?u+r+s:"0"===c?u+s+r:s+u+r)}return p}(function(e){if(l[e])return l[e];for(var t,r=e,n=[],i=0;r;){if(null!==(t=o.text.exec(r)))n.push(t[0]);else if(null!==(t=o.modulo.exec(r)))n.push("%");else{if(null===(t=o.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){i|=1;var a=[],s=t[2],c=[];if(null===(c=o.key.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(c[1]);""!==(s=s.substring(c[0].length));)if(null!==(c=o.key_access.exec(s)))a.push(c[1]);else{if(null===(c=o.index_access.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(c[1])}t[2]=a}else i|=2;if(3===i)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return l[e]=n}(e),arguments)}function a(e,t){return i.apply(null,[e].concat(t||[]))}var l=Object.create(null);"undefined"!=typeof window&&(window.sprintf=i,window.vsprintf=a,void 0===(n=function(){return{sprintf:i,vsprintf:a}}.call(t,r,t,e))||(e.exports=n))}()},5397:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(1364),o={contextDelimiter:"",onMissingKey:null};function i(e,t){var r;for(r in this.data=e,this.pluralForms={},this.options={},o)this.options[r]=void 0!==t&&r in t?t[r]:o[r]}i.prototype.getPluralForm=function(e,t){var r,o,i,a=this.pluralForms[e];return a||("function"!=typeof(i=(r=this.data[e][""])["Plural-Forms"]||r["plural-forms"]||r.plural_forms)&&(o=function(e){var t,r,n;for(t=e.split(";"),r=0;r{"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}r.d(t,{A:()=>n})},4467:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(9922);function o(e,t,r){return(t=(0,n.A)(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}},2327:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(2284);function o(e,t){if("object"!=(0,n.A)(e)||!e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var o=r.call(e,t||"default");if("object"!=(0,n.A)(o))return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}},9922:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(2284),o=r(2327);function i(e){var t=(0,o.A)(e,"string");return"symbol"==(0,n.A)(t)?t:t+""}},2284:(e,t,r)=>{"use strict";function n(e){return n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(e)}r.d(t,{A:()=>n})}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var i=t[n]={exports:{}};return e[n](i,i.exports,r),i.exports}function n(e){return function(e){if(Array.isArray(e))return i(e)}(e)||function(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}(e)||o(e)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function o(e,t){if(e){if("string"==typeof e)return i(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?i(e,t):void 0}}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},window.FrmFormsConnect=window.FrmFormsConnect||function(e,t,r){var n={messageBox:null,reset:null,setElements:function(){n.messageBox=e.querySelector(".frm_pro_license_msg"),n.reset=e.getElementById("frm_reconnect_link")}},o={init:function(){n.setElements(),r(e.getElementById("frm_deauthorize_link")).on("click",o.deauthorize),r(".frm_authorize_link").on("click",o.authorize),r(".frm-dashboard-license-options").on("click","#frm_deauthorize_link",o.deauthorize),r(".frm-dashboard-license-options").on("click","#frm_reconnect_link",o.reauthorize),null!==n.reset&&r(n.reset).on("click",o.reauthorize)},authorize:function(){var t=this,n=this.getAttribute("data-plugin"),i=e.getElementById("edd_".concat(n,"_license_key")),a=i.value,l=e.getElementById("proplug-wpmu");this.classList.add("frm_loading_button"),l=l&&l.checked?1:0,r.ajax({type:"POST",url:ajaxurl,dataType:"json",data:{action:"frm_addon_activate",license:a,plugin:n,wpmu:l,nonce:frmGlobal.nonce},success:function(e){o.afterAuthorize(e,i),t.classList.remove("frm_loading_button")}})},afterAuthorize:function(e,t){!0===e.success&&(t.value="•••••••••••••••••••"),wp.hooks.doAction("frm_after_authorize",e),o.showMessage(e)},showProgress:function(e){null===n.messageBox&&n.setElements();var t=n.messageBox;null!==t&&(!0===e.success?(t.classList.remove("frm_error_style"),t.classList.add("frm_message","frm_updated_message")):(t.classList.add("frm_error_style"),t.classList.remove("frm_message","frm_updated_message")),t.classList.remove("frm_hidden"),t.innerHTML=e.message)},showMessage:function(r){null===n.messageBox&&n.setElements();var i=n.messageBox;!0===r.success&&(o.showAuthorized(!0),o.showInlineSuccess(),wp.hooks.doAction("frmAdmin.afterLicenseAuthorizeSuccess",{msg:r})),o.showProgress(r),""!==r.message&&(setTimeout(function(){i.innerHTML="",i.classList.add("frm_hidden"),i.classList.remove("frm_error_style","frm_message","frm_updated_message")},1e4),e.querySelector(".frm-admin-page-dashboard")&&setTimeout(function(){t.location.reload()},1e3))},showAuthorized:function(t){var r=t?"unauthorized":"authorized",n=t?"authorized":"unauthorized",o=e.querySelectorAll(".frm_".concat(r,"_box"));o.length&&o.forEach(function(e){e.className=e.className.replace("frm_".concat(r,"_box"),"frm_".concat(n,"_box"))})},showInlineSuccess:function(){var t=e.querySelectorAll(".frm-confirm-msg [data-success]");t.length&&t.forEach(function(e){e.innerHTML=frmAdminBuild.purifyHtml(e.getAttribute("data-success"))})},reauthorize:function(){return this.innerHTML='',r.ajax({type:"POST",url:ajaxurl,dataType:"json",data:{action:"frm_reset_cache",plugin:"formidable_pro",nonce:frmGlobal.nonce},success:function(e){n.reset.textContent=e.message,"1"===n.reset.getAttribute("data-refresh")&&t.location.reload()}}),!1},deauthorize:function(){if(!confirm(frmGlobal.deauthorize))return!1;var t=this.getAttribute("data-plugin"),n=e.getElementById("edd_".concat(t,"_license_key")),i=n.value,a=this;return this.innerHTML='',r.ajax({type:"POST",url:ajaxurl,data:{action:"frm_addon_deactivate",license:i,plugin:t,nonce:frmGlobal.nonce},success:function(){o.showAuthorized(!1),n.value="",a.replaceWith("Disconnected"),wp.hooks.doAction("frmAdmin.afterLicenseDeauthorizeSuccess",{})}}),!1}};return o}(document,window,jQuery),window.frmAdminBuildJS=function(){var e,t,i=frm_admin_js,l=frmDom,s=l.tag,c=l.div,d=l.span,f=l.a,u=l.svg,m=l.img,_=frmDom.util.onClickPreventDefault,p=frmDom.ajax.doJsonPost;i.contextualShortcodes=(t=null===(e=document.getElementById("frm_adv_info"))||void 0===e?void 0:e.dataset.contextualShortcodes)?((t=JSON.parse(t)).addressSelector="[id^=email_to], [id^=from_], [id^=cc], [id^=bcc]",t.bodySelector="[id^=email_message_]",t):[];var g,y,v,h={save:u({href:"#frm_save_icon"}),drag:u({href:"#frm_drag_icon",classList:["frm_drag_icon","frm-drag"]})},b=jQuery(document.getElementById("frm-show-fields")),j=document.getElementById("new_fields"),w=document.getElementById("form_id"),Q=!1,x=0,E=0,k=0,A={},S=0,L=wp.i18n,I=L.__,B=L.sprintf,q={dragging:!1};w&&(E=w.value);var C,N=new URL(window.location.href),T=N.searchParams,O=document.getElementById("frm_builder_page");function F(e){e.stopPropagation(),e.preventDefault(),D(this)}function D(e){var t=e.getAttribute("data-frmverify"),r=e.getAttribute("data-loaded-from");return null===t||"frm-confirmed-click"===e.id||("entries-list"===r?wp.hooks.applyFilters("frm_on_multiple_entries_delete",{link:e,initModal:Bi}):function(e){var t=Bi("#frm_confirm_modal","400px"),r=document.getElementById("frm-confirmed-click");if(!1===t)return!1;r&&(r.style.display="block");var n=e.getAttribute("data-frmverify"),o=n?e.getAttribute("data-frmverify-btn"):"",i=jQuery(".frm-confirm-msg");i.empty(),n&&(i.append(document.createTextNode(n)),o&&(null==r||r.classList.add(o)));var a=e.dataset;if(r){for(var l in r.dataset)r.removeAttribute("data-".concat(l));for(var s in a)"frmverify"!==s&&r.setAttribute("data-".concat(s),a[s])}return wp.hooks.doAction("frmAdmin.beforeOpenConfirmModal",{$info:t,link:e}),t.dialog("open"),null==r||r.setAttribute("href",e.getAttribute("href")||e.getAttribute("data-href")),!1}(e))}function M(e){var t=Bi("#frm_info_modal","400px");return!1===t||(jQuery(".frm-info-msg").html(e),t.dialog("open")),!1}function P(e){var t=this.getAttribute("data-frmtoggle"),r=this.getAttribute("data-toggletext"),n=jQuery(t);return e.preventDefault(),n.toggle(),null!==r&&""!==r&&(this.setAttribute("data-toggletext",this.innerHTML),this.textContent=r),!1}function H(e){var t=this.getAttribute("data-frmhide"),r=this.getAttribute("data-frmshow"),n=this.getAttribute("data-frmuncheck"),o=n?n.split(","):[];"INPUT"!==this.nodeName||"checkbox"!==this.type||this.checked||(null!==t?(r=t,t=null):null!==r&&(t=r,r=null)),e.preventDefault();var i=this.getAttribute("data-toggleclass")||"frm_hidden";null!==t&&jQuery(t).addClass(i),null!==r&&jQuery(r).removeClass(i);var a=this.parentNode.querySelectorAll("a.current");if(null!==a){for(var l=0;l1&&(e="",t=""):0===o.indexOf("frm_postmeta_")&&(jQuery("#frm_postmeta_rows .frm_postmeta_row").length<2&&(e=".frm_add_postmeta_row.button"),jQuery(".frm_toggle_cf_opts").length&&jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(o,")")).last().length&&(""!==e&&(e+=","),e+="#".concat(jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(o,")")).last().attr("id")," .frm_toggle_cf_opts")));var i=document.getElementById(o),a=jQuery(i);return a.fadeOut(300,function(){var r;a.remove(),Po(),""!==t&&jQuery(t).hide(),""!==e&&jQuery("".concat(e," a,").concat(e)).removeClass("frm_hidden").fadeIn("slow"),this.closest(".frm_form_action_settings")&&function(e){so(e);var t={type:e};wp.hooks.doAction("frm_after_action_removed",t)}(this.closest(".frm_form_action_settings").querySelector(".frm_action_name").value),null===(r=document.querySelector(".tooltip"))||void 0===r||r.remove()}),void 0!==r&&(r=jQuery(r)).fadeOut(400,function(){r.remove()}),""!==e&&jQuery(this).closest(".frm_logic_rows").fadeOut("slow"),wp.hooks.doAction("frm_admin_tag_removed",o,i),!1}}function G(e,t){void 0===t&&(t=this),Ze(t,!1);var r=jQuery(t).closest(".frm_form_action_settings"),n=e.target;if(r.length&&void 0!==n){var o=n.parentElement.className;if("string"==typeof o&&(o.includes("frm_email_icons")||o.includes("frm_toggle")))return void e.stopPropagation()}var i=r.children(".widget-inside");if(r.length&&i.find("p, div, table").length<1){var a=r.find('input[name$="[ID]"]').val(),l=r.find('input[name$="[post_excerpt]"]').val();l&&(i.html(''),r.find(".spinner").fadeIn("slow"),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_form_action_fill",action_id:a,action_type:l,nonce:frmGlobal.nonce},success:function(e){i.html(e),ci(),Xn("#".concat(r.attr("id"))),yi(i),jQuery(t).trigger("frm-action-loaded"),wp.hooks.doAction("frm_filled_form_action",i)}}))}jQuery(t).closest(".frm_field_box").siblings().find(".widget-inside").slideUp("fast"),void 0!==t.className&&t.className.includes("widget-action")||jQuery(t).closest(".start_divider").length<1||((i=jQuery(t).closest("div.widget").children(".widget-inside")).is(":hidden")?i.slideDown("fast"):i.slideUp("fast"))}function U(){var e=this.getAttribute("href");if(void 0===e)return!1;var t=e.replace("#","."),r=jQuery(this);r.closest("li").addClass("frm-tabs active").siblings("li").removeClass("frm-tabs active starttab"),r.closest("div").children(".tabs-panel").not(e).not(t).hide();var n=document.getElementById(e.replace("#",""));return n&&(n.style.display="block"),"frm_insert_fields_tab"!==this.id||this.closest("#frm_adv_info")||$e(),!1}function W(e,t){var r=(e=jQuery(e)).attr("href");if(void 0!==r){var n,o,i=r.replace("#",".");if(e.closest("li").addClass("frm-tabs active").siblings("li").removeClass("frm-tabs active starttab"),e.closest("div").find(".tabs-panel").length)e.closest("div").children(".tabs-panel").not(r).not(i).hide();else if(null!==document.getElementById("form_global_settings")){var a=e.data("frmajax");e.closest(".frm_wrap").find(".tabs-panel, .hide_with_tabs").hide(),void 0!==a&&"1"==a&&(n=r.replace("#",""),(o=jQuery(".frm_".concat(n,"_ajax"))).length&&jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_settings_tab",tab:n.replace("_settings",""),nonce:frmGlobal.nonce},success:function(e){o.replaceWith(e)}}))}else jQuery("#frm-categorydiv .tabs-panel, .hide_with_tabs").hide();jQuery(r).show(),jQuery(i).show(),$o(),"auto"!==t&&(jQuery(".frm_updated_message").hide(),jQuery(".frm_warning_style").hide()),jQuery(e).closest("#frm_adv_info").length||(jQuery(".frm_form_settings").length?jQuery(".frm_form_settings").attr("action","?page=formidable&frm_action=settings&id=".concat(jQuery('.frm_form_settings input[name="id"]').val(),"&t=").concat(r.replace("#",""))):jQuery(".frm_settings_form").attr("action","?page=formidable-settings&t=".concat(r.replace("#",""))))}}function V(e){var t,r;document.querySelectorAll(e).forEach(function(e){$(e),Array.from(e.children).forEach(function(e){return X(e,".frm-move")});var t=jQuery(e).children('[data-type="divider"]').children(".divider_section_only");t.length&&$(t)}),t=jQuery("#frm_builder_page"),r={items:".frm_sortable_field_opts li",axis:"y",opacity:.65,forcePlaceholderSize:!1,handle:".frm-drag",helper:function(e,t){return Q=t.clone().insertAfter(t),t.clone()},stop:function(e,t){Q&&Q.remove(),on(t.item.attr("id").replace("frm_delete_field_","").replace("-".concat(t.item.data("optkey"),"_container"),"")),Po()}},jQuery(t).sortable(r)}function $(e){jQuery(e).droppable({accept:".frmbutton, li.frm_field_box",deactivate:re,over:K,out:J,tolerance:"pointer"})}function K(e,t){var r=function(e){return e.classList.contains("divider_section_only")&&(e=jQuery(e).nextAll(".start_divider.frm_sorting").get(0)),e}(e.target);if(!je(t.draggable[0],r,e))return r.classList.remove("frm-over-droppable"),void jQuery(r).parents("ul.frm_sorting").addClass("frm-over-droppable");document.querySelectorAll(".frm-over-droppable").forEach(function(e){return e.classList.remove("frm-over-droppable")}),r.classList.add("frm-over-droppable"),jQuery(r).parents("ul.frm_sorting").addClass("frm-over-droppable")}function J(e){e.target.classList.remove("frm-over-droppable")}function X(e,t){var r={helper:Y,revert:"invalid",delay:10,start:Z,stop:ee,drag:te,cursor:"grabbing",refreshPositions:!0,cursorAt:{top:0,left:90}};"string"==typeof t&&(r.handle=t),jQuery(e).draggable(r)}function Y(e){var t,r=e.delegateTarget;if(Qe(r)){var n=document.getElementById("frm-insert-fields").querySelector(".frm_ttext").cloneNode(!0);return n.querySelector("use").setAttributeNS("http://www.w3.org/1999/xlink","href","#frm_field_group_layout_icon"),n.querySelector("span").textContent=I("Field Group","formidable"),n.classList.add("frm_field_box"),n.classList.add("ui-sortable-helper"),n}if(r.classList.contains("frmbutton"))return(t=r.cloneNode(!0)).classList.add("ui-sortable-helper"),r.classList.add("frm-new-field"),t;if(r.hasAttribute("data-ftype")){var o=r.getAttribute("data-ftype");if(t=document.getElementById("frm-insert-fields").querySelector(".frm_t".concat(o)))return(t=t.cloneNode(!0)).classList.add("form-field"),t.classList.add("ui-sortable-helper"),t.cloneNode(!0)}return c({className:"frmbutton"})}function Z(e,t){if(e.target.classList.contains("frm_at_limit"))return Se(),!1;q.dragging=!0;var r,n=y;n.classList.add("frm-dragging-field"),document.body.classList.add("frm-dragging"),t.helper.addClass("frm-sortable-helper"),t.helper.initialOffset=n.scrollTop,e.target.classList.add("frm-drag-fade"),yr(),(r=document.querySelectorAll("ul.start_divider")).length&&r.forEach(function(e){[].slice.call(e.children).forEach(function(e){(0===e.children.length||1===e.children.length&&"ul"===e.firstElementChild.nodeName.toLowerCase()&&0===e.firstElementChild.children.length)&&e.remove()})}),Fe(),Ne(),z()}function ee(){y.classList.remove("frm-dragging-field"),document.body.classList.remove("frm-dragging");var e=document.querySelector(".frm-drag-fade");e&&e.classList.remove("frm-drag-fade")}function te(e,t){!function(e){v.scrollTop(function(t,r){var n=e.clientY,o=y.offsetHeight,i=e.clientY-y.offsetTop,a=i-o/2;return i>o-50&&n>5?r+.1*a:i<70&&n<130?r-Math.abs(.1*a):r})}(e);var r=e.target,n=function(){for(var e=document.getElementById("frm-show-fields");e.querySelector(".frm-over-droppable");)e=e.querySelector(".frm-over-droppable");return"frm-show-fields"!==e.id||e.classList.contains("frm-over-droppable")||(e=!1),e}(),o=document.getElementById("frm_drag_placeholder");if(je(r,n,e)){o||(o=s("li",{id:"frm_drag_placeholder",className:"sortable-placeholder"}));var i,a=t.helper.get(0);if((a.classList.contains("form-field")||a.classList.contains("frm_field_box"))&&(a.style.transform="translateY(".concat((i=t.helper,y.scrollTop-i.initialOffset),"px)")),"frm-show-fields"===n.id||n.classList.contains("start_divider"))return o.style.left=0,void function(e){var t,r=e.y,n=e.placeholder,o=jQuery(e.droppable),i=o.children().not(".edit_field_type_end_divider");if(0===i.length)o.prepend(n),t=0;else{var a=ne(o,r);if(a===i.length){var l=jQuery(i.get(a-1));t=l.offset().top+l.outerHeight(),o.append(n);var s=o.children(".edit_field_type_end_divider");s.length&&o.append(s)}else t=jQuery(i.get(a)).offset().top,jQuery(i.get(a)).before(n)}t-=o.offset().top,n.style.top="".concat(t,"px")}({droppable:n,y:e.clientY,placeholder:o});o.style.top="",function(e){var t,r=e.x,n=e.placeholder,o=jQuery(e.droppable),i=ie(o);if(i.length){var a=function(e,t){var r,n,o,i,a=ie(e);for(i=0,r=a.length-1;r>=0;--r)if(n=a.get(r),t>(o=jQuery(n).offset().left)){i=r,t>o+jQuery(n).outerWidth()/2&&(i=r+1);break}return i}(o,r);if(a===i.length){var l=jQuery(i.get(a-1));t=l.offset().left+l.outerWidth(),o.append(n)}else t=jQuery(i.get(a)).offset().left,jQuery(i.get(a)).before(n),t-=0===a?4:8;t-=o.offset().left,n.style.left="".concat(t,"px")}}({droppable:n,x:e.clientX,placeholder:o})}else o&&o.remove()}function re(e,t){if(q.dragging){q.dragging=!1;var r=t.draggable[0],n=document.getElementById("frm_drag_placeholder");if(!n)return t.helper.remove(),void g();!function(e){if(e.previousElementSibling&&e.previousElementSibling.classList.contains("frm-is-collapsed")){var t=jQuery(e).prevUntil('[data-type="break"]');if(t.length){var r=t.find(".frm-collapse-page").get(0);r&&r.click()}}}(n);var o=t.helper.parent(),i=t.helper.get(0).closest("ul.start_divider"),a=n.closest("ul.start_divider");r.classList.contains("frm-new-field")?function(e){if(pe(e))wp.hooks.doAction("frm_stopped_inserting_by_dragging",e);else{var t=document.getElementById("frm_drag_placeholder"),r="".concat(e.replace("|","-"),"_").concat(be()),n=s("li",{id:r,className:"frm-wait frmbutton_loadingnow"}),o=jQuery(n),i=de(jQuery(t)),a=fe(i),l=ue(i);t.parentNode.insertBefore(n,t),t.remove(),ae(o);var c=0;"summary"===e&&(c=jQuery(".frmbutton_loadingnow#".concat(r)).prevAll('li[data-type="break"]').length?1:0),jQuery.ajax({type:"POST",url:ajaxurl,data:_e(e,l,a,c),success:function(t){ge(t,o);var r=ye(t);r&&wp.hooks.doAction("frm_after_field_added_in_form_builder",{field:t,fieldId:r,fieldType:e,form_id:a})},error:he})}}(r.id):(function(e,t){t.parentNode.insertBefore(e,t)}(r,n),function(e){if("UL"===e.nodeName&&!e.classList.contains("start_divider")&&"frm-show-fields"!==e.id){var t=e.closest("li");t&&!t.classList.contains("ui-draggable")&&X(t,".frm-move")}}(n.parentElement));var l=i?parseInt(i.closest(".edit_field_type_divider").getAttribute("data-fid")):0,c=a?parseInt(a.closest(".edit_field_type_divider").getAttribute("data-fid")):0;n.remove(),t.helper.remove();var d=o.length?ie(o):[];!function(e,t){var r;e.length&&(t.length?ae(t.first()):(r=e.get(0).closest("li.frm_field_box"))&&!r.classList.contains("edit_field_type_divider")&&r.remove())}(o,d),function(e,t){0===t.length&&1===ie(jQuery(e.parentNode)).length||ae(jQuery(e))}(r,d),l!==c&&me(jQuery(r),i),g()}}function ne(e,t){var r,n,o,i,a=e.children().not(".edit_field_type_end_divider"),l=a.length;if(!document.querySelector(".frm-has-fields .frm_no_fields"))return 0;for(i=0,r=l-1;r>=0;--r)if(n=a.get(r),t>(o=jQuery(n).offset().top)){i=r,t>o+jQuery(n).outerHeight()/2&&(i=r+1);break}return i}function oe(){document.querySelectorAll("ul#frm-show-fields, ul.start_divider").forEach(function(e){e.childNodes.forEach(function(e){void 0!==e.classList&&(e.classList.contains("edit_field_type_end_divider")||void 0!==e.classList&&e.classList.contains("form-field")&&Ue(e))})}),kn(),document.querySelectorAll(".edit_field_type_end_divider").forEach(function(e){return e.parentNode.append(e)}),document.querySelectorAll("li.form_field_box:not(.form-field)").forEach(function(e){return!e.children.length&&e.remove()}),En();var e=new Event("frm_sync_after_drag_and_drop",{bubbles:!1});document.dispatchEvent(e)}function ie(e){var t=jQuery(),r=e.get(0);return r.children?(Array.from(r.children).forEach(function(e){if("none"!==e.style.display){var r=e.classList;!r.contains("form-field")||r.contains("edit_field_type_end_divider")||r.contains("frm-sortable-helper")||(t=t.add(e))}}),t):t}function ae(e,t){var r;void 0===t&&(t="even");var n=e.parent().children("li.form-field, li.frmbutton_loadingnow").not(".edit_field_type_end_divider"),o=n.length,i=["frm_full","frm_half","frm_third","frm_fourth","frm_sixth","frm_two_thirds","frm_three_fourths","frm1","frm2","frm3","frm4","frm5","frm6","frm7","frm8","frm9","frm10","frm11","frm12"];"even"===t&&5!==o?n.each(ce(i,$t(o))):"clear"===t?n.each(ce(i,"")):(r=["left","right","middle","even"].includes(t)?function(e){return Vt(o,t,e)}:function(e){return lr(t[e])},n.each(ce(i,r))),le(e.parent(),n.length)}function le(e,t){if(void 0!==e.offset()){var r=t>=2,n=document.getElementById("frm_field_group_controls");if(!n){if(!r)return;(n=c()).id="frm_field_group_controls",n.setAttribute("role","group"),n.setAttribute("tabindex",0),function(e){var t=document.createElement("span");t.innerHTML='';var r=I("Set Row Layout","formidable");se(t,r),zt(t,r);var n=document.createElement("span");n.innerHTML='',n.classList.add("frm-move");var o=I("Move Field Group","formidable");se(n,o),zt(n,o),e.innerHTML="",e.append(t),e.append(n),e.append(function(){var e=d({className:"dropdown"}),t=f({className:"frm_bstooltip frm-hover-icon frm-dropdown-toggle dropdown-toggle",children:[d({child:u({href:"#frm_thick_more_vert_icon"})}),d({className:"screen-reader-text",text:I("Toggle More Options Dropdown","formidable")})]});frmDom.setAttributes(t,{title:I("More Options","formidable"),"data-bs-toggle":"dropdown","data-bs-container":"body","data-bs-display":"static"}),zt(t,I("More Options","formidable")),e.append(t);var r=c({className:"frm-dropdown-menu dropdown-menu dropdown-menu-right"});return r.setAttribute("role","menu"),e.append(r),e}())}(n),O.append(n)}e.append(n),n.style.display=r?"block":"none"}}function se(e,t){e.setAttribute("data-bs-toggle","tooltip"),e.setAttribute("data-bs-container","body"),e.setAttribute("title",t),e.addEventListener("mouseover",function(){null===e.getAttribute("data-original-title")&&jQuery(e).tooltip()})}function ce(e,t){return function(r){for(var n="function"==typeof t?t(r):t,o=e.length,i=!1,a=0;a0&&document.getElementById("form_id").value!==r||(o.last_row_field_ids=function(){var e=document.querySelector(".edit_field_type_submit");if(!e)return[];for(var t=e.parentNode.children,r=[],n=0;nt.childElementCount-1:i<=jQuery(t.querySelector(".edit_field_type_submit").closest("#frm-show-fields > li")).index()}if(n)return!(t.classList.contains("start_divider")||!we(t.parentElement)&&(!we(t.parentElement.nextElementSibling)||e.parentElement.querySelector("li.frm_field_box:not(.edit_field_type_submit)")));var a=t.classList.contains("start_divider")&&null!==t.closest(".repeat_section"),l=null!==t.closest(".repeat_section");if(a||l){if(e.classList.contains("edit_field_type_gdpr")||"gdpr"===e.id)return!1;if(wp.hooks.applyFilters("frm_deny_drop_in_repeater",!1,e))return!1}if(!a){if(!function(e,t){if(e.length<12)return!0;if(e.length>12)return!1;var r=t.attr("data-fid");return 1===jQuery(e).filter('[data-fid="'.concat(r,'"]')).length}(ie(jQuery(t)),jQuery(e)))return!1;if("divider"===e.id&&t.closest(".start_divider"))return!1}return e.classList.contains("frm-new-field")?function(e,t){var r=e.classList,n=r.contains("frm_tbreak"),o=r.contains("frm_thidden"),i=r.contains("frm_tdivider"),a=r.contains("frm_tform"),l=r.contains("frm_tuser_id");return"frm-show-fields"===t.id||t.classList.contains("start_divider")?!(n||o||i||a)||(!(t.classList.contains("start_divider")||null!==t.closest(".start_divider"))||!a&&!i):!(xe(t)||o||n||l)}(e,t):function(e,t){if(Qe(e))return function(e,t){return!(!t.classList.contains("start_divider")||null!==e.querySelector(".start_divider"))}(e,t);if(e.classList.contains("edit_field_type_break"))return!1;if(t.classList.contains("start_divider"))return function(e){return!e.classList.contains("edit_field_type_form")&&!e.querySelector(".edit_field_type_form")&&!(e.classList.contains("edit_field_type_divider")||e.querySelector(".edit_field_type_divider"))}(e);var r=e.classList.contains("edit_field_type_hidden"),n=e.classList.contains("edit_field_type_user_id");return!r&&!n&&function(e,t){if(xe(t))return!1;if(jQuery(e).children("ul.frm_sorting").not(".start_divider").length>0)return!1;var r=e.classList.contains("edit_field_type_divider")||e.querySelector(".edit_field_type_divider"),n=e.classList.contains("edit_field_type_form");return null===t.closest(".start_divider")||!r&&!n}(e,t)}(e,t)}function we(e){return e&&e.matches("#frm-show-fields > li:last-child")}function Qe(e){return e.classList.contains("frm_field_box")&&!e.classList.contains("form-field")}function xe(e){return null!==e.querySelector(".edit_field_type_break, .edit_field_type_hidden, .edit_field_type_user_id")}function Ee(e){var t=document.getElementById(e),r=jQuery(t),n=[],o=function(e){var t=e.querySelector(".frm_hidden_fdata");e.classList.add("frm_load_now"),null!==t&&n.push(t.innerHTML)};o(t);for(var i=ke(t);i&&n.length<15;)o(i),i=ke(i);jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_load_field",field:n,form_id:E,nonce:frmGlobal.nonce},success:function(e){return function(e,t,r){var n,o;if(0===(e=e.replace(/^\s+|\s+$/g,"")).indexOf("{")){for(n in e=JSON.parse(e)){jQuery("#frm_field_id_".concat(n)).replaceWith(e[n]);var i=document.getElementById("frm_field_id_".concat(n));i&&(i.querySelectorAll("[data-toggle]").forEach(function(e){return e.setAttribute("data-bs-toggle",e.getAttribute("data-toggle"))}),i.querySelectorAll(".frm-dropdown-menu").forEach(function(e){return e.classList.add("dropdown-menu")})),V("#frm_field_id_".concat(n,".edit_field_type_divider ul.frm_sorting")),X(document.getElementById("frm_field_id_".concat(n)))}((o=t.nextAll(".frm_field_loading:not(.frm_load_now)")).length||(o=jQuery(document.getElementById("frm-show-fields")).find(".frm_field_loading:not(.frm_load_now)")).length)&&Ee(o.attr("id")),ci(),Fr(),Ie();var a=new Event("frm_ajax_loaded_field",{bubbles:!1});a.frmFields=r.map(function(e){return JSON.parse(e)}),document.dispatchEvent(a)}else jQuery(".frm_load_now").removeClass(".frm_load_now").html("Error")}(e,r,n)}})}function ke(e){var t;return e.nextElementSibling?e.nextElementSibling:null===(t=e.parentNode)||void 0===t||null===(t=t.closest(".frm_field_box"))||void 0===t||null===(t=t.nextElementSibling)||void 0===t?void 0:t.querySelector(".form-field")}function Ae(){var e=jQuery(this);if(e.hasClass("disabled"))return!1;var t=e.closest(".frmbutton"),r=t.attr("id");if(t.hasClass("frm_at_limit"))return Se(),!1;if(!pe(r)){var n=0;"summary"===r&&(n=b.children('li[data-type="break"]').length>0?1:0);var o=E;return jQuery.ajax({type:"POST",url:ajaxurl,data:_e(r,0,o,n),success:function(e){Le(e);var t=ye(e);t&&wp.hooks.doAction("frm_after_field_added_in_form_builder",{field:e,fieldId:t,fieldType:r,form_id:o})},error:he}),!1}}function Se(){var e=document.querySelector(".frm_wrap");if(e){var t=document.createElement("a");t.setAttribute("data-frmverify",I("This field type has reached its limit.","formidable")),e.append(t),t.click(),t.remove();var r=document.getElementById("frm-confirmed-click");r&&(r.style.display="none")}}function Le(e){document.getElementById("frm_form_editor_container").classList.add("frm-has-fields");var t=Ge(e),r=b[0].querySelector(".edit_field_type_submit");r?jQuery(r.closest(".frm_field_box:not(.form-field)")).before(t):b.append(t),We(e,!0),t.each(function(){$(this.querySelector("ul.frm_sorting")),X(this.querySelector(".form-field"),".frm-move")})}function Ie(){var e=!0,t=document.querySelectorAll(".frmjs_prod_field_opt_cont");b.find("li.edit_field_type_product").length>1&&(e=!1);for(var r=0;r'),o.append(document.createTextNode(" ")),o.append(i),n.append(o),e.append(n)})}(t,!0===e);var r=jQuery(t);r.offset().left>jQuery(window).width()-r.outerWidth()?t.style.left="".concat(-r.outerWidth(),"px"):y&&r.offset().left").addClass("frm_field_box").html(jQuery("
    ").addClass("frm_grid_container frm_sorting").append(e)))}),r}function Ue(e){var t=s("ul",{className:"frm_grid_container frm_sorting"}),r=s("li",{className:"frm_field_box",child:t});e.replaceWith(r),t.append(e),$(t),X(r,".frm-move")}function We(e,t){var r,n,o=/id="(\S+)"/.exec(e),i=document.getElementById(o[1]),l="#".concat(o[1],".edit_field_type_divider ul.frm_sorting.start_divider"),s=jQuery(l),d=i.getAttribute("data-type");r=e,(n=c()).innerHTML=r,n.querySelectorAll(".form-field").forEach(Ve);var f,u,m=!1;if(Po(),V(l),"quantity"===d&&function(e){var t=e.getAttribute("data-fid"),r=document.getElementById("field_options[product_field_".concat(t,"]"));r&&(rt(r),oo(document.getElementById("frm-single-settings-".concat(t))))}(i),"product"!==d&&"quantity"!==d||Ie(),s.length)s.parent(".frm_field_box").children(".frm_no_section_fields").addClass("frm_block");else{var _=jQuery(i).closest("ul.frm_sorting.start_divider");_.length&&(An(_),m=!0)}e.includes("frm-collapse-page")&&Fr(),u="frm-newly-added",(f=i).classList?f.classList.add(u):f.className+=" ".concat(u),setTimeout(function(){i.classList.remove("frm-newly-added")},1e3);var p,g=i.querySelector("#frm-last-row-fields-order");if(g&&((p=JSON.parse(g.value))&&"object"===a(p)&&Object.keys(p).forEach(function(e){var t=document.querySelector('input[name="field_options[field_order_'.concat(e,']"]'));t&&(t.value=p[e])})),t){var y=i.getBoundingClientRect(),v=document.getElementById("post-body-content");y.top>=0&&y.left>=0&&y.right<=(window.innerWidth||document.documentElement.clientWidth)&&y.bottom<=(window.innerHeight||document.documentElement.clientHeight)||v.scroll({top:v.scrollHeight,left:0,behavior:"smooth"}),!1===m&&An(s)}Ke(),ci(),document.getElementById("frm-show-fields").classList.remove("frm-over-droppable"),function(e){var t=document.getElementById(e);null!=t&&t.dataset.limit&&kr(e)>=t.dataset.limit&&t.classList.add("frm_at_limit")}(d),i.querySelectorAll("[data-toggle]").forEach(function(e){return e.setAttribute("data-bs-toggle",e.getAttribute("data-toggle"))}),i.querySelectorAll(".frm-dropdown-menu").forEach(function(e){return e.classList.add("dropdown-menu")});var h=new Event("frm_added_field",{bubbles:!1});h.frmField=i,h.frmSection=l,h.frmType=d,h.frmToggles=m,document.dispatchEvent(h)}function Ve(e){if(e.dataset.fid){var t=document.getElementById("draft_fields");t&&(""===t.value?t.value=e.dataset.fid:t.value.split(",").includes(e.dataset.fid)||(t.value+=",".concat(e.dataset.fid)))}}function $e(e){jQuery("#new_fields .frm-single-settings").addClass("frm_hidden"),jQuery("#frm-options-panel > .frm-single-settings").removeClass("frm_hidden"),Ke(e)}function Ke(e){jQuery("li.ui-state-default.selected").removeClass("selected"),jQuery(".frm-show-field-settings.selected").removeClass("selected"),e||yr()}function Je(){var e=this.value,t=function(e){var t,r=[],n=e.split(""),o=n.length,a=["{","[","("],l={"}":"{",")":"(","]":"["},s=!1;for(t=0;t0||s?"".concat(i.unmatched_parens,"\n\n"):""}(e);t+=function(e,t){var r=function(e,t){var r="";return function(e){return jQuery(e).siblings('label[for^="calc_type"]').children("input").prop("checked")}(t)||/\[(date|time|email|ip)\]/.test(e)&&(r="".concat(i.text_shortcodes,"\n\n")),r}(e,t);return r+=function(e){var t="";return/\[id\]|\[key\]|\[if\s\w+\]|\[foreach\s\w+\]|\[created-at(\s*)?/g.test(e)&&(t+="".concat(i.view_shortcodes,"\n\n")),t}(e)}(e,this),""!==t&&M("".concat(e,"\n\n").concat(t))}function Xe(e,t){for(var r=!1,n=0;n").concat(l[t].fieldName,""))):(r=r?" checked":"",o.push('"));e.innerHTML=o.join("")}function nt(){for(var e=document.querySelectorAll(".frmjs_prod_field_opt"),t=0;t'):(d.innerHTML=_n(c),"TEXTAREA"===d.nodeName&&d.classList.contains("wp-editor-area")&&jQuery(d).trigger("change"),d.classList.contains("frm_primary_label")&&"break"===d.nextElementSibling.getAttribute("data-ftype")&&(d.nextElementSibling.querySelector(".frm_button_submit").textContent=c)))}function at(e){var t=parseFloat(e.getAttribute("max")),r=parseFloat(e.getAttribute("min"));return(t-r)/2+r}function lt(){var e=this.getAttribute("data-fid"),t="";["field_options_max_","frm_format_"].forEach(function(r){var n=document.getElementById(r+e);n&&(t+=n.value)});var r=document.getElementsByName("field_options[type_".concat(e,"]"))[0];"text"===r.options[r.selectedIndex].value&&ct(""!==t,".frm_invalid_msg".concat(e))}function st(){var e=this.id.replace("frm_","").replace("req_field_",""),t=this.checked,r=jQuery("#field_label_".concat(e," .frm_required"));if(ct(t,".frm_required_details".concat(e)),t){var n=jQuery('input[name="field_options[required_indicator_'.concat(e,']"]'));""===n.val()&&n.val("*"),r.removeClass("frm_hidden")}else r.addClass("frm_hidden")}function ct(e,t){var r=jQuery(t);if(e)r.fadeIn("fast").closest(".frm_validation_msg").fadeIn("fast");else{var n=r.fadeOut("fast").closest(".frm_validation_box"),o=n.css("display","block").children(":not(".concat(t,"):visible")).length;n.css("display",""),0===o&&r.closest(".frm_validation_msg").fadeOut("fast")}}function dt(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=jQuery(".frm_unique_details".concat(e));if(this.checked){t.fadeIn("fast").closest(".frm_validation_msg").fadeIn("fast");var r=jQuery(".frm_unique_details".concat(e," input"));""===r.val()&&r.val(i.default_unique)}else{var n=t.fadeOut("fast").closest(".frm_validation_box"),o=n.css("display","block").children(":not(.frm_unique_details".concat(e,"):visible")).length;n.css("display",""),0===o&&t.closest(".frm_validation_msg").fadeOut("fast")}}function ft(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=jQuery(this).val(),r=jQuery(document.getElementById("frm_field_id_".concat(e)));if(ct(""!==t,".frm_conf_details".concat(e)),""!==t){var n=jQuery(".frm_validation_box .frm_conf_details".concat(e," input"));""===n.val()&&n.val(i.default_conf),function(e){var t=document.getElementsByName("field_options[type_".concat(e,"]"))[0].value;ut(document.getElementById("field_description_".concat(e)),"field_options[description_".concat(e,"]"),i["enter_".concat(t)]),ut(document.getElementById("conf_field_description_".concat(e)),"field_options[conf_desc_".concat(e,"]"),i["confirm_".concat(t)])}(e),"inline"===t?r.removeClass("frm_conf_below").addClass("frm_conf_inline"):"below"===t&&r.removeClass("frm_conf_inline").addClass("frm_conf_below"),jQuery(".frm-conf-box-".concat(e)).removeClass("frm_hidden")}else jQuery(".frm-conf-box-".concat(e)).addClass("frm_hidden"),setTimeout(function(){r.removeClass("frm_conf_inline frm_conf_below")},200)}function ut(e,t,r){e.innerHTML===i.desc&&(e.innerHTML=r,document.getElementsByName(t)[0].value=r)}function mt(e){var t=JSON.parse(this.getAttribute("data-opts"));return e.preventDefault(),document.getElementById("frm_bulk_options").value=t.join("\n"),!1}function _t(){var e,t,r,n=jQuery(this).closest(".frm-single-settings").data("fid"),o=jQuery("#frm_field_".concat(n,"_opts .frm_option_template")).prop("outerHTML"),i=jQuery(this).data("opttype"),a=0,l="000",s=function(e){for(var t=0,r=0,n=jQuery("#frm_field_".concat(e,"_opts li")),o=0;to||"000"===o)&&(o=r)}return o}(n);if(s!==l&&(a=s+1),"other"===i){document.getElementById("other_input_".concat(n)).value=1;var c=jQuery(this).data("ftype");"radio"!==c&&"select"!==c||jQuery(this).fadeOut("slow");var d={action:"frm_add_field_option",field_id:n,opt_key:a,opt_type:i,nonce:frmGlobal.nonce};jQuery.post(ajaxurl,d,function(e){jQuery(document.getElementById("frm_field_".concat(n,"_opts"))).append(e),on(n)})}else{o=(o=(o=(o=(o=o.replace(new RegExp('optkey="'.concat(l,'"'),"g"),'optkey="'.concat(a,'"'))).replace(new RegExp("-".concat(l,"_"),"g"),"-".concat(a,"_"))).replace(new RegExp("-".concat(l,'"'),"g"),"-".concat(a,'"'))).replace(new RegExp("\\[".concat(l,"\\]"),"g"),"[".concat(a,"]"))).replace("frm_hidden frm_option_template",""),Di(n,o={newOption:o});var f=this.closest(".frm_single_option");f?f.after(o.newOption):jQuery("#frm_field_".concat(n,"_opts")).append(o.newOption),on(n)}null==(r=(e=this).classList.contains("frm-add-option-legacy")?null===(t=e.closest(".frm-collapse-me"))||void 0===t?void 0:t.querySelector(".frm_sortable_field_opts"):e.closest(".frm_sortable_field_opts"))||r.querySelectorAll(".frm_remove_tag.frm_disabled").forEach(function(e){return e.classList.remove("frm_disabled")}),Po()}function pt(){gt(jQuery(this).closest(".frm-single-settings").data("fid"),this.value)}function gt(e,t){var r=jQuery(".frm_multiple_cont_".concat(e));"select"===t?r.fadeIn("fast"):r.fadeOut("fast")}function yt(){var e=jQuery(this).closest(".frm-single-settings").data("fid");qi(jQuery(".field_".concat(e,"_option_key"))),jQuery(".field_".concat(e,"_option")).toggleClass("frm_with_key")}function vt(){var e=jQuery(this).closest(".frm-single-settings"),t=e.data("fid"),r=document.getElementById("frm_field_id_".concat(t));wt(jQuery(this)),qi(jQuery(".field_".concat(t,"_image_id"))),qi(jQuery(".frm_toggle_image_options_".concat(t))),qi(jQuery(".frm_image_size_".concat(t))),qi(jQuery(".frm_alignment_".concat(t))),qi(jQuery(".frm-add-other#frm_add_field_".concat(t)));var n=vn(t);if(n){bt(t,"inline"),ht(r);var o=nn(t);r.classList.add("frm_image_options"),r.classList.add("frm_image_size_".concat(o)),e.find(".frm-bulk-edit-link").hide()}else r.classList.remove("frm_image_options"),ht(r),bt(t,"block"),e.find(".frm-bulk-edit-link").show();wp.hooks.doAction("frm_image_options_toggled",e[0],n)}function ht(e){e.classList.remove("frm_image_size_","frm_image_size_small","frm_image_size_medium","frm_image_size_large","frm_image_size_xlarge")}function bt(e,t){jQuery("#field_options_align_".concat(e)).val(t).trigger("change")}function jt(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=document.getElementById("frm_field_id_".concat(e));Qt(),vn(e)&&(ht(t),t.classList.add("frm_image_options"),t.classList.add("frm_image_size_".concat(nn(e))))}function wt(e){var t=e.closest(".frm-single-settings").data("fid");jQuery(".field_".concat(t,"_option")).trigger("change")}function Qt(){wt(jQuery(this))}function xt(e){var t,r=e.target.closest(".frm_image_preview_wrapper");if(null!==(t=wp)&&void 0!==t&&t.media&&(null==r||!r.dataset.upgrade)){e.preventDefault(),wp.media.model.settings.post.id=0;var n=wp.media.frames.file_frame=wp.media({multiple:!1,library:{type:["image"]}});n.on("select",function(){var e=n.state().get("selection").first().toJSON(),t=r.querySelector("img");t.setAttribute("src",e.url),t.classList.remove("frm_hidden"),t.removeAttribute("srcset"),r.querySelector(".frm_image_preview_frame").style.display="block",r.querySelector(".frm_image_preview_title").textContent=e.filename,r.querySelector(".frm_choose_image_box").style.display="none";var o=jQuery(r);o.siblings('input[name*="[label]"]').data("frmimgurl",e.url),o.find("input.frm_image_id").val(e.id).trigger("change"),wp.media.model.settings.post.id=0}),n.open()}}function Et(e){var t=jQuery(this).closest(".frm_image_preview_wrapper");e.preventDefault(),e.stopPropagation(),t.find("img").attr("src",""),t.find(".frm_image_preview_frame").hide(),t.find(".frm_choose_image_box").show(),t.find("input.frm_image_id").val(0).trigger("change")}function kt(){var e=jQuery(this).closest("li").find(".frm_form_fields select");this.checked?e.attr("multiple","multiple"):e.removeAttr("multiple")}function At(){var e=document.getElementById("dropform-search-input");e&&setTimeout(function(){e.focus()},100)}function St(e){var t=e.target,r=t.closest(".frm_warning_style");jQuery(r).fadeOut(400,function(){return r.remove()});var n=t.dataset.action,o=new FormData;p(n,o)}function Lt(e){e.preventDefault()}function It(){var e,t,r=this.parentNode,n=r.parentNode,o=n.querySelectorAll("li:not(.frm_hidden)");2===o.length&&(null===(e=Array.from(o).find(function(e){return e!==r}).querySelector(".frm_remove_tag"))||void 0===e||e.classList.add("frm_disabled"));var i=this.getAttribute("data-fid");jQuery(r).fadeOut("fast",function(){wp.hooks.doAction("frm_before_delete_field_option",this),jQuery(r).remove(),jQuery(n).find(".frm_other_option").length<1&&((t=document.getElementById("other_input_".concat(i)))&&(t.value=0),jQuery("#other_button_".concat(i)).fadeIn("fast"))}),Po()}function Bt(){var e=jQuery(this);if(e.is(":checked")){var t,r=function(){e.off("mouseup",t)};t=function(){setTimeout(function(){e.prop("checked",!1)},0),r()},e.on("mouseup",t),e.one("mouseout",r)}}function qt(){this.value===i.new_option&&(this.setAttribute("data-value-on-focus",this.value),this.value="")}function Ct(e){return B(I("Are you sure you want to delete these %1$s selected field(s)?","formidable"),e)}function Nt(){var e=i.conf_delete,t=this.parentNode.parentNode.parentNode.parentNode.parentNode,r=t.parentNode,n=jQuery(this).closest("li.form-field"),o=n.data("fid");if("divider"===n.data("ftype")){var a=document.querySelectorAll(".frm-field-group-hover-target .start_divider .frm_field_box"),l=0;a.forEach(function(e){var t=e.querySelectorAll("li.form-field");t&&(l+=t.length)}),l&&(e=Ct(++l))}return r.classList.contains("frm-section-collapsed")||r.classList.contains("frm-page-collapsed")||("divider_section_only"===t.className&&(e=i.conf_delete_sec),this.setAttribute("data-frmverify",e),this.setAttribute("data-frmverify-btn","frm-button-red"),this.setAttribute("data-deletefield",o),Ne(),D(this)),!1}function Tt(){this.closest("li.form-field").click()}function Ot(){var e=document.querySelector(".frm-field-group-hover-target");if(e){e.classList.add("frm-selected-field-group");var t=document.createElement("div");t.classList.add("frm-delete-field-groups","frm_hidden"),document.body.append(t),t.click()}}function Ft(){var e=document.querySelector(".frm-field-group-hover-target");if(e){var t="frm_field_group_".concat(be()),r=document.createTextNode("");Ue(r);var n=jQuery(r).closest("li").get(0);n.classList.add("frm_hidden");var o=n.querySelector("ul");o.id=t,jQuery(e.closest("li.frm_field_box")).after(n);var i=ie(jQuery(e)),a=[],l=[],s=i.length,c={},d=0;jQuery(n).on("frm_added_duplicated_field_to_row",function(e,t){if(c[jQuery(t.duplicatedFieldHtml).attr("data-fid")]=t.originalFieldId,!(s>++d)){var r=jQuery(o),i=ie(r);l.forEach(function(e){e.remove()});for(var f=0;f6)return t.append(Gt(e,"even")),t;if(5!==e&&t.append(Gt(e,"even")),e%2==1&&t.append(Gt(e,"middle")),e<6)t.append(Gt(e,"left")),t.append(Gt(e,"right"));else{var r=c();r.classList.add("frm_fourth"),t.prepend(r)}return t}(e),l=t.closest("ul.frm_sorting");return l&&function(e,t){for(var r=t.children.length,n=0;n6?"frm_full":e%2==1?"frm_fourth":"frm_third"}return n.classList.add(r),n.setAttribute("layout-type",t),n.append(function(e,t){for(var r=Xt(),n=0;n6?"frm1":[2,3,4,6].includes(e)?lr(12/e):5===e&&void 0!==t?0===t?"frm4":"frm2":"frm12"}function Kt(e){switch(e){case 2:case 3:return"frm3";case 4:case 5:return"frm2";case 6:return"frm1";default:return"frm12"}}function Jt(e){switch(e){case 2:return"frm9";case 3:case 4:return"frm6";case 5:return"frm4";case 6:return"frm7";default:return"frm12"}}function Xt(){var e=c();return e.classList.add("frm_grid_container"),e}function Yt(){var e=document.querySelector(".frm-field-group-hover-target");if(e){var t=this.getAttribute("layout-type");ae(ie(jQuery(e)).first(),t),fr()}}function Zt(){var e=er(),t=this.getAttribute("layout-type");ae(ie(e).first(),t),yr()}function er(){var e=jQuery(".frm-selected-field-group"),t=e.first();return e.not(t).each(function(){ie(jQuery(this)).each(function(){var e=this.parentNode;ie(t).last().after(this),jQuery(e).children("li.form-field").length||e.closest("li.frm_field_box").remove()})}),En(),ae(ie(t).first()),t}function tr(){null===this.closest(".frm-merge-fields-into-row")&&rr(ie(jQuery(".frm-field-group-hover-target")))}function rr(e){var t=e.length,r=document.getElementById("frm_field_group_popup");r.innerHTML="";var n=c();n.style.padding="0 24px";var o=$t(5===t?6:t),i=c();if(i.style.padding="20px 0",i.classList.add("frm_grid_container"),5===t){var a=document.createElement("span");a.classList.add("frm1"),i.append(a)}var l=jr()>0&&ir($t(t));!1!==l&&l>=12&&(l=Math.floor(12/t));for(var s=0;s',""),t);e.prepend(r),document.getElementById("frm-field-group-message-dismiss").addEventListener("click",function(){_r(document.getElementById("frm-field-group-message"))})}}(),"ul"===e.originalEvent.target.nodeName.toLowerCase()){var t=document.querySelector(".frm-field-group-hover-target");if(t){var r=e.ctrlKey||e.metaKey,n=e.shiftKey,o=t.classList.contains("frm-selected-field-group"),i=function(){var e=jQuery(".frm-selected-field-group");if(e.length)return e;var t=pr();if(t){var r=t.closest("ul");if(r&&1===ie(jQuery(r)).length)return r.classList.add("frm-selected-field-group"),jQuery(r)}return jQuery()}(),a=i.length;if(r||n){var l=pr();if(null===l||jQuery(l).siblings("li.form-field").length||(l.parentNode.classList.add("frm-selected-field-group"),++a),r){if(o)return--a,t.classList.remove("frm-selected-field-group"),void gr(a);++a}else if(n&&!o){++a;var s=i.first();(s.parent().index()=2||1===e&&ie(jQuery(document.querySelector(".frm-selected-field-group"))).length>1?function(){var e=document.getElementById("frm_field_multiselect_popup");if(e)return e.classList.toggle("frm-unmergable",!hr()),e;(e=c()).id="frm_field_multiselect_popup",hr()||e.classList.add("frm-unmergable");var t=c();t.classList.add("frm-merge-fields-into-row"),t.textContent=I("Merge into row","formidable");var r=document.createElement("a");r.style.marginLeft="5px",r.classList.add("frm_icon_font","frm_arrowdown6_icon"),r.setAttribute("href","#"),t.append(r),e.append(t);var n=c();n.classList.add("frm-multiselect-popup-separator"),e.append(n);var o=c();o.classList.add("frm-delete-field-groups"),o.append(Rt("frm_trash_svg")),e.append(o),document.getElementById("post-body-content").append(e),jQuery(e).hide().fadeIn()}():vr(),Fe()}function yr(e){if(void 0!==e){if(null!==e.originalEvent.target.closest("#frm-show-fields"))return;if(e.originalEvent.target.classList.contains("frm-merge-fields-into-row"))return;if(null!==e.originalEvent.target.closest(".frm-merge-fields-into-row"))return;if(e.originalEvent.target.classList.contains("frm-custom-field-group-layout"))return;if(e.originalEvent.target.classList.contains("frm-cancel-custom-field-group-layout"))return}jQuery(".frm-selected-field-group").removeClass("frm-selected-field-group"),jQuery(document).off("click",yr),vr()}function vr(){var e=document.getElementById("frm_field_multiselect_popup");e&&e.remove()}function hr(){var e=document.querySelectorAll(".frm-selected-field-group"),t=e.length;if(1===t)return!1;for(var r=0,n=0;n12)return!1}return!0}function br(e){if(null===e.originalEvent.target.closest("#frm_field_group_popup")&&!e.originalEvent.target.classList.contains("frm-custom-field-group-layout")){var t=Ht(jr(),document.querySelector(".frm-selected-field-group").firstChild);this.append(t)}}function jr(){var e=0;return jQuery(document.querySelectorAll(".frm-selected-field-group")).each(function(){e+=ie(jQuery(this)).length}),e}function wr(){var e,t=(e=[],jQuery(".frm-selected-field-group > li.form-field").each(function(){e.push(this.dataset.fid)}),e),r=function(e){return function(t){t.preventDefault(),function(e){e.forEach(function(e){xr(e)})}(e)}}(t),n=document.getElementById("frm_field_multiselect_popup");n&&n.remove(),this.setAttribute("data-frmverify",Ct(t.length)),D(this);var o=document.getElementById("frm-confirmed-click");null==o||o.removeAttribute("data-deletefield"),jQuery(o).on("click",r),jQuery("#frm_confirm_modal").one("dialogclose",function(){jQuery(o).off("click",r)})}function Qr(){xr(this.getAttribute("data-deletefield"))}function xr(e){var t=jQuery("#frm_field_id_".concat(e));Er(e),t.hasClass("edit_field_type_divider")&&t.find("li.frm_field_box[data-fid]").each(function(){Er(this.getAttribute("data-fid"))}),kn()}function Er(e){jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_delete_field",field_id:e,nonce:frmGlobal.nonce},success:function(){var t,r,n,o=jQuery(document.getElementById("frm_field_id_".concat(e))),i=jQuery("#frm-single-settings-".concat(e));i.is(":visible")&&(null===(t=document.querySelector(".frm-settings-panel .frm-tabs-navs ul > li:first-child"))||void 0===t||t.click(),document.querySelector("#frm-options-panel .frm-single-settings").classList.remove("frm_hidden")),function(e){var t=e[0].querySelectorAll(".frm-inline-modal[data-fills]");t.length&&t.forEach(function(e){e.classList.add("frm_hidden"),e.removeAttribute("data-fills"),e.closest("form").append(e)})}(i),i.remove(),o.fadeOut("slow",function(){var e,t=o.closest(".start_divider"),r=o.data("type"),n=o.siblings("li.form-field");if(n.length||(o.is(".edit_field_type_end_divider")?n.length=o.closest("li.form-field").siblings():e=o.closest("ul.frm_sorting").parent()),o.remove(),"break"===r?Fr():"product"===r&&(Ie(),nt()),n.length?ae(n.first()):e.remove(),0===jQuery("#frm-show-fields li").length||function(){if(b.get(0).childElementCount>1)return!1;var e=b.get(0).firstElementChild.firstElementChild.querySelectorAll("li.frm_field_box");return!(e.length>1)&&e[0].classList.contains("edit_field_type_submit")}()){var i=document.getElementById("frm_form_editor_container");i.classList.remove("frm-has-fields"),i.classList.add("frm-empty-fields")}else t.length&&An(t);z()}),o.length&&(r=o.data("type"),(n=document.getElementById(r))&&n.dataset.limit&&kr(r)-11)for(document.getElementById("frm-fake-page").style.display="block",e=0;e200)&&(M(i.repeat_limit_min),this.value="")}function Yr(){var e=this.value;""!==e&&(e<1||e>200)&&(M(i.checkbox_limit),this.value="")}function Zr(e,t){jQuery(e).closest(".frm_field_box").find(".frm_".concat(t,"_form_row .frm_repeat_label")).text(e.value)}function en(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=this.value,r=document.getElementById("frm_show_selected_fields_".concat(e)),n=document.getElementById("frm_show_selected_forms_".concat(e));jQuery(n).find("select").val(""),"form"===t?(n.style.display="inline",function(e){if(null!==e)for(;e.firstChild;)e.firstChild.remove()}(r)):(r.style.display="none",n.style.display="none",xn(t,e))}function tn(){var e=rn(this);if(e){var t=jQuery(this).closest(".frm_single_option");!function(e,t,r){var n=r.data("optkey"),o=yn(e),i=jQuery('label[for="field_'.concat(t,"-").concat(n,'"]')),a="field_options[options_".concat(e,"][").concat(n,"]"),l=jQuery('input[name="'.concat(a,'[label]"]'));if(i.length<1)return on(e),void(r.find('input[name^="default_value_"]').is(":checked")&&l.length>0&&jQuery('select[name^="item_meta['.concat(e,']"]')).val(l.val()));var s,d=i.children("input");if(s=l.length<1?(l=jQuery('input[name="'.concat(a,'"]'))).val():o?jQuery('input[name="'.concat(a,'[value]"]')).val():l.val(),!(l.length<1)){var f=i[0].childNodes;if(vn(e)){var u=function(e,t,r){var n,o=e.find("img");o&&(n=o.attr("src"));var i=hn(t);return pn(r.val(),i,n)}(r,e,l),m=i.find(".frm_image_option_container");m.length>0?m.replaceWith(u):(f[f.length-1].nodeValue="",i.append(u))}else{var _=!1;f.forEach(function(t,r){if(!1===_)"INPUT"===t.tagName&&(_=r);else if(r===_+1){var n="";!function(e){var t=document.getElementsByName("field_options[image_options_".concat(e,"]")),r=Array.from(t).find(function(e){return e.checked&&"buttons"===e.value});return void 0!==r}(e)?t.nodeValue=" ".concat(l.val()):(n=c({className:"frm_label_button_container",text:" ".concat(l.val())}),i[0].replaceChild(n,t))}else t.remove()})}d.val(s),defaultVal=r.find('input[name^="default_value_"]'),d.prop("checked",!!defaultVal.is(":checked"))}}(e.fieldId,e.fieldKey,t)}}function rn(e){var t=jQuery(e).closest(".frm_sortable_field_opts");return!!t.length&&{fieldId:t.attr("id").replace("frm_field_","").replace("_opts",""),fieldKey:t.data("key")}}function nn(e){var t,r=document.getElementById("field_options_image_size_".concat(e)),n="";return r&&""!==(t=r.value)&&(n=t),n}function on(e){var t=jQuery('[name^="item_meta['.concat(e,']"]'));if(!(t.length<1)){if(t.is("select")){var r=document.getElementById("frm_placeholder_".concat(e));r&&""!==r.value?dn(t[0],{sourceID:e,placeholder:r.value}):dn(t[0],{sourceID:e})}else{var n=un(e);jQuery("#field_".concat(e,"_inner_container > .frm_form_fields")).html("");for(var o=rn(jQuery("#frm_delete_field_".concat(e,"-000_container"))),i=jQuery("#field_".concat(e,"_inner_container > .frm_form_fields")),a=vn(e),l=a?nn(e):"",s=a?"frm_image_option frm_image_".concat(l," "):"",c=Oi(e),d="hidden"===t.attr("type")?t.data("field-type"):t.attr("type"),f=0;f=0;f--)d();var u=c.querySelector('option[value=""]');null!==u&&c.prepend(u)}}}function sn(e,t,r,n){null!==t||e.querySelector('option[value="'.concat(r,'"]'))||((t=frmDom.tag("option",{text:n})).value=r),e.prepend(t)}function cn(e,t,r,n,o,i){var a="",l=t.key.includes("other"),s="field_".concat(n,"-").concat(t.key),c="scale"===e?"radio":e,d='');return this.getSingle=function(){return""!==(a=wp.hooks.applyFilters("frm_admin.build_single_option_template",a,{opt:t,type:e,fieldId:r,classes:i,id:s}))?a:'
    \n\t\t\t\t\t\n\t\t\t\t\t").concat(l?d:"","\n\t\t\t\t
    ")},this.getSingle()}function dn(e,t){if(e){var r=t.sourceID,n=t.placeholder,o=Oi(r),i=t.other;!function(e){var t;if(void 0!==e.options)for(t=e.options.length-1;t>=0;t--)e.remove(t)}(e);for(var a=un(r,e.id.includes("frm_field_logic_opt")),l=void 0!==n,s=0;s1&&void 0!==arguments[1]&&arguments[1],s=[],c=jQuery('input[name^="field_options[options_'.concat(e,']"]')).filter('[name$="[label]"], [name*="[other_"]'),d=Oi(e),f=hn(e),u=vn(e),m=yn(e);for(t=0;t0||(o=r=c[t].value,i=c[t].name.replace("field_options[options_".concat(e,"]["),"").replace("[label]","").replace("]",""),m&&(n=c[t].name.replace("[label]","[value]"),r=jQuery('input[name="'.concat(n,'"]')).val(),l&&""===o&&(o=""!==r?r:frm_admin_js.no_label)),u&&(o=pn(o,f,mn(c[t]))),a={saved:r,label:o=frmAdminBuild.hooks.applyFilters("frm_choice_field_label",o,e,c[t],u),checked:gn(c[t].id),key:i},d&&(n=c[t].name.replace("[label]","[price]"),a.price=jQuery('input[name="'.concat(n,'"]')).val()),s.push(a));return s}function mn(e){var t=jQuery(e).siblings(".frm_image_preview_wrapper");if(!t.length)return"";var r=t.find("img");return r.length?r.attr("src"):""}function _n(e){(e instanceof Element||e instanceof Document)&&(e=e.outerHTML);var t=jQuery.parseHTML(e).reduce(function(e,t){var r=frmDom.cleanNode(t);return"#text"===r.nodeName?e+r.textContent:e+r.outerHTML},"");return t!==e?_n(t):t}function pn(e,t,r){var n,o=e;o=_n(o),r?n=m({src:r,alt:o}):(n=c({className:"frm_empty_url"})).innerHTML=i.image_placeholder_icon;var a=t?" frm_label_with_image":"",l=s("span",{className:"frm_text_label_for_image_inner"});return l.innerHTML=o,s("span",{className:"frm_image_option_container".concat(a),children:[n,s("span",{className:"frm_text_label_for_image",child:l})]})}function gn(e){var t=jQuery("#".concat(e));if(0===t.length)return!1;var r=t.siblings("input[type=checkbox]");return r.length&&r.prop("checked")}function yn(e){return bn("separate_value_".concat(e))}function vn(e){for(var t=!1,r=document.getElementsByName("field_options[image_options_".concat(e,"]")),n=0;n=0&&(t.splice(r,1),e.val(t),e.next(".btn-group").find('.multiselect-container input[value=""]').prop("checked",!1))}(jQuery(this))}function Bn(e){e.val(""),e.next(".btn-group").find('.multiselect-container input[value!=""]').prop("checked",!1)}function qn(){jQuery(".frm-hide-empty").each(function(){0===jQuery(this).text().trim().length&&jQuery(this).remove()})}function Cn(e){e.preventDefault(),function(e,t,r){var n=document.getElementById(e.getAttribute("data-open")),o=jQuery(e).closest("p,ul"),i=void 0!==t;if(o.hasClass("frm-open"))o.removeClass("frm-open"),n.classList.add("frm_hidden");else{if(i||(t=Wo(e)),t){if(!i){var a=r.key;"Enter"!==a&&" "!==a&&t.focus()}o.after(n),n.setAttribute("data-fills",t.id.replace("-proxy-input","")),0===n.id.indexOf("frm-calc-box")&&Ze(n,!0)}o.addClass("frm-open"),n.classList.remove("frm_hidden"),wp.hooks.doAction("frm_show_inline_modal",n,e)}}(this,void 0,e)}function Nn(e){e.preventDefault(),this.parentNode.classList.add("frm_hidden"),jQuery('.frm-open [data-open="'.concat(this.parentNode.id,'"]')).closest(".frm-open").removeClass("frm-open")}function Tn(e){var t=e.target;t.closest(".frm-inline-modal.frm-modal-no-dismiss")||t.closest(".frm-show-inline-modal")||t.closest("#frm_adv_info")||t.closest(".frm-token-proxy-input")||document.querySelectorAll(".frm-inline-modal.frm-modal-no-dismiss:not(.frm_hidden)").forEach(function(e){e.classList.add("frm_hidden"),e.previousElementSibling.classList.remove("frm-open")})}function On(){var e,t=this.getAttribute("data-frmchange").split(",");for(e=0;e').before('')}function Yn(){var e="success";"options[edit_action]"===this.name&&(e="edit");var t=jQuery(this).val();jQuery(".".concat(e,"_action_box")).hide(),"redirect"===t?jQuery(".".concat(e,"_action_redirect_box.").concat(e,"_action_box")).fadeIn("slow"):"page"===t?jQuery(".".concat(e,"_action_page_box.").concat(e,"_action_box")).fadeIn("slow"):jQuery(".".concat(e,"_action_message_box.").concat(e,"_action_box")).fadeIn("slow")}function Zn(e){if(!function(e){var t=jQuery(e),r=t.closest(".frm_form_action_settings"),n=r.find(".widget-inside");if(n.find("p, div, table").length)return!1;var o=r.find(".widget-top");return o.on("frm-action-loaded",function(){t.trigger("click"),r.removeClass("open"),n.hide()}),o.trigger("click"),!0}(e.target)){var t=e.target.closest(".frm_form_action_settings"),r=t.querySelectorAll(".wp-editor-area");r.length&&r.forEach(function(e){tinymce.EditorManager.execCommand("mceRemoveEditor",!0,e.id)});var n=jQuery(t).clone(),o=n.attr("id").replace("frm_form_action_",""),i=eo(o);n.find(".frm_action_id, .frm-btn-group").remove(),n.find('input[name$="['.concat(o,'][ID]"]')).val(""),n.find(".widget-inside").hide(),n.find("input[type=text], textarea, input[type=number]").prop("defaultValue",function(){return this.value}),n.find("input[type=checkbox], input[type=radio]").prop("defaultChecked",function(){return this.checked});var a=new RegExp("\\[".concat(o,"\\]"),"g"),l=new RegExp("_".concat(o,'"'),"g"),s=new RegExp("-".concat(o,'"'),"g"),d=new RegExp('"'.concat(o,'"'),"g"),f=n.html().replace(a,"[".concat(i,"]")).replace(l,"_".concat(i,'"'));f=f.replace(s,"-".concat(i,'"')).replace(d,'"'.concat(i,'"'));var u=c({id:"frm_form_action_".concat(i),className:n.get(0).className});u.setAttribute("data-actionkey",i),u.innerHTML=f,u.querySelectorAll(".wp-editor-wrap, .wp-editor-wrap *").forEach(function(e){"string"==typeof e.className&&(e.className=e.className.replace(o,i)),e.id=e.id.replace(o,i)}),u.classList.remove("open"),document.getElementById("frm_notification_settings").append(u),r.length&&(r.forEach(function(e){frmDom.wysiwyg.init(e)}),u.querySelectorAll(".wp-editor-area").forEach(function(e){frmDom.wysiwyg.init(e)})),u.classList.contains("frm_single_on_submit_settings")&&u.querySelector("input.frm-page-search")&&yi(u),ci(),wp.hooks.doAction("frm_after_duplicate_action",u)}}function eo(e){var t=parseInt(e,10)+11;return document.getElementById("frm_form_action_".concat(t))&&(t=eo(++t)),t}function to(){var e,t=jQuery(this).data("actiontype");if(!co(t)){var r=(e=Sr(document.querySelectorAll(".frm_form_action_settings"),"frm_form_action_"),void 0!==document.getElementById("frm_form_action_".concat(e))&&(e+=100),S>=e&&(e=S+1),S=e,e),n=E,o=document.createElement("div");o.classList.add("frm_single_".concat(t,"_settings"));var i=document.getElementById("frm_notification_settings");i.append(o),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_add_form_action",type:t,list_id:r,form_id:n,nonce:frmGlobal.nonce},success:function(e){Po(),o.remove(),document.querySelectorAll(".frm_form_action_settings.open").forEach(function(e){return e.classList.remove("open")});var n=c();n.innerHTML=e;var a=n.querySelector(".widget-top");Array.from(n.children).forEach(function(e){return i.append(e)}),jQuery(".frm_form_action_settings").fadeIn("slow");var l=document.getElementById("frm_form_action_".concat(r));l.classList.add("open"),document.getElementById("post-body-content").scroll({top:l.offsetTop+10,left:0,behavior:"smooth"}),so(t),Xn("#frm_form_action_".concat(r)),ci(),yi(l),a&&jQuery(a).trigger("frm-action-loaded"),frmAdminBuild.hooks.doAction("frm_added_form_action",l)}})}}function ro(){var e=document.getElementById("frm_email_addon_menu").classList,t=document.getElementById("actions-search-input");e.contains("frm-all-actions")?(e.remove("frm-all-actions"),e.add("frm-limited-actions")):(e.add("frm-all-actions"),e.remove("frm-limited-actions")),t.value="",ki(t,"input")}function no(e){e.on("Change",function(){!function(e){(function(){var e=document.querySelector(".frm-single-settings:not(.frm_hidden)");if(!e)return!1;var t=e.querySelector(".wp-editor-wrap");return t&&t.classList.contains("tmce-active")})()&&!tinyMCE.activeEditor.isHidden()&&(e.targetElm.value=e.getContent(),jQuery(e.targetElm).trigger("change"))}(e)})}function oo(e){var t=this;if(e)return this.fragment=document.createDocumentFragment(),this.initOnceInAllInstances=function(){void 0===oo.prototype.endMarker&&(oo.prototype.endMarker=document.getElementById("frm-end-form-marker"))},this.append=function(e){var r=e?e.parentElement.classList:"";e&&(r.contains("frm_field_box")||r.contains("divider_section_only"))&&t.fragment.append(e)},this.moveFields=function(){j.insertBefore(t.fragment,oo.prototype.endMarker)},this.initOnceInAllInstances(),void 0!==e?(this.append(e),void this.moveFields()):{append:this.append,moveFields:this.moveFields}}function io(){var e=jQuery(this).closest(".frm_form_action_settings").data("actionkey"),t=this.getAttribute("data-emailrow");jQuery("#frm_form_action_".concat(e," .frm_").concat(t,"_row")).fadeIn("slow"),jQuery(this).fadeOut("slow")}function ao(){var e=jQuery(this).closest(".frm_form_action_settings"),t=this.getAttribute("data-emailrow"),r=".frm_".concat(t,"_row"),n=".frm_".concat(t,"_button");jQuery(e).find(n).fadeIn("slow"),jQuery(e).find(r).fadeOut("slow",function(){jQuery(e).find("".concat(r," input")).val("")})}function lo(){var e=jQuery(this).closest(".frm_form_action_settings"),t=".frm_from_to_match_row";e.find('input[name$="[post_content][from]"]').val()===e.find('input[name$="[post_content][email_to]"]').val()?jQuery(e).find(t).fadeIn("slow"):jQuery(e).find(t).fadeOut("slow")}function so(e){var t,r,n=document.querySelectorAll(".frm_".concat(e,"_action"));co(e)?(t=n,r=fo(e)>0,t.forEach(function(e){e.classList.remove("frm_active_action"),e.classList.add("frm_inactive_action"),r&&e.classList.add("frm_already_used")})):n.forEach(function(e){e.querySelector(".frm_show_upgrade")||(e.classList.remove("frm_inactive_action","frm_already_used"),e.classList.add("frm_active_action"))})}function co(e){var t=function(e){return jQuery(".frm_single_".concat(e,"_settings")).length}(e)>=fo(e),r={type:e};return wp.hooks.applyFilters("frm_action_at_limit",t,r)}function fo(e){return parseInt(jQuery(".frm_".concat(e,"_action")).data("limit"),10)}function uo(){var e=i.only_one_action,t=this.dataset.limit;void 0!==t&&((t=parseInt(t))>1?e=e.replace(1,t).trim():e+=" ".concat(i.edit_action_text)),M(e)}function mo(){var e=jQuery(this).data("emailkey"),t=jQuery(this).closest(".frm_form_action_settings").find(".frm_action_name").val(),r=document.getElementById("form_id").value,n=document.getElementById("frm_logic_row_".concat(e)),o=Sr(n.querySelectorAll(".frm_logic_row"),"frm_logic_".concat(e,"_")),i=c({id:"frm_logic_".concat(e,"_").concat(o),className:"frm_logic_row frm_hidden"});return n.append(i),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_add_form_logic_row",email_id:e,form_id:r,meta_name:o,type:t,nonce:frmGlobal.nonce},success:function(t){jQuery(document.getElementById("logic_link_".concat(e))).fadeOut("slow",function(){i.insertAdjacentHTML("beforebegin",t),i.remove(),jQuery(n).parent(".frm_logic_rows").fadeIn("slow")})}}),!1}function _o(){var e=jQuery("select.frm_single_post_field");e.css("border-color","");var t=this,r=jQuery(t).val();if(""===r||"checkbox"===r)return!1;e.each(function(){if(jQuery(this).val()===r&&this.name!==t.name)return this.style.borderColor="red",jQuery(t).val(""),M(i.field_already_used),!1})}function po(){var e=jQuery(this).val();""===e?(jQuery(".frm_post_content_opt, select.frm_dyncontent_opt").hide().val(""),jQuery(".frm_dyncontent_opt").hide()):"post_content"===e?(jQuery(".frm_post_content_opt").show(),jQuery(".frm_dyncontent_opt").hide(),jQuery("select.frm_dyncontent_opt").val("")):(jQuery(".frm_post_content_opt").hide().val(""),jQuery("select.frm_dyncontent_opt, .frm_form_field.frm_dyncontent_opt").show())}function go(){var e=jQuery(this).val(),t=jQuery(document.getElementById("frm_dyncontent"));""===e||"new"===e?(t.val(""),jQuery(".frm_dyncontent_opt").show()):jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_display_get_content",id:e,nonce:frmGlobal.nonce},success:function(e){t.val(e),jQuery(".frm_dyncontent_opt").show()}})}function yo(){var e,t,r=document.getElementById("frm_posttax_rows").childNodes,n=document.querySelector(".frm_post_parent_field"),o=document.querySelector(".frm_post_menu_order_field"),i=this.value;jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_replace_posttax_options",post_type:i,nonce:frmGlobal.nonce},success:function(n){for(var o=0;o');var e=jQuery(this).closest(".frm_form_action_settings").find('select[name$="[post_content][post_type]"]').val(),t=jQuery(this).closest(".frm_form_action_settings").data("actionkey"),r=jQuery(this).closest(".frm_posttax_row").attr("id").replace("frm_posttax_",""),n=jQuery(this).val(),o=jQuery(document.getElementById("".concat(r,"_show_exclude"))).is(":checked")?1:0,i=jQuery('select[name$="[post_category]['.concat(r,'][field_id]"]')).val(),a=jQuery('input[name="id"]').val();jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_add_posttax_row",form_id:a,post_type:e,tax_key:r,action_key:t,meta_name:n,field_id:i,show_exclude:o,nonce:frmGlobal.nonce},success:function(e){jQuery(document.getElementById("frm_posttax_".concat(r))).replaceWith(e)}})}}function Qo(){var e=jQuery(this).closest(".frm_postmeta_row"),t=e.find(".frm_cancelnew"),r=e.find(".frm_enternew");return e.find("select.frm_cancelnew").is(":visible")?(t.hide(),r.show()):(t.show(),r.hide()),e.find("input.frm_enternew, select.frm_cancelnew").val(""),!1}function xo(){var e=jQuery(this),t=e.val();"checkbox"===e.attr("type")&&!1===this.checked&&(t="");var r=e.data("toggleclass");""===t?jQuery(".".concat(r)).hide():(jQuery(".".concat(r)).show(),jQuery(".hide_".concat(r,"_").concat(t)).hide())}function Eo(){Un()||($n(this),zn(document.querySelector(".frm_form_settings")))}function ko(e){return e.preventDefault(),Ao(jQuery(this),this.getAttribute("data-code")),!1}function Ao(e,t){var r=!1,n=e;if("object"===a(e)){if(e.hasClass("frm_noallow"))return;void 0===(n=jQuery(e).closest("[data-fills]").attr("data-fills"))&&void 0!==(n=e.closest("div").attr("class"))&&(n=n.split(" ")[1])}if(void 0===n){var o=document.activeElement;"search"===o.type?null===(n=o.id.replace("-search-input","")).match(/\d/gi)&&(n=(o=jQuery(".frm-single-settings:visible .".concat(n))).attr("id")):n=o.id}n&&(r=jQuery("#wp-".concat(n,"-wrap.wp-editor-wrap")).length>0);var i=jQuery(document.getElementById(n));if(void 0===e.attr("data-shortcode")&&(!i.length||void 0===i.attr("data-shortcode"))){var l=e.parents("ul.frm_code_list").attr("data-shortcode");"undefined"!==l&&"no"===l||(t="[".concat(t,"]"))}if(r&&(wpActiveEditor=n),!i.length)return!1;if("[default-html]"===t||"[default-plain]"===t){var s=0;"[default-plain]"===t&&(s=1),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_get_default_html",form_id:jQuery('input[name="id"]').val(),plain_text:s,nonce:frmGlobal.nonce},elementId:n,success:function(e){if(r){var t=document.createElement("p");t.innerText=e,send_to_editor(t.innerHTML)}else So(i,e)}})}else t=function(e,t,r){return"object"===a(t)&&t instanceof jQuery&&0===r[0].id.indexOf("success_url_")&&(t=t[0]).closest("#frm-insert-fields-box")?(t.parentNode.classList.contains("frm_insert_url")||(e=e.replace("]"," sanitize_url=1]")),e):e}(t,e,i),r?send_to_editor(t):So(i,t);return!1}function So(e,t){if(document.selection)e[0].focus(),document.selection.createRange().text=t;else{var r=e[0],n=r.selectionEnd;t=function(e,t,r,n){var o=e.data("sep");if(void 0===o)return t;var i=e.val();if(!i.trim().length)return t;var a=new RegExp("".concat(o,"\\s*$")),l=new RegExp("^\\s*".concat(o));return i.substr(0,r).trim().length&&!1===a.test(i.substr(0,r))&&(t=o+t),i.substr(n,i.length).trim().length&&!1===l.test(i.substr(n,i.length))&&(t+=o),t}(e,t,r.selectionStart,n),r.value=r.value.substr(0,r.selectionStart)+t+r.value.substr(r.selectionEnd,r.value.length);var o=n+t.length;!function(e,t){if(e.classList.contains("frm_classes")&&Lo(t)){var r=e.value.split(" ").filter(Lo);r.length&&(e.value=function(e,t,r){var n=e.split(" ").filter(function(e){return(e=e.trim()).length&&!t.includes(e)});return n.includes(r)||n.push(r),n.join(" ")}(e.value,r,t.trim()))}}(r,t),r.focus(),r.setSelectionRange(o,o)}Rn(e)}function Lo(e){return["frm_half","frm_third","frm_two_thirds","frm_fourth","frm_three_fourths","frm_fifth","frm_sixth","frm2","frm3","frm4","frm6","frm8","frm9","frm10","frm12"].includes(e.trim())}function Io(){var e=document.getElementById("frm-id-condition"),t=document.getElementById("frm-key-condition");"id"===this.value?(e.classList.remove("frm_hidden"),t.classList.add("frm_hidden"),ki(t,"change")):(e.classList.add("frm_hidden"),t.classList.remove("frm_hidden"),ki(e,"change"))}function Bo(){var e=document.getElementById("frm-id-key-condition-id").checked?"frm-id-condition":"frm-key-condition",t=document.getElementById("frm-is-condition").value,r=document.getElementById("frm-text-condition").value,n=document.getElementById("frm-insert-condition"),o=(e=document.getElementById(e)).options[e.selectedIndex].value,a="if ".concat(o," ").concat(t,'="').concat(r,'"]');n.setAttribute("data-code","".concat(a+i.conditional_text,"[/if ").concat(o)),n.innerHTML="[".concat(a,"[/if ").concat(o,"]")}function qo(e){return e.getAttribute("href")||e.getAttributeNS("http://www.w3.org/1999/xlink","href")}function Co(e){var t;e.parentNode.parentNode.classList.contains("frm_has_shortcodes")&&($o(),"use"===(t=Vo(e)).tagName?qo(t=t.firstElementChild).includes("frm_close_icon")||Do(t,"nofocus"):t.classList.contains("frm_close_icon")||Do(t,"nofocus"))}function No(e){e.preventDefault(),e.stopPropagation(),Do(this)}function To(e){!function(e){var t;if(e.id.startsWith("field_options_type_")){var r=e.id.split("_"),n=r.length&&r[r.length-1];null!==(t=document.querySelector("#frm-single-settings-".concat(n)))&&void 0!==t&&t.classList.contains("frm-type-".concat(e.value))||Oo()}}(e.target)}function Oo(e){var t;void 0===e&&(e=I("You are changing the field type. Not all field settings will appear as expected until you reload the page. Would you like to reload the page now?","formidable")),frmDom.modal.maybeCreateModal("frmSaveAndReloadModal",{title:I("Save and Reload?","formidable"),content:(t=c(e),t.style.padding="var(--gap-md)",t),footer:function(){var e=frmDom.modal.footerButton({text:I("Save and Reload","formidable"),buttonType:"primary"});_(e,function(){var e;(e=document.getElementById("frm_submit_side_top")).classList.contains("frm_submit_ajax")&&e.setAttribute("data-new-addon-installed",!0),e.click()});var t=frmDom.modal.footerButton({text:I("Cancel","formidable"),buttonType:"cancel"});return t.classList.add("dismiss"),frmDom.div({children:[t,e]})}()})}function Fo(e){var t;if(e instanceof Event){var r=document.querySelectorAll(".frm-single-settings .frm-show-box.frmsvg use"),n=Array.from(r).find(function(e){return"#frm_close_icon"===e.getAttribute("href")});if(void 0===n)return;t=n.parentElement}else t=e;var o=t.getBoundingClientRect(),i=document.getElementById("frm_adv_info"),a=i.parentElement.getBoundingClientRect();i.style.top="".concat(o.top-a.top+32,"px"),i.style.left="".concat(o.left-a.left-280,"px")}function Do(e,t){var r=Wo(e),n=document.getElementById("frm_adv_info"),a=e.className;if("svg"===e.tagName&&(e=e.firstElementChild),"use"===e.tagName&&(a=qo(e)),a.includes("frm_close_icon"))$o(n);else{if(Fo(e),jQuery(".frm_code_list a").removeClass("frm_noallow"),r.classList.contains("frm_not_email_to")?jQuery("#frm-insert-fields-box .frm_code_list li:not(.show_frm_not_email_to) a").addClass("frm_noallow"):r.classList.contains("frm_not_email_subject")&&jQuery(".frm_code_list li.hide_frm_not_email_subject a").addClass("frm_noallow"),n.setAttribute("data-fills",r.id),n.style.display="block","use"===e.tagName)if(e.hasAttributeNS("http://www.w3.org/1999/xlink","href"))e.setAttributeNS("http://www.w3.org/1999/xlink","href","#frm_close_icon");else{var l=document.createElementNS("http://www.w3.org/2000/svg","use");l.setAttributeNS("http://www.w3.org/1999/xlink","href","#frm_close_icon"),e.parentNode.replaceChild(l,e)}else e.className=a.replace("frm_more_horiz_solid_icon","frm_close_icon");"nofocus"!==t&&("none"!==r.style.display?r.focus():jQuery(tinymce.get(r.id)).trigger("focus")),function(e){["address","body"].forEach(function(t){!function(e,t){var r,n=i.contextualShortcodes["".concat(t,"Selector")],a=i.contextualShortcodes[t],l=e.matches(n),s=function(e){var t="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!t){if(Array.isArray(e)||(t=o(e))){t&&(e=t);var r=0,n=function(){};return{s:n,n:function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}},e:function(e){throw e},f:n}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,l=!1;return{s:function(){t=t.call(e)},n:function(){var e=t.next();return a=e.done,e},e:function(e){l=!0,i=e},f:function(){try{a||null==t.return||t.return()}finally{if(l)throw i}}}}(a);try{for(s.s();!(r=s.n()).done;){var c,d=r.value,f=null===(c=document.querySelector('#frm-adv-info-tab .frm_code_list [data-code="'.concat(d,'"]')))||void 0===c?void 0:c.closest("li");null==f||f.classList.toggle("frm_hidden",!l)}}catch(e){s.e(e)}finally{s.f()}}(e,t)})}(r)}}function Mo(e){return 0===i.contextualShortcodes.length||!function(e){var t=e.querySelector("a");if(!t)return!1;var r=t.dataset.code;return i.contextualShortcodes.address.includes(r)||i.contextualShortcodes.body.includes(r)}(e)||function(e){var t=e.querySelector("a").dataset.code,r=document.getElementById("frm_adv_info").dataset.fills,n=document.getElementById(r),o=i.contextualShortcodes;return o.address.includes(t)?n.matches(o.addressSelector):n.matches(o.bodySelector)}(e)}function Po(){x||(x=1,window.addEventListener("beforeunload",Go))}function Ho(){x=0}function zo(){x=0}function Ro(){x=0}function Go(e){x&&(e.preventDefault(),e.returnValue="")}function Uo(e,t){var r={my:"top",at:"top+".concat(t),of:window};e.dialog("option","position",r)}function Wo(e){if(e.classList.contains("frm-input-icon"))return e.previousElementSibling;for(var t,r=e.nextElementSibling;r&&("INPUT"!==r.tagName&&"TEXTAREA"!==r.tagName||r.classList.contains("frm-token-input-field"));)r=Wo(r);return r||(r=null===(t=e.closest(".frm-field-formula"))||void 0===t?void 0:t.querySelector(".frm-calc-field")),r}function Vo(e){var t;if(null!==(t=e.nextElementSibling)&&void 0!==t&&t.classList.contains("frm-input-icon"))return e.nextElementSibling;for(var r=e.previousElementSibling;null!==r&&"I"!==r.tagName&&"svg"!==r.tagName;)r=Vo(r);return r}function $o(e){if((void 0!==e||(e=document.getElementById("frm_adv_info")))&&null===document.getElementById("frm_dyncontent")){e.style.display="none";for(var t=document.querySelectorAll(".frm-show-box.frm_close_icon"),r=0;r".concat(r.data.name,": ").concat(r.data.msg,"

    "):'

    Imported ').concat(r.data.name,"

    "),e.find(".status").prepend(n),e.find(".status").show(),C.importQueue=jQuery.grep(C.importQueue,function(e){return e!=t}),C.imported++,0===C.importQueue.length?(e.find(".process-count").hide(),e.find(".forms-completed").text(C.imported),e.find(".process-completed").show()):(e.find(".form-current").text(C.imported+1),ei(e)))})}function ti(e){e.preventDefault();var t=!1,r=jQuery('input[name="frm_export_forms[]"]');jQuery('input[name="frm_export_forms[]"]:checked').val()||(r.closest(".frm-table-box").addClass("frm_blank_field"),t="stop");var n=jQuery('input[name="type[]"]');if(jQuery('input[name="type[]"]:checked').val()||"checkbox"!==n.attr("type")||(n.closest("p").addClass("frm_blank_field"),t="stop"),"stop"===t)return!1;e.stopPropagation(),this.submit()}function ri(){var e=jQuery(this).closest(".frm_blank_field");if(void 0!==e){var t=this.name;("type[]"===t&&jQuery('input[name="type[]"]:checked').val()||"frm_export_forms[]"===t&&jQuery(this).val())&&e.removeClass("frm_blank_field")}}function ni(){null!==jQuery(this).val().match(/\.csv$/i)?jQuery(".show_csv").fadeIn():jQuery(".show_csv").fadeOut()}function oi(){var e=document.querySelector('select[name="format"]');return e?e.value:""}function ii(e){var t,r,n=e.target.value;li(n),ai.call(e.target),t=n,r=document.getElementById("frm-export-select-all"),"csv"===t?(r.checked=!1,r.disabled=!0):r.disabled=!1}function ai(){var e=jQuery(this),t=e.find(":selected"),r=t.data("support"),n=r.indexOf("|");jQuery('input[name="type[]"]').each(function(){this.checked=!1,r.includes(this.value)?(this.disabled=!1,-1===n&&(this.checked=!0)):this.disabled=!0}),"csv"===e.val()?(jQuery(".csv_opts").show(),jQuery(".xml_opts").hide()):(jQuery(".csv_opts").hide(),jQuery(".xml_opts").show());var o=t.data("count"),i=jQuery('input[name="frm_export_forms[]"]');"single"===o?(i.prop("multiple",!1),i.prop("checked",!1)):(i.prop("multiple",!0),i.prop("disabled",!1)),e.trigger("change")}function li(e){if(""!==e){var t=document.querySelectorAll(".frm-is-repeater");t.length&&("csv"===e?t.forEach(function(e){e.classList.remove("frm_hidden")}):t.forEach(function(e){e.classList.add("frm_hidden")}),Qi.call(document.querySelector(".frm-auto-search")))}}function si(){var e=jQuery("select[name=format]").find(":selected").data("count"),t=jQuery('input[name="frm_export_forms[]"]');"single"===e&&this.checked?(t.prop("disabled",!0),this.removeAttribute("disabled")):t.prop("disabled",!1)}function ci(){jQuery(".frm_multiselect").hide().each(frmDom.bootstrap.multiselect.init)}function di(e){e.preventDefault(),mi(this,"frm_multiple_addons")}function fi(e){e.preventDefault(),mi(this,"frm_activate_addon")}function ui(e){e.preventDefault(),mi(this,"frm_install_addon")}function mi(e,t){r(1105).toggleAddonState(e,t)}function _i(){gi()}function pi(e){!function(e,t,r){var n=jQuery("#frm_leave_email_error");n.removeClass("frm_hidden").attr("frm-error",r),jQuery("#frm_leave_email").one("keyup",function(){n.addClass("frm_hidden")})}(0,0,e)}function gi(){var e=document.getElementById("frmapi-email-form");jQuery.ajax({dataType:"json",url:e.getAttribute("data-url"),success:function(t){var r=t.renderedHtml;r=r.replace(/]*(formidableforms.css|action=frmpro_css)[^>]*>/gi,""),e.innerHTML=r}})}function yi(e){frmDom.autocomplete.initSelectionAutocomplete(e)}function vi(e){var t=this.parentNode.parentNode,r=t.elements.type.value;e.preventDefault(),this.classList.add("frm_loading_button"),bi(t,r,this)}function hi(e){var t=this.elements.type.value,r=this.querySelector("button");e.preventDefault(),r.classList.add("frm_loading_button"),bi(this,t,r)}function bi(e,t,r){var n=function(e){var t,r,n={},o=e.elements;for(r=0;r .frm-with-line").forEach(function(e){var t=e.nextElementSibling;if(t){var r=t.querySelectorAll(":scope > li.frmbutton"),n=Array.from(r).every(function(e){return e.classList.contains("frm_hidden")});e.classList.toggle("frm_hidden",n)}}),jQuery(this).trigger("frmAfterSearch")}function xi(e,t){return"s"!==t&&"s"!==e[e.length-1]&&"".concat(e,"s").includes(t)}function Ei(e){e.stopPropagation()}function ki(e,t){var r=document.createEvent("HTMLEvents");r.initEvent(t,!1,!0),e.dispatchEvent(r)}function Ai(e,t){var r,n=new XMLHttpRequest,o="string"==typeof e?e:Object.keys(e).map(function(t){return"".concat(encodeURIComponent(t),"=").concat(encodeURIComponent(e[t]))}).join("&");return n.open("post",ajaxurl,!0),n.onreadystatechange=function(){if(n.readyState>3&&200==n.status){r=n.responseText;try{r=JSON.parse(r)}catch(e){}t(r)}},n.setRequestHeader("X-Requested-With","XMLHttpRequest"),n.setRequestHeader("Content-type","application/x-www-form-urlencoded"),n.send(o),n}function Si(e,t){e.classList.add("frm-fade"),setTimeout(t,1e3)}function Li(e){jQuery(e).css("visibility","hidden")}function Ii(e){jQuery(e).css("visibility","visible")}function Bi(e,t){return r(4260).initModal(e,t)}function qi(e,t){if("#"===t){var r=document.getElementById(e),n=r.style.display;r.style.display="none"===n?"block":"none"}else e.is(":visible")?e.hide():e.show()}function Ci(){window.onbeforeunload=null;var e=jQuery(window);e.off("beforeunload.widgets"),e.off("beforeunload.edit-post")}function Ni(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=document.getElementById("frm_field_id_".concat(e));if(t&&"form"===t.dataset.type)if(t=jQuery(t),this.options[this.selectedIndex].value){t.find(".frm-not-set")[0].classList.add("frm_hidden");var r=t.find(".frm-embed-message");r.html(r.data("embedmsg")+this.options[this.selectedIndex].text),t.find(".frm-embed-field-placeholder")[0].classList.remove("frm_hidden")}else t.find(".frm-not-set")[0].classList.remove("frm_hidden"),t.find(".frm-embed-field-placeholder")[0].classList.add("frm_hidden")}function Ti(){var e=jQuery(this).closest(".frm-single-settings"),t=e.find(".frmjs_product_choices"),r=e.find(".frm_prod_options_heading"),n=this.options[this.selectedIndex].value;t.removeClass("frm_prod_type_single frm_prod_type_user_def"),r.removeClass("frm_prod_user_def"),"single"===n?t.addClass("frm_prod_type_single"):"user_def"===n&&(t.addClass("frm_prod_type_user_def"),r.addClass("frm_prod_user_def"))}function Oi(e){var t=document.getElementById("frm_field_id_".concat(e));return!!t&&"product"===t.getAttribute("data-type")}function Fi(){var e=function(e,t){return window.frmCachedSubFields=window.frmCachedSubFields||{},window.frmCachedSubFields[e]=window.frmCachedSubFields[e]||{},window.frmCachedSubFields[e][t]},t=function(e,t,r){window.frmCachedSubFields=window.frmCachedSubFields||{},window.frmCachedSubFields[e]=window.frmCachedSubFields[e]||{},window.frmCachedSubFields[e][t]=r},r=[1,2,3,4,5,6,7,8,9,10,11,12].map(function(e){return"frm".concat(e)}),o=["first","middle","last"];document.addEventListener("change",function(i){i.target.matches(".frm_name_layout_dropdown")&&function(i){var a,l=i.target.value.split("_"),s=i.target.dataset.fieldId,c=document.querySelector("#field_".concat(s,"_inner_container .frm_combo_inputs_container")),d=(a=l.length,"frm".concat(parseInt(12/a)));o.forEach(function(e){var o,i=c.querySelector('[data-sub-field-name="'.concat(e,'"]'));i&&(i.classList.add("frm_hidden"),(o=i.classList).remove.apply(o,n(r)),t(s,e,i))}),l.forEach(function(t){var r=e(s,t);r&&(r.classList.remove("frm_hidden"),r.classList.add(d),c.append(r))}),o.forEach(function(e){var r=document.querySelector(".frm_sub_field_options-".concat(e,'[data-field-id="').concat(s,'"]'));r&&(r.classList.add("frm_hidden"),t(s,"".concat(e,"_options"),r))}),l.forEach(function(t){var r=e(s,"".concat(t,"_options"));r&&r.classList.remove("frm_hidden")})}(i)},!1)}function Di(e,t){var r,n,o,i=!1,a=!1;(r=t.newOption?(new DOMParser).parseFromString(t.newOption,"text/html").body.childNodes[0]:t).querySelectorAll("svg").forEach(function(e){(n=e.getElementsByTagNameNS("http://www.w3.org/2000/svg","use")[0])&&("#frm_drag_icon"===(o=qo(n))&&(i=!0),"#frm_save_icon"===o&&(a=!0))}),i||r.prepend(h.drag.cloneNode(!0)),r.querySelector("[id^=field_key_".concat(e,"-]"))&&!a&&r.querySelector("[id^=field_key_".concat(e,"-]")).after(h.save.cloneNode(!0)),t.newOption&&(t.newOption=r)}function Mi(){var e=document.getElementById("frm_leave_email").value.trim();if(""!==e)if(!1!==/^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(e)){var t=jQuery("#frmapi-email-form").find("form"),r=t.find('[type="email"]').not(".frm_verify");if(r.length){if(document.getElementById("frm_empty_inbox")){document.getElementById("frm-add-my-email-address").remove();var n=document.getElementById("frm_leave_email_wrapper");if(n){n.classList.add("frm_hidden");var o=d({className:"frm-wait frm_spinner"});o.style.visibility="visible",o.style.float="none",o.style.width="unset",n.parentElement.insertBefore(o,n.nextElementSibling)}}r.val(e),jQuery.ajax({type:"POST",url:t.attr("action"),data:"".concat(t.serialize(),"&action=frm_forms_preview")}).done(function(e){if(jQuery(e).find(".frm_message").text().trim().includes("Thanks!")){var t=document.getElementById("frmapi-email-form").parentElement.querySelector(".frm_spinner");t&&t.remove(),wp.hooks.applyFilters("frm_thank_you_on_signup",!0)&&document.getElementById("frm_leave_email_wrapper").replaceWith(d(I("Thank you for signing up!","formidable")))}else pi("invalid")})}}else pi("invalid");else pi("empty")}function Pi(e){var t;if(O||e.stopPropagation(),!(e.target.classList.contains("frm-show-box")||null!==(t=e.target.parentElement)&&void 0!==t&&t.classList.contains("frm-show-box"))){var r=document.getElementById("frm_adv_info");r&&(r.dataset.fills===e.target.id&&void 0!==e.target.id||e.target.closest("#frm_adv_info")||"none"===r.style.display||$o(r))}}return{init:function(){var e,t,o,i,a,l,s;!function(){jQuery(document).on("click","#frm-add-my-email-address",function(e){e.preventDefault(),Mi()});var e=document.getElementById("frm_empty_inbox"),t=document.getElementById("frm_leave_email");if(e&&t){var r=document.getElementById("frm-leave-email-modal");r.classList.remove("frm_hidden"),r.querySelector(".frm_modal_footer").classList.add("frm_hidden"),t.addEventListener("keyup",function(e){if("Enter"===e.key){var t=document.getElementById("frm-add-my-email-address");t&&t.click()}})}}(),t=document.querySelector(".frm-admin-footer-links"),o=null!==(e=document.querySelector(".frm_page_container"))&&void 0!==e?e:document.getElementById("wpbody-content"),t&&o&&(o.append(t),t.classList.remove("frm_hidden")),document.addEventListener("show.bs.dropdown",function(){z()}),C={},jQuery(".wp-admin").on("click",function(e){var t=jQuery(e.target),r=jQuery(".dropdown.open");!r.length||t.hasClass("dropdown")||t.closest(".dropdown").length||r.removeClass("open")}),jQuery("#frm_bs_dropdown:not(.open) a").on("click",At),void 0===E&&(E=jQuery(document.getElementById("form_id")).val()),document.querySelectorAll(".frm-warning-dismiss").forEach(function(e){_(e,St)}),frmAdminBuild.inboxBannerInit(),b.length>0?frmAdminBuild.buildInit():null!==document.getElementById("frm_notification_settings")?frmAdminBuild.settingsInit():null!==document.getElementById("frm_styling_form")?frmAdminBuild.styleInit():null!==document.getElementById("form_global_settings")?frmAdminBuild.globalSettingsInit():null!==document.getElementById("frm_export_xml")?frmAdminBuild.exportInit():null!==document.querySelector(".frm-inbox-wrapper")?frmAdminBuild.inboxInit():null!==document.getElementById("frm-welcome")?frmAdminBuild.solutionInit():(function(){if(document.body.classList.contains("frm-admin-page-entries")){var e=document.getElementById("screen-options-wrap");if(e){var t=c({className:"frm_warning_style",text:I("Only 10 columns can be selected at a time.","formidable")});t.style.margin=0;var r=e.querySelector("legend");r.parentNode.insertBefore(t,r.nextElementSibling);var n=Array.from(e.querySelectorAll('input[type="checkbox"]')),o=function(){n.reduce(function(e,t){return t.checked?e+1:e},0)>=10?(t.classList.remove("frm_hidden"),n.forEach(function(e){e.checked||(e.parentNode.classList.add("frm_noallow"),e.disabled=!0)})):t.classList.add("frm_hidden")};o(),n.forEach(function(e){e.addEventListener("change",function(e){e.target.checked?o():(t.classList.add("frm_hidden"),n.forEach(function(e){e.parentNode.classList.remove("frm_noallow"),e.disabled=!1}))})})}}}(),yi(),jQuery("[data-frmprint]").on("click",function(){return window.print(),!1})),jQuery(document).on("change","select[data-toggleclass], input[data-toggleclass]",xo),function(){function e(e){var t=e.options[e.selectedIndex];e.querySelectorAll("option[data-dependency]:not([data-dependency-skip])").forEach(function(e){var r=document.querySelector(e.dataset.dependency);null==r||r.classList.toggle("frm_hidden",t!==e)})}document.querySelectorAll("select.frm_select_with_dependency").forEach(e),frmDom.util.documentOn("change","select.frm_select_with_dependency",function(t){return e(t.target)})}(),(jQuery(document.getElementById("frm_adv_info")).length>0||jQuery(".frm_field_list").length>0)&&frmAdminBuild.panelInit(),i=jQuery(".wrap, .frm_wrap"),a=document.getElementById("frm_confirm_modal"),l=!1,s=!1,jQuery(a).on("click","[data-deletefield]",Qr),jQuery(a).on("click","[data-removeid]",R),jQuery(a).on("click","[data-trashtemplate]",wi),i.on("click",".frm_remove_tag, .frm_remove_form_action",R),i.on("click","a[data-frmverify]",F),i.on("click","a[data-frmtoggle]",P),i.on("click","a[data-frmhide], a[data-frmshow]",H),i.on("change","input[data-frmhide], input[data-frmshow]",H),i.on("click",".widget-top,a.widget-action",G),i.on("mouseenter.frm",".frm_bstooltip, .frm_help",function(){jQuery(this).off("mouseenter.frm"),function(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],r=e;(r.hasAttribute("data-toggle")||r.hasAttribute("data-bs-toggle"))&&(r.parentElement.setAttribute("title",r.getAttribute("title")),r.removeAttribute("title"),r.classList.remove("frm_bstooltip"),r.parentElement.classList.add("frm_bstooltip"),r=r.parentElement),jQuery(r).tooltip(),t&&(z(),jQuery(r).tooltip("show"))}(this,!0)}),jQuery(document).on("click","#doaction, #doaction2",function(e){var t="doaction"===this.id?"top":"bottom",r=document.getElementById("bulk-action-selector-".concat(t)),n=document.getElementById("confirm-bulk-delete-".concat(t));if(r&&n){if(l=this,!s&&"bulk_delete"===r.value)return e.preventDefault(),D(n),!1}else l=!1}),jQuery(document).on("click","#frm-confirmed-click",function(e){if(!1!==l&&!e.target.classList.contains("frm-btn-inactive"))return"confirm-bulk-delete"===this.getAttribute("href")?(e.preventDefault(),s=!0,l.click(),!1):void 0}),r(4260).initUpgradeModal(),frmDom.util.documentOn("click","[data-modal-title]",Kn);var d=jQuery(document.getElementById("frm_shortcodediv"));d.length>0&&(jQuery("a.edit-frm_shortcode").on("click",function(){return d.is(":hidden")&&(d.slideDown("fast"),this.style.display="none"),!1}),jQuery(".cancel-frm_shortcode","#frm_shortcodediv").on("click",function(){return d.slideUp("fast"),d.siblings("a.edit-frm_shortcode").show(),!1})),jQuery(document).on("click","#frm-nav-tabs a",U),jQuery(".post-type-frm_display .frm-nav-tabs a, .frm-category-tabs a").on("click",function(){var e=this.classList.contains("frm_show_upgrade_tab");if(!this.classList.contains("frm_noallow")||e)return e&&Jn(this),W(this),!1}),W(jQuery(".starttab a"),"auto"),jQuery(document).on("click","#frm-fid-search-menu a",function(){var e=this.id.replace("fid-","");return jQuery('select[name="fid"]').val(e),zn(document.getElementById("posts-filter")),!1}),jQuery(".frm_select_box").on("click focus",function(){this.select()}),jQuery(document).on("input search change",".frm-auto-search:not(#frm-form-templates-page #template-search-input)",Qi),jQuery(document).on("focusin click",".frm-auto-search",Ei);var f=jQuery(".frm-auto-search");""!==f.val()&&f.trigger("keyup"),FrmFormsConnect.init(),jQuery(document).on("click",".frm-install-addon",ui),jQuery(document).on("click",".frm-activate-addon",fi),jQuery(document).on("click",".frm-solution-multiple",di),jQuery("button, input[type=submit]").on("click",Ci),document.addEventListener("click",function(e){if("LABEL"===e.target.nodeName){var t=e.target.getAttribute("for");if(t){var r=document.getElementById(t);if(r&&r.nextElementSibling){var n=r.nextElementSibling.querySelector("button.dropdown-toggle.multiselect");n&&setTimeout(function(){return n.click()},0)}}}}),frmAdminBuild.hooks.addFilter("frm_before_embed_modal",function(e,t){var r,n,o=t.element;if("form"!==t.type)return e;var i=o.closest("tr");if(i)r=parseInt(i.querySelector(".column-id").textContent),n=i.querySelector(".column-form_key").textContent;else{r=document.getElementById("form_id").value;var a=document.getElementById("frm_form_key");if(a)n=a.value;else{var l=document.getElementById("frm-previewDrop");l&&(n=l.nextElementSibling.querySelector(".dropdown-item a").getAttribute("href").split("form=")[1])}}return[r,n]}),document.querySelectorAll("#frm-show-fields > li, .frm_grid_container li").forEach(function(e,t){e.addEventListener("click",function(){var e,t,r;t=(null===(e=this.querySelector("li"))||void 0===e?void 0:e.dataset.fid)||this.dataset.fid,(r=document.querySelectorAll("[id^=frm_delete_field_".concat(t,"-]"))).length<2||n(r).slice(1).forEach(function(e,r){e.classList.contains("frm_other_option")||Di(t,e)})})});var u=document.getElementById("frm_small_screen_proceed_button");u&&_(u,function(){var e;null===(e=document.getElementById("frm_small_device_message_container"))||void 0===e||e.remove(),p("small_screen_proceed",new FormData)});var m=document.getElementById("frm_sale_banner"),g=null==m?void 0:m.querySelector(".dismiss");m&&(_(m,function(e){e.target.closest(".dismiss")||(window.location.href=m.getAttribute("data-url"))}),g&&_(g,function(){m.remove();var e=new FormData;p("sale_banner_dismiss",e)}))},buildInit:function(){jQuery("#frm_builder_page").on("mouseup","*:not(.frm-show-box)",Pi),g=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:100;return frmDom.util.debounce(e,t)}(oe,10),y=document.getElementById("post-body-content"),v=jQuery(y),jQuery(".frm_field_loading").length&&Ee(jQuery(".frm_field_loading").first().attr("id")),V("ul.frm_sorting"),document.querySelectorAll(".field_type_list > li:not(.frm_show_upgrade):not(.frm_show_update)").forEach(X),jQuery("ul.field_type_list, .field_type_list li, ul.frm_code_list, .frm_code_list li, .frm_code_list li a, #frm_adv_info #category-tabs li, #frm_adv_info #category-tabs li a").disableSelection(),jQuery(".frm_submit_ajax").on("click",Hn),jQuery(".frm_submit_no_ajax").on("click",Gn),Wn(),jQuery("a.edit-form-status").on("click",Sn),jQuery(".cancel-form-status").on("click",Ln),jQuery(".save-form-status").on("click",function(){var e=jQuery(document.getElementById("form_change_status")).val();return jQuery('input[name="new_status"]').val(e),jQuery(document.getElementById("form-status-display")).html(e),jQuery(".cancel-form-status").trigger("click"),!1}),jQuery(".frm_form_builder form").first().on("submit",function(){jQuery(".inplace_field").trigger("blur")}),ci(),Fr();var e,t=jQuery(j),r=document.getElementById("frm_form_editor_container");t.on("click",".frm_add_logic_row",Ar),t.on("click",".frm_add_watch_lookup_row",Lr),t.on("change",".frm_get_values_form",Tr),t.on("change",".frm_logic_field_opts",wn),t.on("frm-multiselect-changed",'select[name^="field_options[admin_only_"]',In),jQuery(document.getElementById("frm-insert-fields")).on("click",".frm_add_field",Ae),b.on("click",".frm_clone_field",Be),t.on("blur",'input[id^="frm_calc"]',Je),t.on("change","input.frm_format_opt, input.frm_max_length_opt",lt),t.on("change click","[data-changeme]",it),t.on("click","input.frm_req_field",st),t.on("click",".frm_mark_unique",dt),t.on("change",".frm_repeat_format",Jr),t.on("change",".frm_repeat_limit",Xr),t.on("change",".frm_js_checkbox_limit",Yr),t.on("input",'input[name^="field_options[add_label_"]',function(){Zr(this,"add")}),t.on("input",'input[name^="field_options[remove_label_"]',function(){Zr(this,"remove")}),t.on("change",'select[name^="field_options[data_type_"]',Or),jQuery(r).on("click",".frm-collapse-page",Dr),jQuery(r).on("click",".frm-collapse-section",Hr),t.on("click",".frm-single-settings h3, .frm-single-settings h4.frm-collapsible",zr),t.on("keydown",".frm-single-settings h3, .frm-single-settings h4.frm-collapsible",function(e){"Enter"!==e.key&&" "!==e.key||(e.preventDefault(),zr.call(this,e))}),jQuery(r).on("show.bs.dropdown hide.bs.dropdown",He),t.on("click",".frm_toggle_sep_values",yt),t.on("click",".frm_toggle_image_options",vt),t.on("click",".frm_remove_image_option",Et),t.on("click",".frm_choose_image_box",xt),t.on("change",".frm_hide_image_text",Qt),t.on("change",".frm_field_options_image_size",jt),t.on("click",".frm_multiselect_opt",kt),b.on("mousedown","input, textarea, select",Lt),b.on("click","input[type=radio], input[type=checkbox]",Lt),b.on("click",".frm_delete_field",Nt),b.on("click",".frm_select_field",Tt),jQuery(document).on("click",".frm_delete_field_group",Ot),jQuery(document).on("click",".frm_clone_field_group",Ft),jQuery(document).on("click","#frm_field_group_controls > span:first-child",Dt),jQuery(document).on("click",".frm-row-layout-option",Yt),jQuery(document).on("click",".frm-merge-fields-into-row .frm-row-layout-option",Zt),jQuery(document).on("click",".frm-custom-field-group-layout",tr),jQuery(document).on("click",".frm-merge-fields-into-row .frm-custom-field-group-layout",nr),jQuery(document).on("click",".frm-break-field-group",sr),b.on("click","#frm_field_group_popup .frm_grid_container input",cr),jQuery(document).on("click",".frm-cancel-custom-field-group-layout",dr),jQuery(document).on("click",".frm-save-custom-field-group-layout",ur),b.on("click","ul.frm_sorting",mr),jQuery(document).on("click",".frm-merge-fields-into-row",br),jQuery(document).on("click",".frm-delete-field-groups",wr),b.on("click",'.frm-field-action-icons [data-toggle="dropdown"]',function(){this.closest("li.form-field").classList.add("frm-field-settings-open"),jQuery(document).on("click","#frm_builder_page",Te)}),b.on("mousemove","ul.frm_sorting",Oe),b.on("show.bs.dropdown",".frm-field-action-icons",Me),jQuery(document).on("show.bs.dropdown","#frm_field_group_controls",Pe),t.on("click",".frm_single_option a[data-removeid]",It),t.on("mousedown",".frm_single_option input[type=radio]",Bt),t.on("focusin",".frm_single_option input[type=text]",qt),t.on("click",".frm_add_opt",_t),t.on("change",".frm_single_option input",tn),t.on("change",".frm_image_id",tn),t.on("change",".frm_toggle_mult_sel",pt),b.on("click",".frm_primary_label",Gr),b.on("click",".frm_description",Ur),b.on("click","li.ui-state-default:not(.frm_noallow)",Vr),b.on("dblclick","li.ui-state-default",Kr),t.on("change",".frm_tax_form_select",en),t.on("change","select.conf_field",ft),t.on("change",".frm_get_field_selection",Qn),t.on("click",".frm-show-inline-modal",Cn),t.on("keydown",".frm-show-inline-modal",function(e){var t=e.key;"Enter"!==t&&" "!==t||(e.preventDefault(),Cn.call(this,e))}),t.on("click",".frm-inline-modal .dismiss",Nn),jQuery(document).on("change","[data-frmchange]",On),document.addEventListener("click",Tn),t.on("change",".frm_include_extras_field",et),t.on("change",'select[name^="field_options[form_select_"]',Ni),jQuery(document).on("submit","#frm_js_build_form",Ho),jQuery(document).on("change","#frm_builder_page input:not(.frm-search-input):not(.frm-custom-grid-size-input), #frm_builder_page select, #frm_builder_page textarea",Po),nt(),jQuery(document).on("change",".frmjs_prod_data_type_opt",Ti),jQuery(document).on("focus",'.frm-single-settings ul input[type="text"][name^="field_options[options_"]',Br),jQuery(document).on("blur",'.frm-single-settings ul input[type="text"][name^="field_options[options_"]',Cr),frmDom.util.documentOn("click",".frm-show-field-settings",Vr),frmDom.util.documentOn("change","select.frm_format_dropdown, select.frm_phone_type_dropdown",$r),t.on("keydown",'.frm_single_option input[name^="field_options["], .frm_single_option input[name^="rows_"]',function(e){"Enter"===e.key&&function(e){var t=e.closest(".frm_single_option").parentElement.querySelectorAll('.frm_single_option input[name^="field_options[" ], .frm_single_option input[name^="rows_"]'),r=Array.from(t),n=r.indexOf(e);if(!(n<0)){var o=r.slice(n+1).find(function(e){return null!==e.offsetParent});if(o){o.focus();var i=o.value.length;o.setSelectionRange(i,i)}}}(e.currentTarget)}),!1!==(e=Bi("#frm-bulk-modal","700px"))&&(jQuery(".frm-insert-preset").on("click",mt),jQuery(j).on("click","a.frm-bulk-edit-link",function(t){t.preventDefault();var r="",n=jQuery(this).closest("[data-fid]").data("fid"),o=yn(n),i=Oi(n),a=document.getElementById("frm_field_".concat(n,"_opts"));if(a){var l=a.getElementsByTagName("li");document.getElementById("bulk-field-id").value=n;for(var s=0;s=l.length-1&&(document.getElementById("frm_bulk_options").value=r)}return e.dialog("open"),!1}}),jQuery("#frm-update-bulk-opts").on("click",function(){var t=document.getElementById("bulk-field-id").value;document.getElementById("bulk-option-type").value||(this.classList.add("frm_loading_button"),frmAdminBuild.updateOpts(t,document.getElementById("frm_bulk_options").value,e),Po())})),qn(),document.addEventListener("frm_added_field",qn),Ie(),Fi(),kn(),frmDom.util.documentOn("change",".frm_show_password_setting_input",function(e){var t=e.target.getAttribute("data-fid"),r=document.getElementById("frm_field_id_".concat(t));r&&r.classList.toggle("frm_disabled_show_password",!e.target.checked)}),document.addEventListener("scroll",Fo,!0),document.addEventListener("change",To),document.querySelector(".frm_form_builder").addEventListener("mousedown",function(e){e.shiftKey&&e.preventDefault()}),wp.hooks.addAction("frmShowedFieldSettings","formidableAdmin",function(e,t){t.querySelectorAll(".frm-collapse-me").forEach(Rr)},9999)},settingsInit:function(){var e=jQuery(document.getElementById("frm_notification_settings"));e.on("click",".frm_email_buttons",io),e.on("click",".frm_remove_field",ao),e.on("change",".frm_to_row, .frm_from_row",lo),e.on("change",".frm_tax_selector",wo),e.on("change","select.frm_single_post_field",_o),e.on("change","select.frm_toggle_post_content",po),e.on("change","select.frm_dyncontent_opt",go),e.on("change",".frm_post_type",yo),e.on("click",".frm_add_postmeta_row",bo),e.on("click",".frm_add_posttax_row",ho),e.on("click",".frm_toggle_cf_opts",Qo),e.on("click",".frm_duplicate_form_action",Zn),jQuery(".frm_actions_list").on("click",".frm_active_action",to),jQuery("#frm-show-groups, #frm-hide-groups").on("click",ro),ci(),jQuery("ul.frm_actions_list li").each(function(){so(jQuery(this).children("a").data("actiontype"));var e=jQuery(this).find("i");"none"!==e.css("background-image")&&e.addClass("frm-inverse")}),jQuery(".frm_submit_settings_btn").on("click",Eo),Wn();var t=jQuery(".frm_form_settings");t.on("click",".frm_add_form_logic",mo),t.on("click",".frm_already_used",uo),document.addEventListener("click",function(e){var t=e.target;t.closest(".frm_image_preview_wrapper")&&(t.closest(".frm_choose_image_box")?xt.bind(t)(e):t.closest(".frm_remove_image_option")&&Et.bind(t)(e))}),t.on("mouseup","*:not(.frm-show-box)",Pi),jQuery(document.getElementById("no_save")).on("change",function(){this.checked&&!0!==confirm(i.no_save_warning)&&jQuery(this).attr("checked",!1)}),jQuery('select[name="options[edit_action]"]').on("change",Yn);var r=document.getElementById("logged_in");jQuery(r).on("change",function(){this.checked?Ii(".hide_logged_in"):Li(".hide_logged_in")});var n=jQuery(document.getElementById("frm_cookie_expiration"));jQuery(document.getElementById("frm_single_entry_type")).on("change",function(){"cookie"===this.value?n.fadeIn("slow"):n.fadeOut("slow")});var o=document.getElementById("single_entry");jQuery(o).on("change",function(){this.checked?Ii(".hide_single_entry"):Li(".hide_single_entry"),this.checked&&"cookie"===jQuery(document.getElementById("frm_single_entry_type")).val()?n.fadeIn("slow"):n.fadeOut("slow")}),jQuery(".hide_save_draft").hide();var a=jQuery(document.getElementById("save_draft"));a.on("change",function(){this.checked?jQuery(".hide_save_draft").fadeIn("slow"):jQuery(".hide_save_draft").fadeOut("slow")}),Rn(a);var l=document.getElementById("editable");jQuery(l).on("change",function(){this.checked?(jQuery(".hide_editable").fadeIn("slow"),Rn(document.getElementById("edit_action"))):(jQuery(".hide_editable").fadeOut("slow"),jQuery(".edit_action_message_box").fadeOut("slow"))}),jQuery(document).on("change","#protect_files",function(){this.checked?jQuery(".hide_protect_files").fadeIn("slow"):jQuery(".hide_protect_files").fadeOut("slow")}),jQuery(document).on("frm-multiselect-changed","#protect_files_role",In),jQuery(document).on("submit",".frm_form_settings",zo),jQuery(document).on("change","#form_settings_page input:not(.frm-search-input), #form_settings_page select, #form_settings_page textarea",Po),yi(),jQuery(document).on("frm-action-loaded",Jo),frmDom.util.documentOn("change",'.frm_on_submit_type input[type="radio"]',function(e){if(e.target.checked){var t=e.target.closest(".frm_form_action_settings");t.querySelectorAll(".frm_on_submit_dependent_setting:not(.frm_hidden)").forEach(function(e){e.classList.add("frm_hidden")}),t.querySelectorAll(".frm_on_submit_dependent_setting[data-show-if-".concat(e.target.value,"]")).forEach(function(e){e.classList.remove("frm_hidden")}),t.setAttribute("data-on-submit-type",e.target.value)}}),wp.hooks.addAction("frm_reset_fields_updated","formidableAdmin",Ro)},panelInit:function(){jQuery(".frm_wrap, #postbox-container-1").on("click",".frm_insert_code",ko),jQuery(document).on("change",".frm_insert_val",function(){Ao(jQuery(this).data("target"),jQuery(this).val()),jQuery(this).val("")}),jQuery(document).on("click change",'[name="frm-id-key-condition"]',Io),jQuery(document).on("keyup change",".frm-build-logic",Bo),Xn(),jQuery(document).on("frmElementAdded",function(e,t){Xn(t)}),jQuery(document).on("mousedown",".frm-show-box",No);var e=document.getElementById("form_settings_page"),t=document.body.classList.contains("post-type-frm_display"),r=document.getElementById("frm_insert_fields_tab");(e||t||O)&&jQuery(document).on("focusin","form input, form textarea",function(n){var o,i,a;if(n.stopPropagation(),Co(this),jQuery(this).is(":not(:submit, input[type=button], .frm-search-input, input[type=checkbox])")){if(jQuery(n.target).closest("#frm_adv_info").length)return;if(e||O)o=jQuery("#frm_html_tab"),jQuery(this).closest("#html_settings").length>0?(o.show(),o.siblings().hide(),jQuery("#frm_html_tab a").trigger("click"),void 0===(a=this.id)||a.includes("-search-input")||(jQuery("#frm-adv-info-tab").attr("data-fills",a.trim()),this.classList.contains("field_custom_html")&&(a="field_custom_html"),jQuery.inArray(a,["after_html","before_html","submit_html","field_custom_html"])>=0&&(jQuery(".frm_code_list li:not(.show_".concat(a,")")).addClass("frm_hidden"),jQuery(".frm_code_list li.show_".concat(a)).removeClass("frm_hidden")))):((i=jQuery(".frm-category-tabs li"))[0]&&(i[0].style.display=""),r.click(),o.hide(),o.siblings().show());else if(t){var l=new CustomEvent("frm_legacy_views_handle_field_focus");l.frmData={idAttrValue:this.id},document.dispatchEvent(l)}}}),jQuery(".frm_wrap, #postbox-container-1").on("mousedown","#frm_adv_info a, .frm_field_list a",function(e){e.preventDefault()});var n=jQuery("#frm_adv_info");n.on("click",".subsubsub a.frmids",function(e){Ko("frmids",e)}),n.on("click",".subsubsub a.frmkeys",function(e){Ko("frmkeys",e)})},inboxInit:function(){var e;jQuery(".frm_inbox_dismiss").on("click",function(e){var t=this.parentNode.parentNode,r=t.getAttribute("data-message"),n=this.getAttribute("href"),o=t.cloneNode(!0),i=document.querySelector(".frm-dismissed-inbox-messages");if("free_templates"!==r||this.classList.contains("frm_inbox_dismiss")){e.preventDefault();var a={action:"frm_inbox_dismiss",key:r,nonce:frmGlobal.nonce},l="frm_inbox_slide_in"===t.id;l&&(t.classList.remove("s11-fadein"),t.classList.add("s11-fadeout"),t.addEventListener("animationend",function(){return t.remove()},{once:!0})),Ai(a,function(){if(!l)return"#"!==n?(window.location=n,!0):void Si(t,function(){var e;i&&(o.classList.remove("frm-fade"),null===(e=o.querySelector(".frm-inbox-message-heading .frm_inbox_dismiss"))||void 0===e||e.remove(),i.append(o)),1===t.parentNode.querySelectorAll(".frm-inbox-message-container").length&&(document.getElementById("frm_empty_inbox").classList.remove("frm_hidden"),t.parentNode.closest(".frm-active").classList.add("frm-empty-inbox"),_i()),t.remove()})})}}),!1===(null===(e=document.getElementById("frm_empty_inbox"))||void 0===e?void 0:e.classList.contains("frm_hidden"))&&_i()},solutionInit:function(){jQuery(document).on("submit","#frm-new-template",hi)},styleInit:function(){var e=jQuery(".frm_image_preview_wrapper");e.on("click",".frm_choose_image_box",xt),e.on("click",".frm_remove_image_option",Et),wp.hooks.doAction("frm_style_editor_init")},customCSSInit:function(){console.warn("Calling frmAdminBuild.customCSSInit is deprecated.")},globalSettingsInit:function(){jQuery(document).on("click","[data-frmuninstall]",Xo),ci();var e=document.getElementById("licenses_settings");e&&jQuery(e).on("click",".edd_frm_save_license",Yo),jQuery(document).on("click","#frm-new-template button",vi),jQuery("#frm-dismissable-cta .dismiss").on("click",function(e){e.preventDefault(),jQuery.post(ajaxurl,{action:"frm_lite_settings_upgrade",nonce:frmGlobal.nonce}),jQuery(".settings-lite-cta").remove()});var t=document.getElementById("frm_re_type");t&&t.addEventListener("change",ji),document.querySelector(".frm_captchas").addEventListener("change",function(e){var t,r=null===(t=document.querySelector('.frm_captchas input[checked="checked"]'))||void 0===t?void 0:t.value,n=e.target.value!==r;document.querySelector(".captcha_settings .frm_note_style").classList.toggle("frm_hidden",!n)}),frmDom.util.documentOn("submit",".frm_settings_form",function(){x=0});var r=document.getElementById("manage_styles_settings");r&&r.addEventListener("change",function(e){var t=e.target;"SELECT"===t.nodeName&&t.dataset.name&&!t.getAttribute("name")&&t.setAttribute("name",t.dataset.name)});var n=document.getElementById("payments_settings"),o=null==n?void 0:n.querySelectorAll('[name="frm_payment_section"]');o&&o.forEach(function(e){e.addEventListener("change",function(){if(e.checked){var t=n.querySelector('label[for="'.concat(e.id,'"]'));t&&t.setAttribute("aria-selected","true"),o.forEach(function(t){if(t!==e){var r=n.querySelector('label[for="'.concat(t.id,'"]'));r&&r.setAttribute("aria-selected","false")}})}})})},exportInit:function(){jQuery(".frm_form_importer").on("submit",Zo),jQuery(document.getElementById("frm_export_xml")).on("submit",ti),jQuery("#frm_export_xml input, #frm_export_xml select").on("change",ri),jQuery('input[name="frm_import_file"]').on("change",ni),document.querySelector('select[name="format"]').addEventListener("change",ii),jQuery('input[name="frm_export_forms[]"]').on("click",si),ci(),jQuery(".frm-feature-banner .dismiss").on("click",function(e){e.preventDefault(),jQuery.post(ajaxurl,{action:"frm_dismiss_migrator",plugin:this.id,nonce:frmGlobal.nonce}),this.parentElement.remove()}),li(oi()),document.querySelector("#frm-export-select-all").addEventListener("change",function(e){document.querySelectorAll('[name="frm_export_forms[]"]').forEach(function(t){t.checked=e.target.checked})})},inboxBannerInit:function(){var e=document.getElementById("frm_banner");if(e){var t=e.querySelector(".frm-banner-dismiss");document.addEventListener("click",function(r){r.target===t&&Ai({action:"frm_inbox_dismiss",key:e.dataset.key,nonce:frmGlobal.nonce},function(){jQuery(e).fadeOut(400,function(){e.remove()})})})}},updateOpts:function(e,t,r){var n=yn(e),o=Oi(e)?"frm_bulk_products":"frm_import_options";jQuery.ajax({type:"POST",url:ajaxurl,data:{action:o,field_id:e,opts:t,separate:n,nonce:frmGlobal.nonce},success:function(t){document.getElementById("frm_field_".concat(e,"_opts")).innerHTML=t,wp.hooks.doAction("frm_after_bulk_edit_opts",e),on(e),void 0!==r&&(r.dialog("close"),document.getElementById("frm-update-bulk-opts").classList.remove("frm_loading_button"))}})},triggerRemoveLogic:function(e,t){jQuery("#frm_logic_".concat(e,"_").concat(t," .frm_remove_tag")).trigger("click")},downloadXML:function(e,t,r){var n="".concat(ajaxurl,"?action=frm_").concat(e,"_xml&ids=").concat(t);null!==r&&(n="".concat(n,"&is_template=").concat(r)),location.href=n},hooks:{applyFilters:function(e){for(var t,r=arguments.length,n=new Array(r>1?r-1:0),o=1;o1?r-1:0),o=1;o1&&void 0!==arguments[1]?arguments[1]:{};return new Promise(function(r){var n=E,o=0;"summary"===e&&(o=b.children('li[data-type="break"]').length>0?1:0),jQuery.ajax({type:"POST",url:ajaxurl,data:Object.assign(_e(e,0,n,o),{field_options:t}),success:function(t){r(t),setTimeout(function(){En(),We(t,!0);var r=ye(t);r&&wp.hooks.doAction("frm_after_field_added_in_form_builder",{field:t,fieldId:r,fieldType:e,form_id:n})},10)},error:he})})},confirmLinkClick:D,handleInsertFieldByDraggingResponse:ge,handleAddFieldClickResponse:Le,syncLayoutClasses:ae,moveFieldSettings:oo,maybeCollapseSettings:zr}},window.frmAdminBuild=frmAdminBuildJS(),jQuery(document).ready(function(){var e;frmAdminBuild.init(),document.querySelectorAll(".frm-dropdown-menu").forEach(function(e){e.classList.add("dropdown-menu");var t,r,n=e.querySelector(".frm-dropdown-toggle");n&&(n.hasAttribute("role")||n.setAttribute("role","button"),n.hasAttribute("tabindex")||n.setAttribute("tabindex",0)),"UL"===e.tagName&&(r=(r=(r=(r=(r=(r=(t=e).outerHTML).replace("
      ","")).replaceAll("
    • ",'
    • ",""),t.outerHTML=r)}),null===(e=document.querySelector(".preview.dropdown .frm-dropdown-toggle"))||void 0===e||e.setAttribute("data-bs-toggle","dropdown"),document.querySelectorAll("[data-toggle]").forEach(function(e){return e.setAttribute("data-bs-toggle",e.getAttribute("data-toggle"))})}),window.frm_show_div=function(e,t,r,n){t==r?jQuery(n+e).fadeIn("slow").css("visibility","visible"):jQuery(n+e).fadeOut("slow")},window.frmCheckAll=function(e,t){jQuery('input[name^="'.concat(t,'"]')).prop("checked",Boolean(e))},window.frmCheckAllLevel=function(e,t,r){jQuery(".frm_catlevel_".concat(r)).children(".frm_checkbox").children("label").children('input[name^="'.concat(t,'"]')).prop("checked",Boolean(e))},window.frmGetFieldValues=function(e,t,r,n,o,i){e&&jQuery.ajax({type:"POST",url:ajaxurl,data:"action=frm_get_field_values¤t_field=".concat(t,"&field_id=").concat(e,"&name=").concat(o,"&t=").concat(n,"&form_action=").concat(jQuery('input[name="frm_action"]').val(),"&nonce=").concat(frmGlobal.nonce),success:function(e){document.getElementById("frm_show_selected_values_".concat(t,"_").concat(r)).innerHTML=e,"function"==typeof i&&i()}})},window.frmImportCsv=function(e){var t="";"undefined"!=typeof __FRMURLVARS&&(t=__FRMURLVARS),jQuery.ajax({type:"POST",url:ajaxurl,data:"action=frm_import_csv&nonce=".concat(frmGlobal.nonce,"&frm_skip_cookie=1").concat(t),success:function(t){var r=jQuery(".frm_admin_progress_bar").attr("aria-valuemax"),n=r-t,o=n/r*100;jQuery(".frm_admin_progress_bar").css("width","".concat(o,"%")).attr("aria-valuenow",n),parseInt(t,10)>0?(jQuery(".frm_csv_remaining").html(t),frmImportCsv(e)):(jQuery(document.getElementById("frm_import_message")).html(frm_admin_js.import_complete),setTimeout(function(){location.href="?page=formidable-entries&frm_action=list&form=".concat(e,"&import-message=1")},2e3))}})}})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/admin/addon-state.js": +/*!*************************************!*\ + !*** ./js/src/admin/addon-state.js ***! + \*************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addonError: () => (/* binding */ addonError), +/* harmony export */ afterAddonInstall: () => (/* binding */ afterAddonInstall), +/* harmony export */ extractErrorFromAddOnResponse: () => (/* binding */ extractErrorFromAddOnResponse), +/* harmony export */ toggleAddonState: () => (/* binding */ toggleAddonState) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } + +var _frmDom = frmDom, + div = _frmDom.div, + svg = _frmDom.svg; + +/** + * Toggles the state of an add-on (ie. enable or disable an add-on). + * + * @param {Element} clicked + * @param {string} action + */ +function toggleAddonState(clicked, action) { + var _window$ajaxurl; + var ajaxurl = (_window$ajaxurl = window.ajaxurl) !== null && _window$ajaxurl !== void 0 ? _window$ajaxurl : frm_js.ajax_url; + + // Remove any leftover error messages, output an icon and get the plugin basename that needs to be activated. + jQuery('.frm-addon-error').remove(); + var button = jQuery(clicked); + var plugin = button.attr('rel'); + var el = button.parent(); + var message = el.parent().find('.addon-status-label'); + button.addClass('frm_loading_button'); + + // Process the Ajax to perform the activation. + jQuery.ajax({ + url: ajaxurl, + type: 'POST', + async: true, + cache: false, + dataType: 'json', + data: { + action: action, + nonce: frmGlobal.nonce, + plugin: plugin + }, + success: function success(response) { + var _response$data, _response; + response = (_response$data = (_response = response) === null || _response === void 0 ? void 0 : _response.data) !== null && _response$data !== void 0 ? _response$data : response; + var saveAndReload; + if ('string' !== typeof response && 'string' === typeof response.message) { + if (response.saveAndReload !== undefined) { + saveAndReload = response.saveAndReload; + } + response = response.message; + } + var error = extractErrorFromAddOnResponse(response); + if (error) { + addonError(error, el, button); + return; + } + afterAddonInstall(response, button, message, el, saveAndReload, action); + + /** + * Trigger an action after successfully toggling the addon state. + * + * @param {Object} response + */ + wp.hooks.doAction('frm_update_addon_state', response); + }, + error: function error() { + button.removeClass('frm_loading_button'); + } + }); +} +function extractErrorFromAddOnResponse(response) { + if (typeof response !== 'string') { + if (response.success) { + return false; + } + if (response.form) { + if (jQuery(response.form).is('#message')) { + return { + message: jQuery(response.form).find('p').html() + }; + } + } + return response; + } + return false; +} +function afterAddonInstall(response, button, message, el, saveAndReload) { + var action = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 'frm_activate_addon'; + var frmAdminJs = frm_admin_js; + var addonStatuses = document.querySelectorAll('.frm-addon-status'); + addonStatuses.forEach(function (addonStatus) { + addonStatus.textContent = response; + addonStatus.style.display = 'block'; + }); + + // The Ajax request was successful, so let's update the output. + button.css({ + opacity: '0' + }); + document.querySelectorAll('.frm-oneclick').forEach(function (oneClick) { + oneClick.style.display = 'none'; + }); + showUpgradeModalSuccess(); + + // Proceed with CSS changes + var actionMap = { + frm_activate_addon: { + class: 'frm-addon-active', + message: frmAdminJs.active + }, + frm_deactivate_addon: { + class: 'frm-addon-installed', + message: frmAdminJs.installed + }, + frm_uninstall_addon: { + class: 'frm-addon-not-installed', + message: frmAdminJs.not_installed + } + }; + actionMap.frm_install_addon = actionMap.frm_activate_addon; + var _message = _slicedToArray(message, 1), + messageElement = _message[0]; + if (messageElement) { + messageElement.textContent = actionMap[action].message; + } + var _el = _slicedToArray(el, 1), + parentElement = _el[0].parentElement; + parentElement.classList.remove('frm-addon-not-installed', 'frm-addon-installed', 'frm-addon-active'); + parentElement.classList.add(actionMap[action].class); + var _button = _slicedToArray(button, 1), + buttonElement = _button[0]; + buttonElement.classList.remove('frm_loading_button'); + + // Maybe refresh import and SMTP pages + var refreshPage = document.querySelectorAll('.frm-admin-page-import, #frm-admin-smtp, #frm-welcome'); + if (refreshPage.length > 0) { + window.location.reload(); + return; + } + if (['settings', 'form_builder'].includes(saveAndReload)) { + addonStatuses.forEach(function (addonStatus) { + var inModal = null !== addonStatus.closest('#frm_upgrade_modal'); + addonStatus.append(getSaveAndReloadSettingsOptions(saveAndReload, inModal)); + }); + } +} +function addonError(response, el, button) { + if (response.form) { + jQuery('.frm-inline-error').remove(); + button.closest('.frm-card').html(response.form).css({ + padding: 5 + }).find('#upgrade').attr('rel', button.attr('rel')).on('click', installAddonWithCreds); + } else { + el.append("

      ".concat(response.message, "

      ")); + button.removeClass('frm_loading_button'); + jQuery('.frm-addon-error').delay(4000).fadeOut(); + } +} +function getSaveAndReloadSettingsOptions(saveAndReload, inModal) { + var className = 'frm-save-and-reload-options'; + var children = [saveAndReloadSettingsButton(saveAndReload)]; + if (inModal) { + children.push(closePopupButton()); + } + return div({ + className: className, + children: children + }); +} +function saveAndReloadSettingsButton(saveAndReload) { + var button = document.createElement('button'); + button.classList.add('frm-save-and-reload', 'button', 'button-primary', 'frm-button-primary'); + button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Save and Reload', 'formidable'); + button.addEventListener('click', function () { + if (saveAndReload === 'form_builder') { + saveAndReloadFormBuilder(); + } else if (saveAndReload === 'settings') { + saveAndReloadSettings(); + } + }); + return button; +} +function saveAndReloadSettings() { + var page = document.getElementById('form_settings_page'); + if (page) { + var form = page.querySelector('form.frm_form_settings'); + if (null !== form) { + wp.hooks.doAction('frm_reset_fields_updated'); + form.submit(); + } + } +} +function closePopupButton() { + var a = document.createElement('a'); + a.setAttribute('href', '#'); + a.classList.add('button', 'button-secondary', 'frm-button-secondary', 'dismiss'); + a.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Not Now', 'formidable'); + return a; +} +function saveAndReloadFormBuilder() { + var submitButton = document.getElementById('frm_submit_side_top'); + if (submitButton.classList.contains('frm_submit_ajax')) { + submitButton.setAttribute('data-new-addon-installed', true); + } + submitButton.click(); +} + +/** + * Updates the upgrade modal to show successful addon installation state. + * + * @private + * @return {void} + */ +function showUpgradeModalSuccess() { + var upgradeModal = document.getElementById('frm_upgrade_modal'); + if (!upgradeModal) { + return; + } + upgradeModal.classList.add('frm-success'); + var upgradeMessage = upgradeModal.querySelector('.frm-upgrade-message'); + if (upgradeMessage) { + var image = upgradeMessage.querySelector('img'); + upgradeMessage.replaceChildren((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Great! Everything\'s ready to go!', 'formidable'), document.createElement('br'), (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You just need to refresh the builder so the new field becomes available.', 'formidable')); + if (image) { + upgradeMessage.append(image); + } + } + var frmAddonStatus = document.querySelector('.frm-addon-status'); + if (frmAddonStatus) { + frmAddonStatus.textContent = ''; + } + var circledIcon = upgradeModal.querySelector('.frm-circled-icon'); + if (circledIcon) { + var _circledIcon$querySel; + circledIcon.classList.add('frm-circled-icon-green'); + (_circledIcon$querySel = circledIcon.querySelector('svg')) === null || _circledIcon$querySel === void 0 || _circledIcon$querySel.replaceWith(svg({ + href: '#frm_checkmark_icon' + })); + } +} +function installAddonWithCreds(e) { + // Prevent the default action, let the user know we are attempting to install again and go with it. + e.preventDefault(); + + // Now let's make another Ajax request once the user has submitted their credentials. + var proceed = jQuery(this); + var el = proceed.parent().parent(); + var plugin = proceed.attr('rel'); + proceed.addClass('frm_loading_button'); + jQuery.ajax({ + url: ajaxurl, + type: 'POST', + async: true, + cache: false, + dataType: 'json', + data: { + action: 'frm_install_addon', + nonce: frmAdminJs.nonce, + plugin: plugin, + hostname: el.find('#hostname').val(), + username: el.find('#username').val(), + password: el.find('#password').val() + }, + success: function success(response) { + var _response$data2, _response2; + response = (_response$data2 = (_response2 = response) === null || _response2 === void 0 ? void 0 : _response2.data) !== null && _response$data2 !== void 0 ? _response$data2 : response; + var error = extractErrorFromAddOnResponse(response); + if (error) { + addonError(error, el, proceed); + return; + } + afterAddonInstall(response, proceed, message, el); + }, + error: function error() { + proceed.removeClass('frm_loading_button'); + } + }); +} + +/***/ }), + +/***/ "./js/src/admin/upgrade-popup.js": +/*!***************************************!*\ + !*** ./js/src/admin/upgrade-popup.js ***! + \***************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addOneClick: () => (/* binding */ addOneClick), +/* harmony export */ initModal: () => (/* binding */ initModal), +/* harmony export */ initUpgradeModal: () => (/* binding */ initUpgradeModal) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); + +var _frmDom = frmDom, + svg = _frmDom.svg; +function getShowLinkHrefValue(link, showLink) { + var customLink = link.getAttribute('data-link'); + if (customLink === null || customLink === undefined || customLink === '') { + customLink = showLink.getAttribute('data-default'); + } + return customLink; +} + +/** + * Allow addons to be installed from the upgrade modal. + * + * @param {Element} link + * @param {string} context Either 'modal' or 'tab'. + * @param {string|undefined} upgradeLabel + */ +function addOneClick(link, context, upgradeLabel) { + var container; + if ('modal' === context) { + container = document.getElementById('frm_upgrade_modal'); + } else if ('tab' === context) { + container = document.getElementById(link.getAttribute('href').substr(1)); + } else { + return; + } + var oneclickMessage = container.querySelector('.frm-oneclick'); + var upgradeMessage = container.querySelector('.frm-upgrade-message'); + var showLink = container.querySelector('.frm-upgrade-link'); + var button = container.querySelector('.frm-oneclick-button'); + var addonStatus = container.querySelector('.frm-addon-status'); + var oneclick = link.getAttribute('data-oneclick'); + var newMessage = link.getAttribute('data-message'); + var showIt = 'block'; + var showMsg = 'block'; + var hideIt = 'none'; + var modalIconWrapper = container.querySelector('.frm-circled-icon'); + if (modalIconWrapper) { + var _modalIconWrapper$que; + modalIconWrapper.classList.remove('frm-circled-icon-green'); + (_modalIconWrapper$que = modalIconWrapper.querySelector('svg')) === null || _modalIconWrapper$que === void 0 || _modalIconWrapper$que.replaceWith(svg({ + href: '#frm_filled_lock_icon' + })); + } + var learnMoreLink = container.querySelector('.frm-learn-more'); + if (learnMoreLink) { + learnMoreLink.href = link.dataset.learnMore; + } + + // If one click upgrade, hide other content. + if (oneclickMessage !== null && button !== null && oneclick !== undefined && oneclick) { + if (newMessage === null) { + showMsg = 'none'; + } + showIt = 'none'; + hideIt = 'block'; + oneclick = JSON.parse(oneclick); + button.className = button.className.replace(' frm-install-addon', '').replace(' frm-activate-addon', ''); + button.className = "".concat(button.className, " ").concat(oneclick.class); + button.rel = oneclick.url; + oneclickMessage.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('This plugin is not activated. Would you like to activate it now?', 'formidable'); + button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Activate', 'formidable'); + var linkIcon = link.querySelector('use'); + if (linkIcon) { + modalIconWrapper === null || modalIconWrapper === void 0 || modalIconWrapper.querySelector('svg').replaceWith(svg({ + href: linkIcon.getAttribute('href') || linkIcon.getAttribute('xlink:href'), + // Get the icon from xlink:href if it has not been updated to use href + classList: ['frm_svg32'] + })); + } + } + if (!newMessage) { + newMessage = upgradeMessage.getAttribute('data-default'); + } + if (undefined !== upgradeLabel) { + newMessage = newMessage.replace('', upgradeLabel); + } + upgradeMessage.innerHTML = newMessage; + if (link.dataset.upsellImage) { + upgradeMessage.append(frmDom.img({ + src: link.dataset.upsellImage, + alt: link.dataset.upgrade + })); + } + + // Either set the link or use the default. + showLink.href = getShowLinkHrefValue(link, showLink); + addonStatus.style.display = 'none'; + if (oneclickMessage) { + oneclickMessage.style.display = hideIt; + } + if (button) { + button.style.display = hideIt === 'block' ? 'inline-block' : hideIt; + } + upgradeMessage.style.display = showMsg; + showLink.style.display = showIt === 'block' ? 'inline-block' : showIt; + var showLinkParent = showLink.closest('.frm-upgrade-modal-actions'); + if (showLinkParent) { + showLinkParent.style.display = showIt === 'block' ? 'flex' : showIt; + } +} +function initModal(id, width) { + var $info = jQuery(id); + if (!$info.length) { + return false; + } + if (width === undefined) { + width = '552px'; + } + var dialogArgs = { + dialogClass: 'frm-dialog', + modal: true, + autoOpen: false, + closeOnEscape: true, + width: width, + resizable: false, + draggable: false, + open: function open() { + jQuery('.ui-dialog-titlebar').addClass('frm_hidden').removeClass('ui-helper-clearfix'); + jQuery('#wpwrap').addClass('frm_overlay'); + jQuery('.frm-dialog').removeClass('ui-widget ui-widget-content ui-corner-all'); + $info.removeClass('ui-dialog-content ui-widget-content'); + bindClickForDialogClose($info); + }, + close: function close() { + jQuery('#wpwrap').removeClass('frm_overlay'); + jQuery('.spinner').css('visibility', 'hidden'); + this.removeAttribute('data-option-type'); + var optionType = document.getElementById('bulk-option-type'); + if (optionType) { + optionType.value = ''; + } + } + }; + $info.dialog(dialogArgs); + return $info; +} +function bindClickForDialogClose($modal) { + var closeModal = function closeModal() { + $modal.dialog('close'); + }; + jQuery('.ui-widget-overlay').on('click', closeModal); + $modal.on('click', 'a.dismiss', closeModal); +} +function initUpgradeModal() { + var $info = initModal('#frm_upgrade_modal'); + if ($info === false) { + return; + } + document.addEventListener('click', handleUpgradeClick); + frmDom.util.documentOn('change', 'select.frm_select_with_upgrade', handleUpgradeClick); + function handleUpgradeClick(event) { + var element; + var link; + var content; + element = event.target; + if (!element.classList) { + return; + } + var showExpiredModal = element.classList.contains('frm_show_expired_modal') || null !== element.querySelector('.frm_show_expired_modal') || element.closest('.frm_show_expired_modal'); + + // If a `select` element is clicked, check if the selected option has a 'data-upgrade' attribute + if (event.type === 'change' && element.classList.contains('frm_select_with_upgrade')) { + var selectedOption = element.options[element.selectedIndex]; + if (selectedOption && selectedOption.dataset.upgrade) { + element = selectedOption; + } + } + if (!element.dataset.upgrade) { + var parent = element.closest('[data-upgrade]'); + if (!parent) { + parent = element.closest('.frm_field_box'); + if (!parent) { + return; + } + // Fake it if it's missing to avoid error. + element.dataset.upgrade = ''; + } + element = parent; + } + if (showExpiredModal) { + var hookName = 'frm_show_expired_modal'; + wp.hooks.doAction(hookName, element); + return; + } + var upgradeLabel = element.dataset.upgrade; + if (!upgradeLabel || element.classList.contains('frm_show_upgrade_tab')) { + return; + } + event.preventDefault(); + var modal = $info.get(0); + modal.classList.remove('frm-success'); + var lockIcon = modal.querySelector('.frm_lock_icon'); + if (lockIcon) { + lockIcon.style.display = 'block'; + lockIcon.classList.remove('frm_lock_open_icon'); + lockIcon.querySelector('use').setAttribute('href', '#frm_lock_icon'); + } + var upgradeImageId = 'frm_upgrade_modal_image'; + var oldImage = document.getElementById(upgradeImageId); + if (oldImage) { + oldImage.remove(); + } + if (element.dataset.image && lockIcon) { + lockIcon.style.display = 'none'; + lockIcon.parentNode.insertBefore(frmDom.img({ + id: upgradeImageId, + src: "".concat(frmGlobal.url, "/images/").concat(element.dataset.image) + }), lockIcon); + } + var level = modal.querySelector('.license-level'); + if (level) { + level.textContent = getRequiredLicenseFromTrigger(element); + } + + // If one click upgrade, hide other content + addOneClick(element, 'modal', upgradeLabel); + var notInstalled = modal.querySelector('.frm_are_not_installed'); + notInstalled.style.display = element.dataset.image || element.dataset.oneclick ? 'none' : 'inline-block'; + notInstalled.textContent = notInstalled.dataset.default; + modal.querySelector('.frm-upgrade-modal-title-prefix').style.display = element.dataset.oneclick ? 'inline' : 'none'; + modal.querySelector('.frm_feature_label').textContent = upgradeLabel; + modal.querySelector('.frm-upgrade-modal-title-suffix').style.display = 'none'; + modal.querySelector('h2').style.display = 'block'; + $info.dialog('open'); + + // set the utm medium + var button = modal.querySelector('.button-primary:not(.frm-oneclick-button)'); + link = button.getAttribute('href').replace(/(medium=)[a-z_-]+/ig, "$1".concat(element.getAttribute('data-medium'))); + content = element.getAttribute('data-content'); + if (content === null) { + content = ''; + } + link = link.replace(/(content=)[a-z_-]+/ig, "$1".concat(content)); + button.setAttribute('href', link); + if (element.classList.contains('frm_show_update')) { + applyUpdateModalOverrides(modal); + } + } +} + +/** + * Override upgrade modal content for update prompts. + * + * @since 6.29 + * + * @param {Element} modal The upgrade modal element. + */ +function applyUpdateModalOverrides(modal) { + var titlePrefix = modal.querySelector('.frm-upgrade-modal-title-prefix'); + if (titlePrefix) { + titlePrefix.style.display = 'none'; + } + var notInstalled = modal.querySelector('.frm_are_not_installed'); + if (notInstalled) { + notInstalled.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('require an update', 'formidable'); + notInstalled.style.display = ''; // Clear inline style, span defaults to display:inline. + } + var oneclickMsg = modal.querySelector('.frm-oneclick'); + if (oneclickMsg) { + oneclickMsg.style.display = 'none'; + } + var button = modal.querySelector('.frm-oneclick-button'); + if (button) { + button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Update Now', 'formidable'); + } +} +function getRequiredLicenseFromTrigger(element) { + if (element.dataset.requires) { + return element.dataset.requires; + } + return 'Pro'; +} + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. +(() => { +/*!*******************************!*\ + !*** ./js/src/admin/admin.js ***! + \*******************************/ +function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } +function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } +function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/* exported frm_add_logic_row, frm_remove_tag, frm_show_div, frmCheckAll, frmCheckAllLevel */ + +window.FrmFormsConnect = window.FrmFormsConnect || function (document, window, $) { + var el = { + messageBox: null, + reset: null, + setElements: function setElements() { + el.messageBox = document.querySelector('.frm_pro_license_msg'); + el.reset = document.getElementById('frm_reconnect_link'); + } + }; + + /** + * Public functions and properties. + * + * @since 4.03 + * + * @type {Object} + */ + var app = { + /** + * Register connect button event. + * + * @since 4.03 + */ + init: function init() { + el.setElements(); + $(document.getElementById('frm_deauthorize_link')).on('click', app.deauthorize); + $('.frm_authorize_link').on('click', app.authorize); + // Handles FF dashboard Authorize & Reauthorize events. + // Attach click event to parent as #frm_deauthorize_link & #frm_reconnect_link dynamically recreated by bootstrap.setupBootstrapDropdowns in dom.js + $('.frm-dashboard-license-options').on('click', '#frm_deauthorize_link', app.deauthorize); + $('.frm-dashboard-license-options').on('click', '#frm_reconnect_link', app.reauthorize); + if (el.reset !== null) { + $(el.reset).on('click', app.reauthorize); + } + }, + /* Manual license authorization */authorize: function authorize() { + /*jshint validthis:true */ + var button = this; + var pluginSlug = this.getAttribute('data-plugin'); + var input = document.getElementById("edd_".concat(pluginSlug, "_license_key")); + var license = input.value; + var wpmu = document.getElementById('proplug-wpmu'); + this.classList.add('frm_loading_button'); + if (!wpmu) { + wpmu = 0; + } else if (wpmu.checked) { + wpmu = 1; + } else { + wpmu = 0; + } + $.ajax({ + type: 'POST', + url: ajaxurl, + dataType: 'json', + data: { + action: 'frm_addon_activate', + license: license, + plugin: pluginSlug, + wpmu: wpmu, + nonce: frmGlobal.nonce + }, + success: function success(msg) { + app.afterAuthorize(msg, input); + button.classList.remove('frm_loading_button'); + } + }); + }, + afterAuthorize: function afterAuthorize(msg, input) { + if (msg.success === true) { + input.value = '•••••••••••••••••••'; + } + wp.hooks.doAction('frm_after_authorize', msg); + app.showMessage(msg); + }, + showProgress: function showProgress(msg) { + if (el.messageBox === null) { + // In case the message box was added after page load. + el.setElements(); + } + var messageBox = el.messageBox; + if (messageBox === null) { + return; + } + if (msg.success === true) { + messageBox.classList.remove('frm_error_style'); + messageBox.classList.add('frm_message', 'frm_updated_message'); + } else { + messageBox.classList.add('frm_error_style'); + messageBox.classList.remove('frm_message', 'frm_updated_message'); + } + messageBox.classList.remove('frm_hidden'); + messageBox.innerHTML = msg.message; + }, + showMessage: function showMessage(msg) { + if (el.messageBox === null) { + // In case the message box was added after page load. + el.setElements(); + } + var messageBox = el.messageBox; + if (msg.success === true) { + app.showAuthorized(true); + app.showInlineSuccess(); + + /** + * Triggers the after license is authorized action for a confirmation/success modal. + * + * @param {Object} msg An object containing message data received from Authorize request. + */ + wp.hooks.doAction('frmAdmin.afterLicenseAuthorizeSuccess', { + msg: msg + }); + } + app.showProgress(msg); + if (msg.message !== '') { + setTimeout(function () { + messageBox.innerHTML = ''; + messageBox.classList.add('frm_hidden'); + messageBox.classList.remove('frm_error_style', 'frm_message', 'frm_updated_message'); + }, 10000); + var refreshPage = document.querySelector('.frm-admin-page-dashboard'); + if (refreshPage) { + setTimeout(function () { + window.location.reload(); + }, 1000); + } + } + }, + showAuthorized: function showAuthorized(show) { + var from = show ? 'unauthorized' : 'authorized'; + var to = show ? 'authorized' : 'unauthorized'; + var container = document.querySelectorAll(".frm_".concat(from, "_box")); + if (container.length) { + // Replace all authorized boxes with unauthorized boxes. + container.forEach(function (box) { + box.className = box.className.replace("frm_".concat(from, "_box"), "frm_".concat(to, "_box")); + }); + } + }, + /** + * Use the data-success element to replace the element content. + */ + showInlineSuccess: function showInlineSuccess() { + var successElement = document.querySelectorAll('.frm-confirm-msg [data-success]'); + if (successElement.length) { + successElement.forEach(function (element) { + element.innerHTML = frmAdminBuild.purifyHtml(element.getAttribute('data-success')); + }); + } + }, + /* Clear the site license cache */reauthorize: function reauthorize() { + /*jshint validthis:true */ + this.innerHTML = ''; + $.ajax({ + type: 'POST', + url: ajaxurl, + dataType: 'json', + data: { + action: 'frm_reset_cache', + plugin: 'formidable_pro', + nonce: frmGlobal.nonce + }, + success: function success(msg) { + el.reset.textContent = msg.message; + if (el.reset.getAttribute('data-refresh') === '1') { + window.location.reload(); + } + } + }); + return false; + }, + deauthorize: function deauthorize() { + /*jshint validthis:true */ + if (!confirm(frmGlobal.deauthorize)) { + return false; + } + var pluginSlug = this.getAttribute('data-plugin'); + var input = document.getElementById("edd_".concat(pluginSlug, "_license_key")); + var license = input.value; + var link = this; + this.innerHTML = ''; + $.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_addon_deactivate', + license: license, + plugin: pluginSlug, + nonce: frmGlobal.nonce + }, + success: function success() { + app.showAuthorized(false); + input.value = ''; + link.replaceWith('Disconnected'); + + /** + * Triggers the after license is deauthorized sruccess action. + */ + wp.hooks.doAction('frmAdmin.afterLicenseDeauthorizeSuccess', {}); + } + }); + return false; + } + }; + + // Provide access to public functions/properties. + return app; +}(document, window, jQuery); +window.frmAdminBuildJS = function () { + //'use strict'; + + var MAX_FIELD_GROUP_SIZE = 12; + var frmAdminJs = frm_admin_js; + var _frmDom = frmDom, + tag = _frmDom.tag, + div = _frmDom.div, + span = _frmDom.span, + a = _frmDom.a, + svg = _frmDom.svg, + img = _frmDom.img; + var onClickPreventDefault = frmDom.util.onClickPreventDefault; + var doJsonPost = frmDom.ajax.doJsonPost; + frmAdminJs.contextualShortcodes = getContextualShortcodes(); + var icons = { + save: svg({ + href: '#frm_save_icon' + }), + drag: svg({ + href: '#frm_drag_icon', + classList: ['frm_drag_icon', 'frm-drag'] + }) + }; + var $newFields = jQuery(document.getElementById('frm-show-fields')); + var builderForm = document.getElementById('new_fields'); + var thisForm = document.getElementById('form_id'); + var copyHelper = false; + var fieldsUpdated = 0; + var thisFormId = 0; + var autoId = 0; + var optionMap = {}; + var lastNewActionIdReturned = 0; + var _wp$i18n = wp.i18n, + __ = _wp$i18n.__, + sprintf = _wp$i18n.sprintf; + var debouncedSyncAfterDragAndDrop; + var postBodyContent; + var $postBodyContent; + var dragState = { + dragging: false + }; + if (thisForm) { + thisFormId = thisForm.value; + } + var currentURL = new URL(window.location.href); + var urlParams = currentURL.searchParams; + var builderPage = document.getElementById('frm_builder_page'); + + // Global settings + var s; + function showElement(element) { + if (!element[0]) { + return; + } + element[0].style.display = ''; + } + function empty($obj) { + if ($obj !== null) { + while ($obj.firstChild) { + $obj.firstChild.remove(); + } + } + } + function addClass($obj, className) { + if ($obj.classList) { + $obj.classList.add(className); + } else { + $obj.className += " ".concat(className); + } + } + function confirmClick(e) { + /*jshint validthis:true */ + e.stopPropagation(); + e.preventDefault(); + confirmLinkClick(this); + } + function confirmLinkClick(link) { + var message = link.getAttribute('data-frmverify'); + var loadedFrom = link.getAttribute('data-loaded-from'); + if (message === null || link.id === 'frm-confirmed-click') { + return true; + } + if ('entries-list' === loadedFrom) { + return wp.hooks.applyFilters('frm_on_multiple_entries_delete', { + link: link, + initModal: initModal + }); + } + return confirmModal(link); + } + function confirmModal(link) { + var $info = initModal('#frm_confirm_modal', '400px'); + var continueButton = document.getElementById('frm-confirmed-click'); + if ($info === false) { + return false; + } + + // The confirm button is hidden when showLimitModal is called, + // so make sure it is visible every time we open the modal. + if (continueButton) { + continueButton.style.display = 'block'; + } + var verify = link.getAttribute('data-frmverify'); + var btnClass = verify ? link.getAttribute('data-frmverify-btn') : ''; + var $confirmMessage = jQuery('.frm-confirm-msg'); + $confirmMessage.empty(); + if (verify) { + $confirmMessage.append(document.createTextNode(verify)); + if (btnClass) { + continueButton === null || continueButton === void 0 || continueButton.classList.add(btnClass); + } + } + var dataAtts = link.dataset; + if (continueButton) { + for (var i in continueButton.dataset) { + continueButton.removeAttribute("data-".concat(i)); + } + for (var _i in dataAtts) { + if (_i !== 'frmverify') { + continueButton.setAttribute("data-".concat(_i), dataAtts[_i]); + } + } + } + + /** + * Triggers the pre-open action for a confirmation modal. This action passes + * relevant modal information and associated link to any listening hooks. + * + * @param {Object} options An object containing modal elements and data. + * @param {HTMLElement} options.$info The HTML element containing modal information. + * @param {string} options.link The link associated with the modal action. + */ + wp.hooks.doAction('frmAdmin.beforeOpenConfirmModal', { + $info: $info, + link: link + }); + $info.dialog('open'); + continueButton === null || continueButton === void 0 || continueButton.setAttribute('href', link.getAttribute('href') || link.getAttribute('data-href')); + return false; + } + function infoModal(msg) { + var $info = initModal('#frm_info_modal', '400px'); + if ($info === false) { + return false; + } + jQuery('.frm-info-msg').html(msg); + $info.dialog('open'); + return false; + } + function toggleItem(e) { + /*jshint validthis:true */ + var toggle = this.getAttribute('data-frmtoggle'); + var text = this.getAttribute('data-toggletext'); + var $items = jQuery(toggle); + e.preventDefault(); + $items.toggle(); + if (text !== null && text !== '') { + this.setAttribute('data-toggletext', this.innerHTML); + this.textContent = text; + } + return false; + } + + /** + * Toggle a class on target elements when an anchor is clicked, or when a radio or checkbox has been selected. + * + * @param {Event} e Event with either the change or click type. + * @return {false} Always returns false to prevent default behavior. + */ + function hideShowItem(e) { + /*jshint validthis:true */ + var hide = this.getAttribute('data-frmhide'); + var show = this.getAttribute('data-frmshow'); + var uncheckList = this.getAttribute('data-frmuncheck'); + var uncheckListArray = uncheckList ? uncheckList.split(',') : []; + + // Flip unchecked checkboxes so an off value undoes the on value. + if (isUncheckedCheckbox(this)) { + if (hide !== null) { + show = hide; + hide = null; + } else if (show !== null) { + hide = show; + show = null; + } + } + e.preventDefault(); + var toggleClass = this.getAttribute('data-toggleclass') || 'frm_hidden'; + if (hide !== null) { + jQuery(hide).addClass(toggleClass); + } + if (show !== null) { + jQuery(show).removeClass(toggleClass); + } + var current = this.parentNode.querySelectorAll('a.current'); + if (current !== null) { + for (var i = 0; i < current.length; i++) { + current[i].classList.remove('current'); + } + this.classList.add('current'); + } + if (uncheckListArray.length) { + uncheckListArray.forEach(function (uncheckItem) { + var uncheckItemElement = document.querySelector(uncheckItem); + if (uncheckItemElement) { + uncheckItemElement.checked = false; + } + }); + } + return false; + } + function isUncheckedCheckbox(element) { + return 'INPUT' === element.nodeName && 'checkbox' === element.type && !element.checked; + } + + /** + * Load a tooltip for a single element. + * + * @since 6.26 + * + * @param {HTMLElement} element + * @param {boolean} show + */ + function loadTooltip(element) { + var show = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; + var tooltipTarget = element; + + // Bootstrap 5 does not allow tooltips on dropdown triggers, so move the tooltip to the parent element. + if (tooltipTarget.hasAttribute('data-toggle') || tooltipTarget.hasAttribute('data-bs-toggle')) { + tooltipTarget.parentElement.setAttribute('title', tooltipTarget.getAttribute('title')); + tooltipTarget.removeAttribute('title'); + tooltipTarget.classList.remove('frm_bstooltip'); + tooltipTarget.parentElement.classList.add('frm_bstooltip'); + tooltipTarget = tooltipTarget.parentElement; + } + jQuery(tooltipTarget).tooltip(); + if (show) { + deleteTooltips(); + jQuery(tooltipTarget).tooltip('show'); + } + } + function loadTooltips() { + var wrapClass = jQuery('.wrap, .frm_wrap'); + var confirmModal = document.getElementById('frm_confirm_modal'); + var doAction = false; + var confirmedBulkDelete = false; + jQuery(confirmModal).on('click', '[data-deletefield]', deleteFieldConfirmed); + jQuery(confirmModal).on('click', '[data-removeid]', removeThisTag); + jQuery(confirmModal).on('click', '[data-trashtemplate]', trashTemplate); + wrapClass.on('click', '.frm_remove_tag, .frm_remove_form_action', removeThisTag); + wrapClass.on('click', 'a[data-frmverify]', confirmClick); + wrapClass.on('click', 'a[data-frmtoggle]', toggleItem); + wrapClass.on('click', 'a[data-frmhide], a[data-frmshow]', hideShowItem); + wrapClass.on('change', 'input[data-frmhide], input[data-frmshow]', hideShowItem); + wrapClass.on('click', '.widget-top,a.widget-action', clickWidget); + wrapClass.on('mouseenter.frm', '.frm_bstooltip, .frm_help', function () { + jQuery(this).off('mouseenter.frm'); + loadTooltip(this, true); + }); + jQuery(document).on('click', '#doaction, #doaction2', function (event) { + var isTop = this.id === 'doaction'; + var suffix = isTop ? 'top' : 'bottom'; + var bulkActionSelector = document.getElementById("bulk-action-selector-".concat(suffix)); + var confirmBulkDelete = document.getElementById("confirm-bulk-delete-".concat(suffix)); + if (bulkActionSelector && confirmBulkDelete) { + doAction = this; + if (!confirmedBulkDelete && bulkActionSelector.value === 'bulk_delete') { + event.preventDefault(); + confirmLinkClick(confirmBulkDelete); + return false; + } + } else { + doAction = false; + } + }); + jQuery(document).on('click', '#frm-confirmed-click', function (event) { + if (doAction === false || event.target.classList.contains('frm-btn-inactive')) { + return; + } + if (this.getAttribute('href') === 'confirm-bulk-delete') { + event.preventDefault(); + confirmedBulkDelete = true; + doAction.click(); + return false; + } + }); + } + function deleteTooltips() { + document.querySelectorAll('.tooltip').forEach(function (tooltip) { + tooltip.remove(); + }); + } + function removeThisTag() { + /*jshint validthis:true */ + var show; + var hide; + var removeMore; + if (parseInt(this.getAttribute('data-skip-frm-js')) || confirmLinkClick(this) === false) { + return; + } + var deleteButton = jQuery(this); + var id = deleteButton.attr('data-removeid'); + show = deleteButton.attr('data-showlast'); + if (show === undefined) { + show = ''; + } + hide = deleteButton.attr('data-hidelast'); + if (hide === undefined) { + hide = ''; + } + removeMore = deleteButton.attr('data-removemore'); + if (show !== '') { + if (deleteButton.closest('.frm_add_remove').find('.frm_remove_tag:visible').length > 1) { + show = ''; + hide = ''; + } + } else if (id.indexOf('frm_postmeta_') === 0) { + if (jQuery('#frm_postmeta_rows .frm_postmeta_row').length < 2) { + show = '.frm_add_postmeta_row.button'; + } + if (jQuery('.frm_toggle_cf_opts').length && jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(id, ")")).last().length) { + if (show !== '') { + show += ','; + } + show += "#".concat(jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(id, ")")).last().attr('id'), " .frm_toggle_cf_opts"); + } + } + var fadeEle = document.getElementById(id); + var $fadeEle = jQuery(fadeEle); + $fadeEle.fadeOut(300, function () { + var _document$querySelect; + $fadeEle.remove(); + fieldUpdated(); + if (hide !== '') { + jQuery(hide).hide(); + } + if (show !== '') { + jQuery("".concat(show, " a,").concat(show)).removeClass('frm_hidden').fadeIn('slow'); + } + if (this.closest('.frm_form_action_settings')) { + var type = this.closest('.frm_form_action_settings').querySelector('.frm_action_name').value; + afterActionRemoved(type); + } + (_document$querySelect = document.querySelector('.tooltip')) === null || _document$querySelect === void 0 || _document$querySelect.remove(); + }); + if (removeMore !== undefined) { + removeMore = jQuery(removeMore); + removeMore.fadeOut(400, function () { + removeMore.remove(); + }); + } + if (show !== '') { + jQuery(this).closest('.frm_logic_rows').fadeOut('slow'); + } + + /** + * Fires after a tag element has been removed in the admin interface. + * + * @param {string} id The ID of the removed element + * @param {HTMLElement} fadeEle The removed element that was faded out + */ + wp.hooks.doAction('frm_admin_tag_removed', id, fadeEle); + return false; + } + function afterActionRemoved(type) { + checkActiveAction(type); + var hookName = 'frm_after_action_removed'; + var hookArgs = { + type: type + }; + wp.hooks.doAction(hookName, hookArgs); + } + function clickWidget(event, b) { + /*jshint validthis:true */ + if (b === undefined) { + b = this; + } + popCalcFields(b, false); + var cont = jQuery(b).closest('.frm_form_action_settings'); + var target = event.target; + if (cont.length && target !== undefined) { + var className = target.parentElement.className; + if ('string' === typeof className) { + if (className.includes('frm_email_icons') || className.includes('frm_toggle')) { + // clicking on delete icon shouldn't open it + event.stopPropagation(); + return; + } + } + } + var inside = cont.children('.widget-inside'); + if (cont.length && inside.find('p, div, table').length < 1) { + var actionId = cont.find('input[name$="[ID]"]').val(); + var actionType = cont.find('input[name$="[post_excerpt]"]').val(); + if (actionType) { + inside.html(''); + cont.find('.spinner').fadeIn('slow'); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_form_action_fill', + action_id: actionId, + action_type: actionType, + nonce: frmGlobal.nonce + }, + success: function success(html) { + inside.html(html); + initiateMultiselect(); + showInputIcon("#".concat(cont.attr('id'))); + initAutocomplete(inside); + jQuery(b).trigger('frm-action-loaded'); + + /** + * Fires after filling form action content when opening. + * + * @since 5.5.4 + * + * @param {Object} insideElement JQuery object of form action inside element. + */ + wp.hooks.doAction('frm_filled_form_action', inside); + } + }); + } + } + jQuery(b).closest('.frm_field_box').siblings().find('.widget-inside').slideUp('fast'); + if (b.className !== undefined && b.className.includes('widget-action') || jQuery(b).closest('.start_divider').length < 1) { + return; + } + inside = jQuery(b).closest('div.widget').children('.widget-inside'); + if (inside.is(':hidden')) { + inside.slideDown('fast'); + } else { + inside.slideUp('fast'); + } + } + function clickNewTab() { + /*jshint validthis:true */ + var t = this.getAttribute('href'); + if (t === undefined) { + return false; + } + var c = t.replace('#', '.'); + var $link = jQuery(this); + $link.closest('li').addClass('frm-tabs active').siblings('li').removeClass('frm-tabs active starttab'); + $link.closest('div').children('.tabs-panel').not(t).not(c).hide(); + var tabContent = document.getElementById(t.replace('#', '')); + if (tabContent) { + tabContent.style.display = 'block'; + } + + // clearSettingsBox would hide field settings when opening the fields modal and we want to skip it there. + if (this.id === 'frm_insert_fields_tab' && !this.closest('#frm_adv_info')) { + clearSettingsBox(); + } + return false; + } + function clickTab(link, auto) { + link = jQuery(link); + var t = link.attr('href'); + if (t === undefined) { + return; + } + var c = t.replace('#', '.'); + link.closest('li').addClass('frm-tabs active').siblings('li').removeClass('frm-tabs active starttab'); + if (link.closest('div').find('.tabs-panel').length) { + link.closest('div').children('.tabs-panel').not(t).not(c).hide(); + } else if (document.getElementById('form_global_settings') !== null) { + /* global settings */ + var ajax = link.data('frmajax'); + link.closest('.frm_wrap').find('.tabs-panel, .hide_with_tabs').hide(); + if (ajax !== undefined && ajax == '1') { + loadSettingsTab(t); + } + } else { + /* form settings page */ + jQuery('#frm-categorydiv .tabs-panel, .hide_with_tabs').hide(); + } + jQuery(t).show(); + jQuery(c).show(); + hideShortcodes(); + if (auto !== 'auto') { + // Hide success message on tab change. + jQuery('.frm_updated_message').hide(); + jQuery('.frm_warning_style').hide(); + } + if (jQuery(link).closest('#frm_adv_info').length) { + return; + } + if (jQuery('.frm_form_settings').length) { + jQuery('.frm_form_settings').attr('action', "?page=formidable&frm_action=settings&id=".concat(jQuery('.frm_form_settings input[name="id"]').val(), "&t=").concat(t.replace('#', ''))); + } else { + jQuery('.frm_settings_form').attr('action', "?page=formidable-settings&t=".concat(t.replace('#', ''))); + } + } + function setupSortable(sortableSelector) { + document.querySelectorAll(sortableSelector).forEach(function (list) { + makeDroppable(list); + Array.from(list.children).forEach(function (child) { + return makeDraggable(child, '.frm-move'); + }); + var $sectionTitle = jQuery(list).children('[data-type="divider"]').children('.divider_section_only'); + if ($sectionTitle.length) { + makeDroppable($sectionTitle); + } + }); + setupFieldOptionSorting(jQuery('#frm_builder_page')); + } + function makeDroppable(list) { + jQuery(list).droppable({ + accept: '.frmbutton, li.frm_field_box', + deactivate: handleFieldDrop, + over: onDragOverDroppable, + out: onDraggableLeavesDroppable, + tolerance: 'pointer' + }); + } + function onDragOverDroppable(event, ui) { + var droppable = getDroppableForOnDragOver(event.target); + var draggable = ui.draggable[0]; + if (!allowDrop(draggable, droppable, event)) { + droppable.classList.remove('frm-over-droppable'); + jQuery(droppable).parents('ul.frm_sorting').addClass('frm-over-droppable'); + return; + } + document.querySelectorAll('.frm-over-droppable').forEach(function (droppable) { + return droppable.classList.remove('frm-over-droppable'); + }); + droppable.classList.add('frm-over-droppable'); + jQuery(droppable).parents('ul.frm_sorting').addClass('frm-over-droppable'); + } + + /** + * Maybe change the droppable. + * Section titles are made droppable, but are not a list, so we need to change the droppable to the section's list instead. + * + * @param {Element} droppable The droppable element. + * @return {Element} The adjusted droppable element. + */ + function getDroppableForOnDragOver(droppable) { + if (droppable.classList.contains('divider_section_only')) { + droppable = jQuery(droppable).nextAll('.start_divider.frm_sorting').get(0); + } + return droppable; + } + function onDraggableLeavesDroppable(event) { + var droppable = event.target; + droppable.classList.remove('frm-over-droppable'); + } + function makeDraggable(draggable, handle) { + var settings = { + helper: getDraggableHelper, + revert: 'invalid', + delay: 10, + start: handleDragStart, + stop: handleDragStop, + drag: handleDrag, + cursor: 'grabbing', + refreshPositions: true, + cursorAt: { + top: 0, + left: 90 // The width of draggable button is 180. 90 should center the draggable on the cursor. + } + }; + if ('string' === typeof handle) { + settings.handle = handle; + } + jQuery(draggable).draggable(settings); + } + function getDraggableHelper(event) { + var draggable = event.delegateTarget; + if (isFieldGroup(draggable)) { + var newTextFieldClone = document.getElementById('frm-insert-fields').querySelector('.frm_ttext').cloneNode(true); + newTextFieldClone.querySelector('use').setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_field_group_layout_icon'); + newTextFieldClone.querySelector('span').textContent = __('Field Group', 'formidable'); + newTextFieldClone.classList.add('frm_field_box'); + newTextFieldClone.classList.add('ui-sortable-helper'); + return newTextFieldClone; + } + var copyTarget; + var isNewField = draggable.classList.contains('frmbutton'); + if (isNewField) { + copyTarget = draggable.cloneNode(true); + copyTarget.classList.add('ui-sortable-helper'); + draggable.classList.add('frm-new-field'); + return copyTarget; + } + if (draggable.hasAttribute('data-ftype')) { + var fieldType = draggable.getAttribute('data-ftype'); + copyTarget = document.getElementById('frm-insert-fields').querySelector(".frm_t".concat(fieldType)); + if (copyTarget) { + copyTarget = copyTarget.cloneNode(true); + copyTarget.classList.add('form-field'); + copyTarget.classList.add('ui-sortable-helper'); + return copyTarget.cloneNode(true); + } + } + return div({ + className: 'frmbutton' + }); + } + function handleDragStart(event, ui) { + if (event.target.classList.contains('frm_at_limit')) { + showLimitModal(); + return false; + } + dragState.dragging = true; + var container = postBodyContent; + container.classList.add('frm-dragging-field'); + document.body.classList.add('frm-dragging'); + ui.helper.addClass('frm-sortable-helper'); + ui.helper.initialOffset = container.scrollTop; + event.target.classList.add('frm-drag-fade'); + unselectFieldGroups(); + deleteEmptyDividerWrappers(); + maybeRemoveGroupHoverTarget(); + closeOpenFieldDropdowns(); + deleteTooltips(); + } + function handleDragStop() { + var container = postBodyContent; + container.classList.remove('frm-dragging-field'); + document.body.classList.remove('frm-dragging'); + var fade = document.querySelector('.frm-drag-fade'); + if (fade) { + fade.classList.remove('frm-drag-fade'); + } + } + function handleDrag(event, ui) { + maybeScrollBuilder(event); + var draggable = event.target; + var droppable = getDroppableTarget(); + var placeholder = document.getElementById('frm_drag_placeholder'); + if (!allowDrop(draggable, droppable, event)) { + if (placeholder) { + placeholder.remove(); + } + return; + } + if (!placeholder) { + placeholder = tag('li', { + id: 'frm_drag_placeholder', + className: 'sortable-placeholder' + }); + } + var frmSortableHelper = ui.helper.get(0); + if (frmSortableHelper.classList.contains('form-field') || frmSortableHelper.classList.contains('frm_field_box')) { + // Sync the y position of the draggable so it still follows the cursor after scrolling up and down the field list. + frmSortableHelper.style.transform = "translateY(".concat(getDragOffset(ui.helper), "px)"); + } + if ('frm-show-fields' === droppable.id || droppable.classList.contains('start_divider')) { + placeholder.style.left = 0; + handleDragOverYAxis({ + droppable: droppable, + y: event.clientY, + placeholder: placeholder + }); + return; + } + placeholder.style.top = ''; + handleDragOverFieldGroup({ + droppable: droppable, + x: event.clientX, + placeholder: placeholder + }); + } + function maybeScrollBuilder(event) { + $postBodyContent.scrollTop(function (_, v) { + var moved = event.clientY; + var h = postBodyContent.offsetHeight; + var relativePos = event.clientY - postBodyContent.offsetTop; + var y = relativePos - h / 2; + if (relativePos > h - 50 && moved > 5) { + // Scrolling down. + return v + y * 0.1; + } + if (relativePos < 70 && moved < 130) { + // Scrolling up. + return v - Math.abs(y * 0.1); + } + return v; + }); + } + function getDragOffset($helper) { + return postBodyContent.scrollTop - $helper.initialOffset; + } + function getDroppableTarget() { + var droppable = document.getElementById('frm-show-fields'); + while (droppable.querySelector('.frm-over-droppable')) { + droppable = droppable.querySelector('.frm-over-droppable'); + } + if ('frm-show-fields' === droppable.id && !droppable.classList.contains('frm-over-droppable')) { + droppable = false; + } + return droppable; + } + function handleFieldDrop(_, ui) { + if (!dragState.dragging) { + // dragState.dragging is set to true on drag start. + // The deactivate event gets called for every droppable. This check to make sure it happens once. + return; + } + dragState.dragging = false; + var draggable = ui.draggable[0]; + var placeholder = document.getElementById('frm_drag_placeholder'); + if (!placeholder) { + ui.helper.remove(); + debouncedSyncAfterDragAndDrop(); + return; + } + maybeOpenCollapsedPage(placeholder); + var $previousFieldContainer = ui.helper.parent(); + var previousSection = ui.helper.get(0).closest('ul.start_divider'); + var newSection = placeholder.closest('ul.start_divider'); + if (draggable.classList.contains('frm-new-field')) { + insertNewFieldByDragging(draggable.id); + } else { + moveFieldThatAlreadyExists(draggable, placeholder); + maybeMakeFieldGroupDraggableAfterDragging(placeholder.parentElement); + } + var previousSectionId = previousSection ? parseInt(previousSection.closest('.edit_field_type_divider').getAttribute('data-fid')) : 0; + var newSectionId = newSection ? parseInt(newSection.closest('.edit_field_type_divider').getAttribute('data-fid')) : 0; + placeholder.remove(); + ui.helper.remove(); + var $previousContainerFields = $previousFieldContainer.length ? getFieldsInRow($previousFieldContainer) : []; + maybeUpdatePreviousFieldContainerAfterDrop($previousFieldContainer, $previousContainerFields); + maybeUpdateDraggableClassAfterDrop(draggable, $previousContainerFields); + if (previousSectionId !== newSectionId) { + updateFieldAfterMovingBetweenSections(jQuery(draggable), previousSection); + } + debouncedSyncAfterDragAndDrop(); + } + + /** + * When a field is moved into a field group, make sure the field group is draggable. + * + * @since 6.24 + * + * @param {HTMLElement} placeholderParent + * @return {void} + */ + function maybeMakeFieldGroupDraggableAfterDragging(placeholderParent) { + var isDroppingIntoFieldGroup = placeholderParent.nodeName === 'UL' && !placeholderParent.classList.contains('start_divider') && 'frm-show-fields' !== placeholderParent.id; + if (!isDroppingIntoFieldGroup) { + return; + } + var fieldGroupLi = placeholderParent.closest('li'); + if (fieldGroupLi && !fieldGroupLi.classList.contains('ui-draggable')) { + makeDraggable(fieldGroupLi, '.frm-move'); + } + } + + /** + * If a page if collapsed, expand it before dragging since only the page break will move. + * + * @param {Element} placeholder + * @return {void} + */ + function maybeOpenCollapsedPage(placeholder) { + if (!placeholder.previousElementSibling || !placeholder.previousElementSibling.classList.contains('frm-is-collapsed')) { + return; + } + var $pageBreakField = jQuery(placeholder).prevUntil('[data-type="break"]'); + if (!$pageBreakField.length) { + return; + } + var collapseButton = $pageBreakField.find('.frm-collapse-page').get(0); + if (collapseButton) { + collapseButton.click(); + } + } + function maybeUpdatePreviousFieldContainerAfterDrop($previousFieldContainer, $previousContainerFields) { + if (!$previousFieldContainer.length) { + return; + } + if ($previousContainerFields.length) { + syncLayoutClasses($previousContainerFields.first()); + } else { + maybeDeleteAnEmptyFieldGroup($previousFieldContainer.get(0)); + } + } + function maybeUpdateDraggableClassAfterDrop(draggable, $previousContainerFields) { + if (0 !== $previousContainerFields.length || 1 !== getFieldsInRow(jQuery(draggable.parentNode)).length) { + syncLayoutClasses(jQuery(draggable)); + } + } + + /** + * Remove an empty field group, but don't remove an empty section. + * + * @param {Element} previousFieldContainer + * @return {void} + */ + function maybeDeleteAnEmptyFieldGroup(previousFieldContainer) { + var closestFieldBox = previousFieldContainer.closest('li.frm_field_box'); + if (closestFieldBox && !closestFieldBox.classList.contains('edit_field_type_divider')) { + closestFieldBox.remove(); + } + } + function handleDragOverYAxis(_ref) { + var droppable = _ref.droppable, + y = _ref.y, + placeholder = _ref.placeholder; + var $list = jQuery(droppable); + var top; + var $children = $list.children().not('.edit_field_type_end_divider'); + if (0 === $children.length) { + $list.prepend(placeholder); + top = 0; + } else { + var insertAtIndex = determineIndexBasedOffOfMousePositionInList($list, y); + if (insertAtIndex === $children.length) { + var $lastChild = jQuery($children.get(insertAtIndex - 1)); + top = $lastChild.offset().top + $lastChild.outerHeight(); + $list.append(placeholder); + + // Make sure nothing gets inserted after the end divider. + var $endDivider = $list.children('.edit_field_type_end_divider'); + if ($endDivider.length) { + $list.append($endDivider); + } + } else { + top = jQuery($children.get(insertAtIndex)).offset().top; + jQuery($children.get(insertAtIndex)).before(placeholder); + } + } + top -= $list.offset().top; + placeholder.style.top = "".concat(top, "px"); + } + function determineIndexBasedOffOfMousePositionInList($list, y) { + var $items = $list.children().not('.edit_field_type_end_divider'); + var length = $items.length; + var index; + var item; + var itemTop; + var returnIndex; + if (!document.querySelector('.frm-has-fields .frm_no_fields')) { + // Always return 0 when there are no fields. + return 0; + } + returnIndex = 0; + for (index = length - 1; index >= 0; --index) { + item = $items.get(index); + itemTop = jQuery(item).offset().top; + if (y > itemTop) { + returnIndex = index; + if (y > itemTop + jQuery(item).outerHeight() / 2) { + returnIndex = index + 1; + } + break; + } + } + return returnIndex; + } + function handleDragOverFieldGroup(_ref2) { + var droppable = _ref2.droppable, + x = _ref2.x, + placeholder = _ref2.placeholder; + var $row = jQuery(droppable); + var $children = getFieldsInRow($row); + if (!$children.length) { + return; + } + var left; + var insertAtIndex = determineIndexBasedOffOfMousePositionInRow($row, x); + if (insertAtIndex === $children.length) { + var $lastChild = jQuery($children.get(insertAtIndex - 1)); + left = $lastChild.offset().left + $lastChild.outerWidth(); + $row.append(placeholder); + } else { + left = jQuery($children.get(insertAtIndex)).offset().left; + jQuery($children.get(insertAtIndex)).before(placeholder); + var amountToOffsetLeftBy = 0 === insertAtIndex ? 4 : 8; // Offset by 8 in between rows, but only 4 for the first item in a group. + left -= amountToOffsetLeftBy; // Offset the placeholder slightly so it appears between two fields. + } + left -= $row.offset().left; + placeholder.style.left = "".concat(left, "px"); + } + function syncAfterDragAndDrop() { + fixUnwrappedListItems(); + toggleSectionHolder(); + maybeFixEndDividers(); + maybeDeleteEmptyFieldGroups(); + updateFieldOrder(); + var event = new Event('frm_sync_after_drag_and_drop', { + bubbles: false + }); + document.dispatchEvent(event); + } + function maybeFixEndDividers() { + document.querySelectorAll('.edit_field_type_end_divider').forEach(function (endDivider) { + return endDivider.parentNode.append(endDivider); + }); + } + function maybeDeleteEmptyFieldGroups() { + document.querySelectorAll('li.form_field_box:not(.form-field)').forEach(function (fieldGroup) { + return !fieldGroup.children.length && fieldGroup.remove(); + }); + } + function fixUnwrappedListItems() { + var lists = document.querySelectorAll('ul#frm-show-fields, ul.start_divider'); + lists.forEach(function (list) { + list.childNodes.forEach(function (child) { + if (child.classList === undefined) { + return; + } + if (child.classList.contains('edit_field_type_end_divider')) { + // Never wrap end divider in place. + return; + } + if (child.classList !== undefined && child.classList.contains('form-field')) { + wrapFieldLiInPlace(child); + } + }); + }); + } + function deleteEmptyDividerWrappers() { + var dividers = document.querySelectorAll('ul.start_divider'); + if (!dividers.length) { + return; + } + dividers.forEach(function (divider) { + var children = [].slice.call(divider.children); + children.forEach(function (child) { + if (0 === child.children.length) { + child.remove(); + } else if (1 === child.children.length && 'ul' === child.firstElementChild.nodeName.toLowerCase() && 0 === child.firstElementChild.children.length) { + child.remove(); + } + }); + }); + } + function getFieldsInRow($row) { + var $fields = jQuery(); + var row = $row.get(0); + if (!row.children) { + return $fields; + } + Array.from(row.children).forEach(function (child) { + if ('none' === child.style.display) { + return; + } + var classes = child.classList; + if (!classes.contains('form-field') || classes.contains('edit_field_type_end_divider') || classes.contains('frm-sortable-helper')) { + return; + } + $fields = $fields.add(child); + }); + return $fields; + } + function determineIndexBasedOffOfMousePositionInRow($row, x) { + var $inputs = getFieldsInRow($row); + var length = $inputs.length; + var index; + var input; + var inputLeft; + var returnIndex; + returnIndex = 0; + for (index = length - 1; index >= 0; --index) { + input = $inputs.get(index); + inputLeft = jQuery(input).offset().left; + if (x > inputLeft) { + returnIndex = index; + if (x > inputLeft + jQuery(input).outerWidth() / 2) { + returnIndex = index + 1; + } + break; + } + } + return returnIndex; + } + function syncLayoutClasses($item, type) { + var classToAddFunction; + if (type === undefined) { + type = 'even'; + } + var $fields = $item.parent().children('li.form-field, li.frmbutton_loadingnow').not('.edit_field_type_end_divider'); + var size = $fields.length; + var layoutClasses = getLayoutClasses(); + if ('even' === type && 5 !== size) { + $fields.each(getSyncLayoutClass(layoutClasses, getEvenClassForSize(size))); + } else if ('clear' === type) { + $fields.each(getSyncLayoutClass(layoutClasses, '')); + } else { + if (['left', 'right', 'middle', 'even'].includes(type)) { + classToAddFunction = function classToAddFunction(index) { + return getClassForBlock(size, type, index); + }; + } else { + classToAddFunction = function classToAddFunction(index) { + var size = type[index]; + return getLayoutClassForSize(size); + }; + } + $fields.each(getSyncLayoutClass(layoutClasses, classToAddFunction)); + } + updateFieldGroupControls($item.parent(), $fields.length); + } + function updateFieldGroupControls($row, count) { + var rowOffset = $row.offset(); + if (rowOffset === undefined) { + return; + } + var shouldShowControls = count >= 2; + var controls = document.getElementById('frm_field_group_controls'); + if (!controls) { + if (!shouldShowControls) { + // exit early. if we do not need controls and they do not exist, do nothing. + return; + } + controls = div(); + controls.id = 'frm_field_group_controls'; + controls.setAttribute('role', 'group'); + controls.setAttribute('tabindex', 0); + setFieldControlsHtml(controls); + builderPage.append(controls); + } + $row.append(controls); + controls.style.display = shouldShowControls ? 'block' : 'none'; + } + function setFieldControlsHtml(controls) { + var layoutOption = document.createElement('span'); + layoutOption.innerHTML = ''; + var layoutOptionLabel = __('Set Row Layout', 'formidable'); + addTooltip(layoutOption, layoutOptionLabel); + makeTabbable(layoutOption, layoutOptionLabel); + var moveOption = document.createElement('span'); + moveOption.innerHTML = ''; + moveOption.classList.add('frm-move'); + var moveOptionLabel = __('Move Field Group', 'formidable'); + addTooltip(moveOption, moveOptionLabel); + makeTabbable(moveOption, moveOptionLabel); + controls.innerHTML = ''; + controls.append(layoutOption); + controls.append(moveOption); + controls.append(getFieldControlsDropdown()); + } + function addTooltip(element, title) { + element.setAttribute('data-bs-toggle', 'tooltip'); + element.setAttribute('data-bs-container', 'body'); + element.setAttribute('title', title); + element.addEventListener('mouseover', function () { + if (null === element.getAttribute('data-original-title')) { + jQuery(element).tooltip(); + } + }); + } + function getFieldControlsDropdown() { + var dropdown = span({ + className: 'dropdown' + }); + var trigger = a({ + className: 'frm_bstooltip frm-hover-icon frm-dropdown-toggle dropdown-toggle', + children: [span({ + child: svg({ + href: '#frm_thick_more_vert_icon' + }) + }), span({ + className: 'screen-reader-text', + text: __('Toggle More Options Dropdown', 'formidable') + })] + }); + frmDom.setAttributes(trigger, { + title: __('More Options', 'formidable'), + 'data-bs-toggle': 'dropdown', + 'data-bs-container': 'body', + 'data-bs-display': 'static' + }); + makeTabbable(trigger, __('More Options', 'formidable')); + dropdown.append(trigger); + var ul = div({ + className: 'frm-dropdown-menu dropdown-menu dropdown-menu-right' + }); + ul.setAttribute('role', 'menu'); + dropdown.append(ul); + return dropdown; + } + function getSyncLayoutClass(layoutClasses, classToAdd) { + return function (itemIndex) { + var currentClassToAdd = 'function' === typeof classToAdd ? classToAdd(itemIndex) : classToAdd; + var length = layoutClasses.length; + var activeLayoutClass = false; + for (var layoutClassIndex = 0; layoutClassIndex < length; ++layoutClassIndex) { + var currentClass = layoutClasses[layoutClassIndex]; + if (this.classList.contains(currentClass)) { + activeLayoutClass = currentClass; + break; + } + } + var fieldId = this.dataset.fid; + if (fieldId === undefined) { + // we are syncing the drag/drop placeholder before the actual field has loaded. + // this will get called again afterward and the input will exist then. + this.classList.add(currentClassToAdd); + return; + } + moveFieldSettings(document.getElementById("frm-single-settings-".concat(fieldId))); + var layoutClassesInput = document.getElementById("frm_classes_".concat(fieldId)); + if (!layoutClassesInput) { + // not every field type has a layout class input. + return; + } + if (false === activeLayoutClass) { + if ('' !== currentClassToAdd) { + layoutClassesInput.value = layoutClassesInput.value.concat(" ".concat(currentClassToAdd)); + } + } else { + this.classList.remove(activeLayoutClass); + layoutClassesInput.value = layoutClassesInput.value.replace(activeLayoutClass, currentClassToAdd); + } + if (this.classList.contains('frm_first')) { + this.classList.remove('frm_first'); + layoutClassesInput.value = layoutClassesInput.value.replace('frm_first', '').trim(); + } + if (0 === itemIndex) { + this.classList.add('frm_first'); + layoutClassesInput.value = layoutClassesInput.value.concat(' frm_first'); + } + jQuery(layoutClassesInput).trigger('change'); + }; + } + function getLayoutClasses() { + return ['frm_full', 'frm_half', 'frm_third', 'frm_fourth', 'frm_sixth', 'frm_two_thirds', 'frm_three_fourths', 'frm1', 'frm2', 'frm3', 'frm4', 'frm5', 'frm6', 'frm7', 'frm8', 'frm9', 'frm10', 'frm11', 'frm12']; + } + function setupFieldOptionSorting(sort) { + var opts = { + items: '.frm_sortable_field_opts li', + axis: 'y', + opacity: 0.65, + forcePlaceholderSize: false, + handle: '.frm-drag', + helper: function helper(e, li) { + copyHelper = li.clone().insertAfter(li); + return li.clone(); + }, + stop: function stop(e, ui) { + if (copyHelper) { + copyHelper.remove(); + } + var fieldId = ui.item.attr('id').replace('frm_delete_field_', '').replace("-".concat(ui.item.data('optkey'), "_container"), ''); + resetDisplayedOpts(fieldId); + fieldUpdated(); + } + }; + jQuery(sort).sortable(opts); + } + + // Get the section where a field is dropped + function getSectionForFieldPlacement(currentItem) { + var section = ''; + if (currentItem !== undefined && !currentItem.hasClass('edit_field_type_divider')) { + section = currentItem.closest('.edit_field_type_divider'); + } + return section; + } + + // Get the form ID where a field is dropped + function getFormIdForFieldPlacement(section) { + var formId = ''; + if (section[0] !== undefined) { + var sDivide = section.children('.start_divider'); + sDivide.children('.edit_field_type_end_divider').appendTo(sDivide); + if (section.attr('data-formid') !== undefined) { + var fieldId = section.attr('data-fid'); + formId = jQuery("input[name=\"field_options[form_select_".concat(fieldId, "]\"]")).val(); + } + } + if (formId === undefined || formId === '') { + formId = thisFormId; + } + return formId; + } + + // Get the section ID where a field is dropped + function getSectionIdForFieldPlacement(section) { + var sectionId = 0; + if (section[0] !== undefined) { + sectionId = section.attr('id').replace('frm_field_id_', ''); + } + return sectionId; + } + + /** + * Update a field after it is dragged and dropped into, out of, or between sections + * + * @param {Object} currentItem + * @param {Object} previousSection + * @return {void} + */ + function updateFieldAfterMovingBetweenSections(currentItem, previousSection) { + if (!currentItem.hasClass('form-field')) { + // currentItem is a field group. Call for children recursively. + getFieldsInRow(jQuery(currentItem.get(0).firstChild)).each(function () { + updateFieldAfterMovingBetweenSections(jQuery(this), previousSection); + }); + return; + } + var fieldId = currentItem.attr('id').replace('frm_field_id_', ''); + var section = getSectionForFieldPlacement(currentItem); + var formId = getFormIdForFieldPlacement(section); + var sectionId = getSectionIdForFieldPlacement(section); + var previousFormId = previousSection ? getFormIdForFieldPlacement(jQuery(previousSection.parentNode)) : 0; + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_update_field_after_move', + form_id: formId, + field: fieldId, + section_id: sectionId, + previous_form_id: previousFormId, + nonce: frmGlobal.nonce + }, + success: function success() { + toggleSectionHolder(); + updateInSectionValue(fieldId, sectionId); + } + }); + } + + // Update the in_section field value + function updateInSectionValue(fieldId, sectionId) { + document.getElementById("frm_in_section_".concat(fieldId)).value = sectionId; + } + + /** + * Get the arguments for inserting a new field. + * + * @since 6.23 + * + * @param {string} fieldType The type of field to insert. + * @param {string} sectionId The section ID to insert into. + * @param {string} formId The form ID. + * @param {number} hasBreak Whether the field has a page break. + * + * @return {Object} Data object for the new field AJAX request. + */ + function getInsertNewFieldArgs(fieldType, sectionId, formId, hasBreak) { + var fieldArgs = { + action: 'frm_insert_field', + form_id: formId, + field_type: fieldType, + section_id: sectionId, + nonce: frmGlobal.nonce, + has_break: hasBreak + }; + + // Only send last row field IDs to update their order if this field isn't added to a repeater. + var isInRepeater = sectionId > 0 && document.getElementById('form_id').value !== formId; + if (!isInRepeater) { + fieldArgs.last_row_field_ids = getFieldIdsInSubmitRow(); + } + return fieldArgs; + } + + /** + * Returns true if it's a range field type and slider type is not selected. + * + * @since 6.23 + * + * @param {string} fieldType The field type to check. + * @return {boolean} True if range field without slider type selected. + */ + function shouldStopInsertingField(fieldType) { + return wp.hooks.applyFilters('frm_should_stop_inserting_field', false, fieldType); + } + + /** + * Add a new field by dragging and dropping it from the Fields sidebar + * + * @param {string} fieldType + */ + function insertNewFieldByDragging(fieldType) { + if (shouldStopInsertingField(fieldType)) { + wp.hooks.doAction('frm_stopped_inserting_by_dragging', fieldType); + return; + } + var placeholder = document.getElementById('frm_drag_placeholder'); + var loadingID = "".concat(fieldType.replace('|', '-'), "_").concat(getAutoId()); + var loading = tag('li', { + id: loadingID, + className: 'frm-wait frmbutton_loadingnow' + }); + var $placeholder = jQuery(loading); + var currentItem = jQuery(placeholder); + var section = getSectionForFieldPlacement(currentItem); + var formId = getFormIdForFieldPlacement(section); + var sectionId = getSectionIdForFieldPlacement(section); + placeholder.parentNode.insertBefore(loading, placeholder); + placeholder.remove(); + syncLayoutClasses($placeholder); + var hasBreak = 0; + if ('summary' === fieldType) { + // see if we need to insert a page break before this newly-added summary field. Check for at least 1 page break + hasBreak = jQuery(".frmbutton_loadingnow#".concat(loadingID)).prevAll('li[data-type="break"]').length ? 1 : 0; + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: getInsertNewFieldArgs(fieldType, sectionId, formId, hasBreak), + success: function success(msg) { + handleInsertFieldByDraggingResponse(msg, $placeholder); + var fieldId = checkMsgForFieldId(msg); + if (fieldId) { + /** + * Fires after a field is added. + * + * @since 6.23 + * + * @param {Object} fieldData The field data. + * @param {string} fieldData.field The field HTML. + * @param {string} fieldData.field_type The field type. + * @param {string} fieldData.form_id The form ID. + */ + wp.hooks.doAction('frm_after_field_added_in_form_builder', { + field: msg, + fieldId: fieldId, + fieldType: fieldType, + form_id: formId + }); + } + }, + error: handleInsertFieldError + }); + } + + /** + * @param {string} msg + * @param {Object} $placeholder jQuery object. + */ + function handleInsertFieldByDraggingResponse(msg, $placeholder) { + var replaceWith; + document.getElementById('frm_form_editor_container').classList.add('frm-has-fields'); + var $siblings = $placeholder.siblings('li.form-field').not('.edit_field_type_end_divider'); + if (!$siblings.length) { + // if dragging into a new row, we need to wrap the li first. + replaceWith = wrapFieldLi(msg); + } else { + replaceWith = msgAsjQueryObject(msg); + if (!$placeholder.get(0).parentNode.parentNode.classList.contains('ui-draggable')) { + // If a field group wasn't draggable because it only had a single field, make it draggable. + makeDraggable($placeholder.get(0).parentNode.parentNode, '.frm-move'); + } + } + $placeholder.replaceWith(replaceWith); + updateFieldOrder(); + afterAddField(msg, false); + if ($siblings.length) { + syncLayoutClasses($siblings.first()); + } + toggleSectionHolder(); + if (!$siblings.length) { + makeDroppable(replaceWith.get(0).querySelector('ul.frm_sorting')); + makeDraggable(replaceWith.get(0).querySelector('li.form-field'), '.frm-move'); + } else { + makeDraggable(replaceWith.get(0), '.frm-move'); + } + } + + /** + * Get the field ID from the response message. + * + * @since 6.23 + * + * @param {string} msg The response message containing the field ID. + * @return {number} The extracted field ID. + */ + function checkMsgForFieldId(msg) { + var result = msg.match(/data-fid="(\d+)"/); + return result ? parseInt(result[1]) : 0; + } + function getFieldIdsInSubmitRow() { + var submitField = document.querySelector('.edit_field_type_submit'); + if (!submitField) { + return []; + } + var lastRowFields = submitField.parentNode.children; + var ids = []; + for (var i = 0; i < lastRowFields.length; i++) { + ids.push(lastRowFields[i].dataset.fid); + } + return ids; + } + function moveFieldThatAlreadyExists(draggable, placeholder) { + placeholder.parentNode.insertBefore(draggable, placeholder); + } + function msgAsjQueryObject(msg) { + var element = div(); + element.innerHTML = msg; + return jQuery(element.firstChild); + } + function handleInsertFieldError(jqXHR, _, errorThrown) { + maybeShowInsertFieldError(errorThrown, jqXHR); + } + function maybeShowInsertFieldError(errorThrown, jqXHR) { + if (!jqXHRAborted(jqXHR)) { + infoModal("".concat(errorThrown, ". Please try again.")); + } + } + function jqXHRAborted(jqXHR) { + return jqXHR.status === 0 || jqXHR.readyState === 0; + } + + /** + * Get a unique id that automatically increments with every function call. + * Can be used for any UI that requires a unique id. + * Not to be used in data. + * + * @return {number} A unique auto-incremented ID. + */ + function getAutoId() { + return ++autoId; + } + + /** + * Determine if a draggable element can be droppable into a droppable element. + * + * Don't allow page break, embed form, or section inside section field + * Don't allow page breaks inside of field groups. + * Don't allow field groups with sections inside of sections. + * Don't allow field groups in field groups. + * Don't allow hidden fields inside of field groups but allow them in sections. + * Don't allow any fields below the submit button field. + * Don't allow submit button field above any fields. + * Don't allow GDPR fields in repeaters. + * + * @param {HTMLElement} draggable + * @param {HTMLElement} droppable + * @param {Event} event + * @return {boolean} Whether the drag operation is allowed. + */ + function allowDrop(draggable, droppable, event) { + if (false === droppable) { + // Don't show drop placeholder if dragging somewhere off of the droppable area. + return false; + } + if (droppable.closest('.frm-sortable-helper')) { + // Do not allow drop into draggable. + return false; + } + var isSubmitBtn = draggable.classList.contains('edit_field_type_submit'); + var containSubmitBtn = !draggable.classList.contains('form_field') && !!draggable.querySelector('.edit_field_type_submit'); + if ('frm-show-fields' === droppable.id) { + var draggableIndex = determineIndexBasedOffOfMousePositionInList(jQuery(droppable), event.clientY); + if (isSubmitBtn || containSubmitBtn) { + // Do not allow dropping submit button to above position. + var lastRowIndex = droppable.childElementCount - 1; + return draggableIndex > lastRowIndex; + } + + // Do not allow dropping other fields to below submit button. + var submitButtonIndex = jQuery(droppable.querySelector('.edit_field_type_submit').closest('#frm-show-fields > li')).index(); + return draggableIndex <= submitButtonIndex; + } + if (isSubmitBtn) { + if (droppable.classList.contains('start_divider')) { + // Don't allow dropping submit button into a repeater. + return false; + } + if (isLastRow(droppable.parentElement)) { + // Allow dropping submit button into the last row. + return true; + } + if (!isLastRow(droppable.parentElement.nextElementSibling)) { + // Don't a dropping submit button into the row that isn't the second one from bottom. + return false; + } + + // Allow dropping submit button into the second row from bottom if there is only submit button in the last row. + return !draggable.parentElement.querySelector('li.frm_field_box:not(.edit_field_type_submit)'); + } + var droppableIsARepeater = droppable.classList.contains('start_divider') && null !== droppable.closest('.repeat_section'); + var droppableIsInsideOfARepeater = null !== droppable.closest('.repeat_section'); + if (droppableIsARepeater || droppableIsInsideOfARepeater) { + var isGdpr = draggable.classList.contains('edit_field_type_gdpr') || draggable.id === 'gdpr'; + if (isGdpr) { + return false; + } + + /** + * @since 6.27 + * + * @param {boolean} denyDropInRepeater + * @param {HTMLElement} draggable + */ + var shouldDenyDropInRepeater = wp.hooks.applyFilters('frm_deny_drop_in_repeater', false, draggable); + if (shouldDenyDropInRepeater) { + return false; + } + } + if (!droppableIsARepeater) { + var $fieldsInRow = getFieldsInRow(jQuery(droppable)); + if (!groupCanFitAnotherField($fieldsInRow, jQuery(draggable))) { + // Field group is full and cannot accept another field. + return false; + } + if (draggable.id === 'divider' && droppable.closest('.start_divider')) { + return false; + } + } + var isNewField = draggable.classList.contains('frm-new-field'); + if (isNewField) { + return allowNewFieldDrop(draggable, droppable); + } + return allowMoveField(draggable, droppable); + } + + /** + * Checks if given element is the last row in form builder. + * + * @param {HTMLElement} element Element. + * @return {boolean} True if the element is the last row. + */ + function isLastRow(element) { + return element && element.matches('#frm-show-fields > li:last-child'); + } + + // Don't allow a new page break or hidden field in a field group. + // Don't allow a new field into a field group that includes a page break or hidden field. + // Don't allow a new section inside of a section. + // Don't allow an embedded form in a section. + function allowNewFieldDrop(draggable, droppable) { + var classes = draggable.classList; + var newPageBreakField = classes.contains('frm_tbreak'); + var newHiddenField = classes.contains('frm_thidden'); + var newSectionField = classes.contains('frm_tdivider'); + var newEmbedField = classes.contains('frm_tform'); + var newUserIdField = classes.contains('frm_tuser_id'); + var newFieldWillBeAddedToAGroup = !('frm-show-fields' === droppable.id || droppable.classList.contains('start_divider')); + if (newFieldWillBeAddedToAGroup) { + if (groupIncludesBreakOrHiddenOrUserId(droppable)) { + // Never allow any field beside a page break or a hidden field. + return false; + } + return !newHiddenField && !newPageBreakField && !newUserIdField; + } + var fieldTypeIsAlwaysAllowed = !newPageBreakField && !newHiddenField && !newSectionField && !newEmbedField; + if (fieldTypeIsAlwaysAllowed) { + return true; + } + var newFieldWillBeAddedToASection = droppable.classList.contains('start_divider') || null !== droppable.closest('.start_divider'); + if (newFieldWillBeAddedToASection) { + // Don't allow a section or an embedded form in a section. + return !newEmbedField && !newSectionField; + } + return true; + } + function allowMoveField(draggable, droppable) { + if (isFieldGroup(draggable)) { + return allowMoveFieldGroup(draggable, droppable); + } + var isPageBreak = draggable.classList.contains('edit_field_type_break'); + if (isPageBreak) { + // Page breaks are only allowed in the main list of fields, not in sections or in field groups. + return false; + } + if (droppable.classList.contains('start_divider')) { + return allowMoveFieldToSection(draggable); + } + var isHiddenField = draggable.classList.contains('edit_field_type_hidden'); + var isUserIdField = draggable.classList.contains('edit_field_type_user_id'); + if (isHiddenField || isUserIdField) { + // Hidden fields and user id fields should not be added to field groups since they're not shown + // and don't make sense with the grid distribution. + return false; + } + return allowMoveFieldToGroup(draggable, droppable); + } + function isFieldGroup(draggable) { + return draggable.classList.contains('frm_field_box') && !draggable.classList.contains('form-field'); + } + function allowMoveFieldGroup(fieldGroup, droppable) { + if (droppable.classList.contains('start_divider') && null === fieldGroup.querySelector('.start_divider')) { + // Allow a field group with no section inside of a section. + return true; + } + return false; + } + function allowMoveFieldToSection(draggable) { + var draggableIncludeEmbedForm = draggable.classList.contains('edit_field_type_form') || draggable.querySelector('.edit_field_type_form'); + if (draggableIncludeEmbedForm) { + // Do not allow an embedded form inside of a section. + return false; + } + var draggableIncludesSection = draggable.classList.contains('edit_field_type_divider') || draggable.querySelector('.edit_field_type_divider'); + if (draggableIncludesSection) { + // Do not allow a section inside of a section. + return false; + } + return true; + } + function allowMoveFieldToGroup(draggable, group) { + if (groupIncludesBreakOrHiddenOrUserId(group)) { + // Never allow any field beside a page break or a hidden field. + return false; + } + var isFieldGroup = jQuery(draggable).children('ul.frm_sorting').not('.start_divider').length > 0; + if (isFieldGroup) { + // Do not allow a field group directly inside of a field group unless it's in a section. + return false; + } + var draggableIncludesASection = draggable.classList.contains('edit_field_type_divider') || draggable.querySelector('.edit_field_type_divider'); + var draggableIsEmbedField = draggable.classList.contains('edit_field_type_form'); + var groupIsInASection = null !== group.closest('.start_divider'); + if (groupIsInASection && (draggableIncludesASection || draggableIsEmbedField)) { + // Do not allow a section or an embed field inside of a section. + return false; + } + return true; + } + function groupIncludesBreakOrHiddenOrUserId(group) { + return null !== group.querySelector('.edit_field_type_break, .edit_field_type_hidden, .edit_field_type_user_id'); + } + function groupCanFitAnotherField(fieldsInRow, $field) { + if (fieldsInRow.length < MAX_FIELD_GROUP_SIZE) { + return true; + } + if (fieldsInRow.length > MAX_FIELD_GROUP_SIZE) { + return false; + } + var fieldId = $field.attr('data-fid'); + // Allow the maximum number if we're not changing field groups. + return 1 === jQuery(fieldsInRow).filter("[data-fid=\"".concat(fieldId, "\"]")).length; + } + function loadFields(fieldId) { + var thisField = document.getElementById(fieldId); + var $thisField = jQuery(thisField); + var field = []; + var addHtmlToField = function addHtmlToField(element) { + var frmHiddenFdata = element.querySelector('.frm_hidden_fdata'); + element.classList.add('frm_load_now'); + if (frmHiddenFdata !== null) { + field.push(frmHiddenFdata.innerHTML); + } + }; + addHtmlToField(thisField); + var nextField = getNextField(thisField); + while (nextField && field.length < 15) { + addHtmlToField(nextField); + nextField = getNextField(nextField); + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_load_field', + field: field, + form_id: thisFormId, + nonce: frmGlobal.nonce + }, + success: function success(html) { + return handleAjaxLoadFieldSuccess(html, $thisField, field); + } + }); + } + function getNextField(field) { + var _field$parentNode; + if (field.nextElementSibling) { + return field.nextElementSibling; + } + return (_field$parentNode = field.parentNode) === null || _field$parentNode === void 0 || (_field$parentNode = _field$parentNode.closest('.frm_field_box')) === null || _field$parentNode === void 0 || (_field$parentNode = _field$parentNode.nextElementSibling) === null || _field$parentNode === void 0 ? void 0 : _field$parentNode.querySelector('.form-field'); + } + function handleAjaxLoadFieldSuccess(html, $thisField, field) { + var key; + var $nextSet; + html = html.replace(/^\s+|\s+$/g, ''); + if (html.indexOf('{') !== 0) { + jQuery('.frm_load_now').removeClass('.frm_load_now').html('Error'); + return; + } + html = JSON.parse(html); + for (key in html) { + jQuery("#frm_field_id_".concat(key)).replaceWith(html[key]); + var newReplacedField = document.getElementById("frm_field_id_".concat(key)); + if (newReplacedField) { + newReplacedField.querySelectorAll('[data-toggle]').forEach(function (toggle) { + return toggle.setAttribute('data-bs-toggle', toggle.getAttribute('data-toggle')); + }); + newReplacedField.querySelectorAll('.frm-dropdown-menu').forEach(function (dropdownMenu) { + return dropdownMenu.classList.add('dropdown-menu'); + }); + } + setupSortable("#frm_field_id_".concat(key, ".edit_field_type_divider ul.frm_sorting")); + makeDraggable(document.getElementById("frm_field_id_".concat(key))); + } + $nextSet = $thisField.nextAll('.frm_field_loading:not(.frm_load_now)'); + if ($nextSet.length) { + loadFields($nextSet.attr('id')); + } else { + // go up a level + $nextSet = jQuery(document.getElementById('frm-show-fields')).find('.frm_field_loading:not(.frm_load_now)'); + if ($nextSet.length) { + loadFields($nextSet.attr('id')); + } + } + initiateMultiselect(); + renumberPageBreaks(); + maybeHideQuantityProductFieldOption(); + var loadedEvent = new Event('frm_ajax_loaded_field', { + bubbles: false + }); + loadedEvent.frmFields = field.map(function (f) { + return JSON.parse(f); + }); + document.dispatchEvent(loadedEvent); + } + function addFieldClick() { + /*jshint validthis:true */ + var $thisObj = jQuery(this); + // there is no real way to disable a (with a valid href attribute) in HTML - https://css-tricks.com/how-to-disable-links/ + if ($thisObj.hasClass('disabled')) { + return false; + } + var $button = $thisObj.closest('.frmbutton'); + var fieldType = $button.attr('id'); + if ($button.hasClass('frm_at_limit')) { + showLimitModal(); + return false; + } + if (shouldStopInsertingField(fieldType)) { + // We do not want to return false here. + // Otherwise it causes issues with trying to add a new slider field + // when clicking the button. + return; + } + var hasBreak = 0; + if ('summary' === fieldType) { + hasBreak = $newFields.children('li[data-type="break"]').length > 0 ? 1 : 0; + } + var formId = thisFormId; + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: getInsertNewFieldArgs(fieldType, 0, formId, hasBreak), + success: function success(msg) { + handleAddFieldClickResponse(msg); + var fieldId = checkMsgForFieldId(msg); + if (fieldId) { + /** + * Fires after a field is added. + * + * @since 6.23 + * + * @param {Object} fieldData The field data. + * @param {string} fieldData.field The field HTML. + * @param {string} fieldData.field_type The field type. + * @param {string} fieldData.form_id The form ID. + */ + wp.hooks.doAction('frm_after_field_added_in_form_builder', { + field: msg, + fieldId: fieldId, + fieldType: fieldType, + form_id: formId + }); + } + }, + error: handleInsertFieldError + }); + return false; + } + function showLimitModal() { + var wrapper = document.querySelector('.frm_wrap'); + if (!wrapper) { + return; + } + var temporaryAnchor = document.createElement('a'); + temporaryAnchor.setAttribute('data-frmverify', __('This field type has reached its limit.', 'formidable')); + wrapper.append(temporaryAnchor); + temporaryAnchor.click(); + temporaryAnchor.remove(); + var confirmButton = document.getElementById('frm-confirmed-click'); + if (confirmButton) { + confirmButton.style.display = 'none'; + } + } + function handleAddFieldClickResponse(msg) { + document.getElementById('frm_form_editor_container').classList.add('frm-has-fields'); + var replaceWith = wrapFieldLi(msg); + var submitField = $newFields[0].querySelector('.edit_field_type_submit'); + if (!submitField) { + $newFields.append(replaceWith); + } else { + jQuery(submitField.closest('.frm_field_box:not(.form-field)')).before(replaceWith); + } + afterAddField(msg, true); + replaceWith.each(function () { + makeDroppable(this.querySelector('ul.frm_sorting')); + makeDraggable(this.querySelector('.form-field'), '.frm-move'); + }); + } + function insertFormField(fieldType) { + var fieldOptions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + return new Promise(function (resolve) { + var formId = thisFormId; + var hasBreak = 0; + if ('summary' === fieldType) { + hasBreak = $newFields.children('li[data-type="break"]').length > 0 ? 1 : 0; + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: Object.assign(getInsertNewFieldArgs(fieldType, 0, formId, hasBreak), { + field_options: fieldOptions + }), + success: function success(msg) { + resolve(msg); + setTimeout(function () { + updateFieldOrder(); + afterAddField(msg, true); + var fieldId = checkMsgForFieldId(msg); + if (fieldId) { + /** + * Fires after a field is added. + * + * @since 6.23 + * + * @param {Object} fieldData The field data. + * @param {string} fieldData.field The field HTML. + * @param {string} fieldData.field_type The field type. + * @param {string} fieldData.form_id The form ID. + */ + wp.hooks.doAction('frm_after_field_added_in_form_builder', { + field: msg, + fieldId: fieldId, + fieldType: fieldType, + form_id: formId + }); + } + }, 10); + }, + error: handleInsertFieldError + }); + }); + } + function maybeHideQuantityProductFieldOption() { + var hide = true; + var opts = document.querySelectorAll('.frmjs_prod_field_opt_cont'); + if ($newFields.find('li.edit_field_type_product').length > 1) { + hide = false; + } + for (var i = 0; i < opts.length; i++) { + opts[i].classList.toggle('frm_hidden', hide); + } + } + + /** + * Returns true if a field can be duplicated. + * + * @since 6.19 + * + * @param {HTMLElement} field + * @param {number} maxFieldsInGroup Maximum allowed fields in a group. + * + * @return {boolean} True if the field can be added to the group. + */ + function canDuplicateField(field, maxFieldsInGroup) { + if (field.classList.contains('frm-page-collapsed')) { + return false; + } + var fieldGroup = field.closest('li.frm_field_box:not(.form-field)'); + if (!fieldGroup) { + return true; + } + var fieldsInGroup = getFieldsInRow(jQuery(fieldGroup.querySelector('ul'))).length; + return fieldsInGroup < maxFieldsInGroup; + } + function duplicateField() { + var maxFieldsInGroup = MAX_FIELD_GROUP_SIZE; + var $field = jQuery(this).closest('li.form-field'); + var newRowId = this.getAttribute('frm-target-row-id'); + if (!(newRowId !== null && newRowId !== void 0 && newRowId.startsWith('frm_field_group_')) && !canDuplicateField($field.get(0), maxFieldsInGroup)) { + /* translators: %1$d: Maximum number of fields allowed in a field group. */ + infoModal(sprintf(__('You can only have a maximum of %1$d fields in a field group. Delete or move out a field from the group and try again.', 'formidable'), maxFieldsInGroup)); + return; + } + closeOpenFieldDropdowns(); + var fieldId = $field.data('fid'); + var children = fieldsInSection(fieldId); + var fieldOrder; + if (null !== newRowId) { + fieldOrder = this.getAttribute('frm-field-order'); + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_duplicate_field', + field_id: fieldId, + form_id: thisFormId, + children: children, + nonce: frmGlobal.nonce + }, + success: function success(msg) { + var _$field$0$querySelect; + var newRow; + var replaceWith; + if (null !== newRowId) { + newRow = document.getElementById(newRowId); + if (newRow) { + replaceWith = msgAsjQueryObject(msg); + jQuery(newRow).append(replaceWith); + makeDraggable(replaceWith.get(0), '.frm-move'); + if (null !== fieldOrder) { + newRow.lastElementChild.setAttribute('frm-field-order', fieldOrder); + } + jQuery(newRow).trigger('frm_added_duplicated_field_to_row', { + duplicatedFieldHtml: msg, + originalFieldId: fieldId + }); + afterAddField(msg, false); + setLayoutClassesForDuplicatedFieldInGroup($field.get(0), replaceWith.get(0)); + return; + } + } + if ($field.siblings('li.form-field').length) { + replaceWith = msgAsjQueryObject(msg); + $field.after(replaceWith); + syncLayoutClasses($field); + makeDraggable(replaceWith.get(0), '.frm-move'); + } else { + replaceWith = wrapFieldLi(msg); + $field.parent().parent().after(replaceWith); + makeDroppable(replaceWith.get(0).querySelector('ul.frm_sorting')); + makeDraggable(replaceWith.get(0).querySelector('li.form-field'), '.frm-move'); + } + updateFieldOrder(); + afterAddField(msg, false); + maybeDuplicateUnsavedSettings(fieldId, msg); + toggleOneSectionHolder(replaceWith.find('.start_divider')); + (_$field$0$querySelect = $field[0].querySelector('.frm-dropdown-menu.dropdown-menu-right')) === null || _$field$0$querySelect === void 0 || _$field$0$querySelect.classList.remove('show'); + setLayoutClassesForDuplicatedFieldInGroup($field.get(0), replaceWith.get(0)); + } + }); + return false; + } + + /** + * Sets the layout classes for a duplicated field in a field group from the layout classes of the original field. + * + * @param {HTMLElement} field The original field. + * @param {HTMLElement} newField The duplicated field. + * + * @return {void} + */ + function setLayoutClassesForDuplicatedFieldInGroup(field, newField) { + var _document$getElementB; + var hoverTarget = field.closest('.frm-field-group-hover-target'); + if (!hoverTarget || !isFieldGroup(hoverTarget.parentElement)) { + return; + } + var fieldId = field.dataset.fid; + var fieldClasses = (_document$getElementB = document.getElementById("frm_classes_".concat(fieldId))) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.value; + if (!fieldClasses) { + return; + } + fieldClasses = fieldClasses.replace('frm_first', ''); + if (!newField.className.includes(fieldClasses)) { + newField.className += " ".concat(fieldClasses); + var classesInput = document.getElementById("frm_classes_".concat(newField.dataset.fid)); + if (classesInput) { + classesInput.value = fieldClasses; + } + } + } + function maybeDuplicateUnsavedSettings(originalFieldId, newFieldHtml) { + var originalSettings = document.getElementById("frm-single-settings-".concat(originalFieldId)); + if (!originalSettings) { + return; + } + var newFieldId = jQuery(newFieldHtml).attr('data-fid'); + if (newFieldId === undefined) { + return; + } + var copySettings = document.getElementById("frm-single-settings-".concat(newFieldId)); + if (!copySettings) { + return; + } + var fieldOptionKeys = ['name', 'required', 'unique', 'read_only', 'placeholder', 'description', 'size', 'max', 'format', 'prepend', 'append', 'separate_value']; + originalSettings.querySelectorAll('input[name^="field_options["], textarea[name^="field_options["]').forEach(function (originalSetting) { + var key = getKeyFromSettingInput(originalSetting); + if ('options' === key) { + copyOption(originalSetting, copySettings, originalFieldId, newFieldId); + return; + } + if (!fieldOptionKeys.includes(key)) { + return; + } + var tagType = originalSetting.matches('input') ? 'input' : 'textarea'; + var copySetting = copySettings.querySelector("".concat(tagType, "[name=\"field_options[").concat(key, "_").concat(newFieldId, "]\"]")); + if (null === copySetting) { + return; + } + if ('checkbox' === originalSetting.type) { + if (originalSetting.checked !== copySetting.checked) { + jQuery(copySetting).trigger('click'); + } + } else if ('text' === originalSetting.type || 'textarea' === tagType) { + if (originalSetting.value !== copySetting.value) { + copySetting.value = originalSetting.value; + jQuery(copySetting).trigger('change'); + } + } + }); + var originalDefault = originalSettings.querySelector("input[name=\"default_value_".concat(originalFieldId, "\"]")); + if (null !== originalDefault) { + var copyDefault = copySettings.querySelector("input[name=\"default_value_".concat(newFieldId, "\"]")); + if (null !== copyDefault && originalDefault.value !== copyDefault.value) { + copyDefault.value = originalDefault.value; + jQuery(copyDefault).trigger('change'); + } + } + } + function copyOption(originalSetting, copySettings, originalFieldId, newFieldId) { + var remainingKeyDetails = originalSetting.name.substr(23 + "".concat(originalFieldId).length); + var copyKey = "field_options[options_".concat(newFieldId, "]").concat(remainingKeyDetails); + var copySetting = copySettings.querySelector("input[name=\"".concat(copyKey, "\"]")); + if (null !== copySetting && copySetting.value !== originalSetting.value) { + copySetting.value = originalSetting.value; + jQuery(copySetting).trigger('change'); + } + } + function getKeyFromSettingInput(input) { + var nameWithoutPrefix = input.name.substr(14); + var nameSplit = nameWithoutPrefix.split('_'); + nameSplit.pop(); + return nameSplit.join('_'); + } + function closeOpenFieldDropdowns() { + var openSettings = document.querySelector('.frm-field-settings-open'); + if (openSettings) { + openSettings.classList.remove('frm-field-settings-open'); + jQuery(document).off('click', '#frm_builder_page', handleClickOutsideOfFieldSettings); + jQuery('.frm-field-action-icons .dropdown.open').removeClass('open'); + } + } + function handleClickOutsideOfFieldSettings(event) { + if (!jQuery(event.originalEvent.target).closest('.frm-field-action-icons').length) { + closeOpenFieldDropdowns(); + } + } + function checkForMultiselectKeysOnMouseMove(event) { + var keyIsDown = Boolean(event.ctrlKey || event.metaKey || event.shiftKey); + jQuery(builderPage).toggleClass('frm-multiselect-key-is-down', keyIsDown); + checkForActiveHoverTarget(event); + } + function checkForActiveHoverTarget(event) { + var container = postBodyContent; + if (container.classList.contains('frm-dragging-field')) { + return; + } + if (null !== document.querySelector('.frm-field-group-hover-target .frm-field-settings-open')) { + // do not set a hover target if a dropdown is open for the current hover target. + return; + } + var elementFromPoint = document.elementFromPoint(event.clientX, event.clientY); + if (null !== elementFromPoint && !elementFromPoint.classList.contains('edit_field_type_divider')) { + var list = elementFromPoint.closest('ul.frm_sorting'); + if (null !== list && !list.classList.contains('start_divider') && 'frm-show-fields' !== list.id) { + var previousHoverTarget = maybeRemoveGroupHoverTarget(); + if (false !== previousHoverTarget && !jQuery(previousHoverTarget).is(list)) { + destroyFieldGroupPopup(); + } + updateFieldGroupControls(jQuery(list), getFieldsInRow(jQuery(list)).length); + list.classList.add('frm-field-group-hover-target'); + jQuery('#wpbody-content').on('mousemove', maybeRemoveHoverTargetOnMouseMove); + } + } + } + function maybeRemoveGroupHoverTarget() { + var controls = document.getElementById('frm_field_group_controls'); + if (controls) { + controls.style.display = 'none'; + } + var previousHoverTarget = document.querySelector('.frm-field-group-hover-target'); + if (!previousHoverTarget) { + return false; + } + jQuery('#wpbody-content').off('mousemove', maybeRemoveHoverTargetOnMouseMove); + previousHoverTarget.classList.remove('frm-field-group-hover-target'); + return previousHoverTarget; + } + function maybeRemoveHoverTargetOnMouseMove(event) { + var elementFromPoint = document.elementFromPoint(event.clientX, event.clientY); + if (null !== elementFromPoint && null !== elementFromPoint.closest('#frm-show-fields')) { + return; + } + maybeRemoveGroupHoverTarget(); + deleteTooltips(); + } + function onFieldActionDropdownShow(isFieldGroup) { + unselectFieldGroups(); + + // maybe offset the dropdown if it goes off the edge of the screen or container. + setTimeout(function () { + var ul = document.querySelector('.dropdown .frm-dropdown-menu.show'); + if (!ul) { + return; + } + if (null === ul.getAttribute('aria-label')) { + ul.setAttribute('aria-label', __('More Options', 'formidable')); + } + if (0 === ul.children.length) { + fillFieldActionDropdown(ul, true === isFieldGroup); + } + var $ul = jQuery(ul); + if ($ul.offset().left > jQuery(window).width() - $ul.outerWidth()) { + ul.style.left = "".concat(-$ul.outerWidth(), "px"); + } else if (postBodyContent && $ul.offset().left < postBodyContent.getBoundingClientRect().left) { + ul.style.right = 'auto'; + ul.style.left = '0'; + } + var firstAnchor = ul.firstElementChild.querySelector('a'); + if (firstAnchor) { + firstAnchor.focus(); + } + }, 0); + } + function onFieldGroupActionDropdownShow() { + onFieldActionDropdownShow(true); + } + function changeSectionStyle(e) { + var collapsedSection = e.target.closest('.frm-section-collapsed'); + if (!collapsedSection) { + return; + } + if (e.type === 'show') { + collapsedSection.style.zIndex = 3; + } else { + collapsedSection.style.zIndex = 1; + } + } + function fillFieldActionDropdown(ul, isFieldGroup) { + var classSuffix = isFieldGroup ? '_field_group' : '_field'; + var options = [getDeleteActionOption(isFieldGroup), getDuplicateActionOption(isFieldGroup)]; + if (!isFieldGroup) { + options.push({ + class: 'frm_select', + icon: 'frm_settings_icon', + label: __('Field Settings', 'formidable') + }); + } + options.forEach(function (option) { + var li = document.createElement('div'); + li.classList.add('frm_more_options_li', 'dropdown-item'); + var anchor = document.createElement('a'); + anchor.classList.add(option.class + classSuffix); + anchor.setAttribute('href', '#'); + makeTabbable(anchor); + var span = document.createElement('span'); + span.textContent = option.label; + anchor.innerHTML = ""); + anchor.append(document.createTextNode(' ')); + anchor.append(span); + li.append(anchor); + ul.append(li); + }); + } + function getDeleteActionOption(isFieldGroup) { + var option = { + class: 'frm_delete', + icon: 'frm_delete_icon' + }; + option.label = isFieldGroup ? __('Delete Group', 'formidable') : __('Delete', 'formidable'); + return option; + } + function getDuplicateActionOption(isFieldGroup) { + var option = { + class: 'frm_clone', + icon: 'frm_clone_icon' + }; + option.label = isFieldGroup ? __('Duplicate Group', 'formidable') : __('Duplicate', 'formidable'); + return option; + } + function wrapFieldLi(field) { + var wrapper = div(); + if ('string' === typeof field) { + wrapper.innerHTML = field; + } else { + wrapper.append(field); + } + var result = jQuery(); + Array.from(wrapper.children).forEach(function (li) { + result = result.add(jQuery('
    • ').addClass('frm_field_box').html(jQuery('
        ').addClass('frm_grid_container frm_sorting').append(li))); + }); + return result; + } + function wrapFieldLiInPlace(li) { + var ul = tag('ul', { + className: 'frm_grid_container frm_sorting' + }); + var wrapper = tag('li', { + className: 'frm_field_box', + child: ul + }); + li.replaceWith(wrapper); + ul.append(li); + makeDroppable(ul); + makeDraggable(wrapper, '.frm-move'); + } + function afterAddField(msg, addFocus) { + var regex = /id="(\S+)"/; + var match = regex.exec(msg); + var field = document.getElementById(match[1]); + var section = "#".concat(match[1], ".edit_field_type_divider ul.frm_sorting.start_divider"); + var $thisSection = jQuery(section); + var type = field.getAttribute('data-type'); + checkHtmlForNewFields(msg); + var toggled = false; + fieldUpdated(); + setupSortable(section); + if ('quantity' === type) { + // try to automatically attach a product field + maybeSetProductField(field); + } + if ('product' === type || 'quantity' === type) { + // quantity too needs to be a part of the if stmt especially cos of the very + // 1st quantity field (or even if it's just one quantity field in the form). + maybeHideQuantityProductFieldOption(); + } + if ($thisSection.length) { + $thisSection.parent('.frm_field_box').children('.frm_no_section_fields').addClass('frm_block'); + } else { + var $parentSection = jQuery(field).closest('ul.frm_sorting.start_divider'); + if ($parentSection.length) { + toggleOneSectionHolder($parentSection); + toggled = true; + } + } + if (msg.includes('frm-collapse-page')) { + renumberPageBreaks(); + } + addClass(field, 'frm-newly-added'); + setTimeout(function () { + field.classList.remove('frm-newly-added'); + }, 1000); + var lastRowOrderInput = field.querySelector('#frm-last-row-fields-order'); + if (lastRowOrderInput) { + updateLastRowFieldsOrder(JSON.parse(lastRowOrderInput.value)); + } + if (addFocus) { + var bounding = field.getBoundingClientRect(); + var container = document.getElementById('post-body-content'); + var inView = bounding.top >= 0 && bounding.left >= 0 && bounding.right <= (window.innerWidth || document.documentElement.clientWidth) && bounding.bottom <= (window.innerHeight || document.documentElement.clientHeight); + if (!inView) { + container.scroll({ + top: container.scrollHeight, + left: 0, + behavior: 'smooth' + }); + } + if (toggled === false) { + toggleOneSectionHolder($thisSection); + } + } + deselectFields(); + initiateMultiselect(); + document.getElementById('frm-show-fields').classList.remove('frm-over-droppable'); + maybeDisableFieldButtonAtLimit(type); + + // Bootstrap 5 uses data-bs-toggle instead of data-toggle, and requires that elements have the dropdown-menu class. + field.querySelectorAll('[data-toggle]').forEach(function (toggle) { + return toggle.setAttribute('data-bs-toggle', toggle.getAttribute('data-toggle')); + }); + field.querySelectorAll('.frm-dropdown-menu').forEach(function (dropdownMenu) { + return dropdownMenu.classList.add('dropdown-menu'); + }); + var addedEvent = new Event('frm_added_field', { + bubbles: false + }); + addedEvent.frmField = field; + addedEvent.frmSection = section; + addedEvent.frmType = type; + addedEvent.frmToggles = toggled; + document.dispatchEvent(addedEvent); + } + + /** + * @since 6.27 + * + * @param {string} type + * @return {void} + */ + function maybeDisableFieldButtonAtLimit(type) { + var button = document.getElementById(type); + if (button !== null && button !== void 0 && button.dataset.limit && countFieldTypeInForm(type) >= button.dataset.limit) { + button.classList.add('frm_at_limit'); + } + } + function updateLastRowFieldsOrder(fieldsOrder) { + if (!fieldsOrder || 'object' !== _typeof(fieldsOrder)) { + return; + } + Object.keys(fieldsOrder).forEach(function (fieldId) { + var orderInput = document.querySelector("input[name=\"field_options[field_order_".concat(fieldId, "]\"]")); + if (orderInput) { + orderInput.value = fieldsOrder[fieldId]; + } + }); + } + + /** + * Since multiple new fields may get added when a new field is inserted, check the HTML. + * + * @param {string} html + * @return {void} + */ + function checkHtmlForNewFields(html) { + var element = div(); + element.innerHTML = html; + element.querySelectorAll('.form-field').forEach(addFieldIdToDraftFieldsInput); + } + + /** + * @param {HTMLElement} field + * @return {void} + */ + function addFieldIdToDraftFieldsInput(field) { + if (!field.dataset.fid) { + return; + } + var draftInput = document.getElementById('draft_fields'); + if (!draftInput) { + return; + } + if ('' === draftInput.value) { + draftInput.value = field.dataset.fid; + } else { + var split = draftInput.value.split(','); + if (!split.includes(field.dataset.fid)) { + draftInput.value += ",".concat(field.dataset.fid); + } + } + } + function clearSettingsBox(preventFieldGroups) { + jQuery('#new_fields .frm-single-settings').addClass('frm_hidden'); + jQuery('#frm-options-panel > .frm-single-settings').removeClass('frm_hidden'); + deselectFields(preventFieldGroups); + } + function deselectFields(preventFieldGroups) { + jQuery('li.ui-state-default.selected').removeClass('selected'); + jQuery('.frm-show-field-settings.selected').removeClass('selected'); + if (!preventFieldGroups) { + unselectFieldGroups(); + } + } + function checkCalculationCreatedByUser() { + var calculation = this.value; + var warningMessage = checkMatchingParens(calculation); + warningMessage += checkShortcodes(calculation, this); + if (warningMessage !== '') { + infoModal("".concat(calculation, "\n\n").concat(warningMessage)); + } + } + + /** + * Checks a string for parens, brackets, and curly braces and returns a message if any unmatched are found. + * + * @param {string} formula The formula string to check. + * @return {string} Warning message if unmatched delimiters found, empty string otherwise. + */ + function checkMatchingParens(formula) { + var stack = []; + var formulaArray = formula.split(''); + var length = formulaArray.length; + var opening = ['{', '[', '(']; + var closing = { + '}': '{', + ')': '(', + ']': '[' + }; + var hasUnmatchedClosing = false; + var msg = ''; + var i; + var top; + for (i = 0; i < length; i++) { + if (opening.includes(formulaArray[i])) { + stack.push(formulaArray[i]); + continue; + } + if (Object.hasOwn(closing, formulaArray[i])) { + top = stack.pop(); + if (top !== closing[formulaArray[i]]) { + hasUnmatchedClosing = true; + } + } + } + if (stack.length > 0 || hasUnmatchedClosing) { + msg = "".concat(frmAdminJs.unmatched_parens, "\n\n"); + return msg; + } + return ''; + } + + /** + * Checks a calculation for shortcodes that shouldn't be in it and returns a message if found. + * + * @param {string} calculation The calculation formula. + * @param {HTMLElement} inputElement The input element for the calculation. + * @return {string} Warning message if invalid shortcodes found, empty string otherwise. + */ + function checkShortcodes(calculation, inputElement) { + var msg = checkNonNumericShortcodes(calculation, inputElement); + msg += checkNonFormShortcodes(calculation); + return msg; + } + + /** + * Checks if a numeric calculation has shortcodes that output non-numeric strings and returns a message if found. + * + * @param {string} calculation The calculation formula. + * @param {HTMLElement} inputElement The input element for the calculation. + * @return {string} Warning message if non-numeric shortcodes found, empty string otherwise. + */ + function checkNonNumericShortcodes(calculation, inputElement) { + var msg = ''; + if (isTextCalculation(inputElement)) { + return msg; + } + var nonNumericShortcodes = getNonNumericShortcodes(); + if (nonNumericShortcodes.test(calculation)) { + msg = "".concat(frmAdminJs.text_shortcodes, "\n\n"); + } + return msg; + } + + /** + * Determines if the calculation input is from a text calculation. + * + * @param {HTMLElement} inputElement The calculation input element. + */ + function isTextCalculation(inputElement) { + return jQuery(inputElement).siblings('label[for^="calc_type"]').children('input').prop('checked'); + } + + /** + * Returns a regular expression of shortcodes that can't be used in numeric calculations. + * + * @return {RegExp} Pattern matching non-numeric shortcodes. + */ + function getNonNumericShortcodes() { + return /\[(date|time|email|ip)\]/; + } + + /** + * Checks if a string has any shortcodes that do not belong in forms and returns a message if any are found. + * + * @param {string} formula The formula string to check. + * @return {string} Warning message if non-form shortcodes found, empty string otherwise. + */ + function checkNonFormShortcodes(formula) { + var nonFormShortcodes = getNonFormShortcodes(); + var msg = ''; + if (nonFormShortcodes.test(formula)) { + msg += "".concat(frmAdminJs.view_shortcodes, "\n\n"); + } + return msg; + } + + /** + * Returns a regular expression of shortcodes that can't be used in forms but can be used in Views, Email + * Notifications, and other Formidable areas. + * + * @return {RegExp} Pattern matching shortcodes not valid in forms. + */ + function getNonFormShortcodes() { + return /\[id\]|\[key\]|\[if\s\w+\]|\[foreach\s\w+\]|\[created-at(\s*)?/g; + } + function isCalcBoxType(box, listClass) { + var list = jQuery(box).find('.frm_code_list'); + return 1 === list.length && list.hasClass(listClass); + } + function extractExcludedOptions(exclude) { + var opts = []; + if (!Array.isArray(exclude)) { + return opts; + } + for (var i = 0; i < exclude.length; i++) { + if (exclude[i].startsWith('[')) { + opts.push(exclude[i]); + // remove it + exclude.splice(i, 1); + // https://love2dev.com/blog/javascript-remove-from-array/#remove-from-array-splice-value + i--; + } + } + return opts; + } + function hasExcludedOption(field, excludedOpts) { + var hasOption = false; + for (var i = 0; i < excludedOpts.length; i++) { + var inputs = document.getElementsByName(getFieldOptionInputName(excludedOpts[i], field.fieldId)); + // 2nd condition checks that there's at least one non-empty value + if (inputs.length && jQuery(inputs[0]).val()) { + hasOption = true; + break; + } + } + return hasOption; + } + function getFieldOptionInputName(opt, fieldId) { + var at = opt.indexOf(']'); + return "field_options".concat(opt.substring(0, at), "_").concat(fieldId).concat(opt.substring(at)); + } + function popCalcFields(element, force) { + var settingsBox = jQuery(element).closest('.frm-single-settings'); + var calc = settingsBox.find('.frm-calc-field'); + if (!force && (!calc.length || calc.val() === '' || calc.is(':hidden'))) { + return; + } + var isSummary = isCalcBoxType(element, 'frm_js_summary_list'); + var fieldId = settingsBox.find('input[name="frm_fields_submitted[]"]').val(); + var box; + if (force) { + box = element; + } else { + box = document.getElementById("frm-calc-box-".concat(fieldId)); + } + var exclude = getExcludeArray(box, isSummary); + var excludedOpts = extractExcludedOptions(exclude); + var fields = getFieldList(); + var list = document.getElementById("frm-calc-list-".concat(fieldId)); + list.innerHTML = ''; + for (var i = 0; i < fields.length; i++) { + if (exclude !== null && exclude !== void 0 && exclude.includes(fields[i].fieldType) || excludedOpts.length && hasExcludedOption(fields[i], excludedOpts)) { + continue; + } + var _a = document.createElement('a'); + _a.setAttribute('href', '#'); + _a.setAttribute('data-code', fields[i].fieldId); + _a.classList.add('frm_insert_code'); + _a.append(span(fields[i].fieldName)); + _a.append(span({ + className: 'frm-text-sm frm-text-grey-500', + text: "[".concat(fields[i].fieldId, "]") + })); + var li = document.createElement('li'); + li.classList.add("frm-field-list-".concat(fieldId)); + li.classList.add("frm-field-list-".concat(fields[i].fieldType)); + li.append(_a); + list.append(li); + } + } + function getExcludeArray(calcBox, isSummary) { + var codeList = calcBox.querySelector('.frm_code_list'); + var exclude = JSON.parse(codeList.getAttribute('data-exclude')); + if (isSummary) { + // includedExtras are those that are normally excluded from the summary but the form owner can choose to include, + // when they have been chosen to be included, then they can now be manually excluded in the calc box. + var includedExtras = getIncludedExtras(); + if (includedExtras.length) { + for (var i = 0; i < exclude.length; i++) { + if (includedExtras.includes(exclude[i])) { + // remove it + exclude.splice(i, 1); + // https://love2dev.com/blog/javascript-remove-from-array/#remove-from-array-splice-value + i--; + } + } + } + } + return exclude; + } + function getIncludedExtras() { + var checked = []; + var checkboxes = document.getElementsByClassName('frm_include_extras_field'); + for (var i = 0; i < checkboxes.length; i++) { + if (checkboxes[i].checked) { + checked.push(checkboxes[i].value); + } + } + return checked; + } + function rePopCalcFieldsForSummary() { + popCalcFields(jQuery('.frm-inline-modal.postbox:has(.frm_js_summary_list)')[0], true); + } + function getFieldList(fieldType) { + var i; + var fields = []; + var allFields = document.querySelectorAll('li.frm_field_box'); + var checkType = fieldType !== undefined; + for (i = 0; i < allFields.length; i++) { + // data-ftype is better (than data-type) cos of fields loaded by AJAX - which might not be ready yet + if (checkType && allFields[i].getAttribute('data-ftype') !== fieldType) { + continue; + } + var fieldId = allFields[i].getAttribute('data-fid'); + if (fieldId) { + fields.push({ + fieldId: fieldId, + fieldName: getPossibleValue("frm_name_".concat(fieldId)), + fieldType: getPossibleValue("field_options_type_".concat(fieldId)), + fieldKey: getPossibleValue("field_options_field_key_".concat(fieldId)) + }); + } + } + return wp.hooks.applyFilters('frm_admin_get_field_list', fields, fieldType, allFields); + } + function popProductFields(field) { + var i; + var checked; + var id; + var options = []; + var current = getCurrentProductFields(field); + var fName = field.getAttribute('data-frmfname'); + var products = getFieldList('product'); + var quantities = getFieldList('quantity'); + var isSelect = field.tagName === 'SELECT'; // for reverse compatibility. + // whether we have just 1 product and 1 quantity field & should therefore attach the latter to the former + var auto = 1 === quantities.length && 1 === products.length; + if (isSelect) { + // This fallback can be removed after 4.05. + current = field.getAttribute('data-frmcurrent'); + } + for (i = 0; i < products.length; i++) { + // let's be double sure it's string, else indexOf will fail + id = products[i].fieldId.toString(); + checked = auto || current.includes(id); + if (isSelect) { + // This fallback can be removed after 4.05. + checked = checked ? ' selected' : ''; + options.push("")); + } else { + checked = checked ? ' checked' : ''; + options.push(''); + } + } + field.innerHTML = options.join(''); + } + function getCurrentProductFields(prodFieldOpt) { + var products = prodFieldOpt.querySelectorAll('[type="checkbox"]:checked'); + var idsArray = []; + for (var i = 0; i < products.length; i++) { + idsArray.push(products[i].value); + } + return idsArray; + } + function popAllProductFields() { + var opts = document.querySelectorAll('.frmjs_prod_field_opt'); + for (var i = 0; i < opts.length; i++) { + popProductFields(opts[i]); + } + } + function maybeSetProductField(field) { + var fieldId = field.getAttribute('data-fid'); + var productFieldOpt = document.getElementById("field_options[product_field_".concat(fieldId, "]")); + if (!productFieldOpt) { + return; + } + popProductFields(productFieldOpt); + // in order to move its settings to that LHS panel where + // the update form resides, else it'll lose this setting + moveFieldSettings(document.getElementById("frm-single-settings-".concat(fieldId))); + } + + /** + * If the element doesn't exist, use a blank value. + * @param {string} id The element ID to look up. + */ + function getPossibleValue(id) { + var field = document.getElementById(id); + if (field) { + return field.value; + } + return ''; + } + function liveChanges() { + /*jshint validthis:true */ + var option; + var newValue = this.value; + var changes = document.getElementById(this.getAttribute('data-changeme')); + var att = this.getAttribute('data-changeatt'); + if (!changes) { + return; + } + if (att !== null) { + if (changes.tagName === 'SELECT' && att === 'placeholder') { + option = changes.options[0]; + if (option.value === '') { + option.innerHTML = newValue; + } else { + // Create a placeholder option if there are no blank values. + addBlankSelectOption(changes, newValue); + } + } else if (att === 'class') { + changeFieldClass(changes, this); + } else if (isSliderField(changes)) { + updateSliderFieldPreview(changes, att, newValue); + } else { + changes.setAttribute(att, newValue); + } + } else if (changes.id.indexOf('setup-message') === 0) { + if (newValue !== '') { + changes.innerHTML = ''; + } + } else { + changes.innerHTML = purifyHtml(newValue); + if ('TEXTAREA' === changes.nodeName && changes.classList.contains('wp-editor-area')) { + // Trigger change events on wysiwyg textareas so we can also sync default values in the visual tab. + jQuery(changes).trigger('change'); + } + if (changes.classList.contains('frm_primary_label') && 'break' === changes.nextElementSibling.getAttribute('data-ftype')) { + changes.nextElementSibling.querySelector('.frm_button_submit').textContent = newValue; + } + } + } + function updateSliderFieldPreview(field, att, newValue) { + if (frmGlobal.proIncludesSliderJs) { + var hookName = 'frm_update_slider_field_preview'; + var hookArgs = { + field: field, + att: att, + newValue: newValue + }; + wp.hooks.doAction(hookName, hookArgs); + return; + } + + // This functionality has been moved to pro since v5.4.3. This code should be removed eventually. + if ('value' === att) { + if ('' === newValue) { + newValue = getSliderMidpoint(field); + } + field.value = newValue; + } else { + field.setAttribute(att, newValue); + } + if (!['value', 'min', 'max'].includes(att)) { + return; + } + if (('max' === att || 'min' === att) && '' === getSliderDefaultValueInput(field.id)) { + field.value = getSliderMidpoint(field); + } + field.parentNode.querySelector('.frm_range_value').textContent = field.value; + } + function getSliderDefaultValueInput(previewInputId) { + return document.querySelector("input[data-changeme=\"".concat(previewInputId, "\"][data-changeatt=\"value\"]")).value; + } + function getSliderMidpoint(sliderInput) { + var max = parseFloat(sliderInput.getAttribute('max')); + var min = parseFloat(sliderInput.getAttribute('min')); + return (max - min) / 2 + min; + } + function isSliderField(previewInput) { + return 'range' === previewInput.type && previewInput.parentNode.classList.contains('frm_range_container'); + } + function toggleInvalidMsg() { + /*jshint validthis:true */ + var fieldId = this.getAttribute('data-fid'); + var value = ''; + ['field_options_max_', 'frm_format_'].forEach(function (id) { + var input = document.getElementById(id + fieldId); + if (!input) { + return; + } + value += input.value; + }); + var typeDropdown = document.getElementsByName("field_options[type_".concat(fieldId, "]"))[0]; + var fieldType = typeDropdown.options[typeDropdown.selectedIndex].value; + if (fieldType === 'text') { + toggleValidationBox('' !== value, ".frm_invalid_msg".concat(fieldId)); + } + } + function markRequired() { + /*jshint validthis:true */ + var thisid = this.id.replace('frm_', ''); + var fieldId = thisid.replace('req_field_', ''); + var checked = this.checked; + var label = jQuery("#field_label_".concat(fieldId, " .frm_required")); + toggleValidationBox(checked, ".frm_required_details".concat(fieldId)); + if (checked) { + var $reqBox = jQuery("input[name=\"field_options[required_indicator_".concat(fieldId, "]\"]")); + if ($reqBox.val() === '') { + $reqBox.val('*'); + } + label.removeClass('frm_hidden'); + } else { + label.addClass('frm_hidden'); + } + } + function toggleValidationBox(hasValue, messageClass) { + var $msg = jQuery(messageClass); + if (hasValue) { + $msg.fadeIn('fast').closest('.frm_validation_msg').fadeIn('fast'); + } else { + // Fade out validation options + var $validationBox = $msg.fadeOut('fast').closest('.frm_validation_box'); + var visibleCount = $validationBox.css('display', 'block').children(":not(".concat(messageClass, "):visible")).length; + $validationBox.css('display', ''); + if (visibleCount === 0) { + $msg.closest('.frm_validation_msg').fadeOut('fast'); + } + } + } + function markUnique() { + /*jshint validthis:true */ + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + var $thisField = jQuery(".frm_unique_details".concat(fieldId)); + if (this.checked) { + $thisField.fadeIn('fast').closest('.frm_validation_msg').fadeIn('fast'); + var $unqDetail = jQuery(".frm_unique_details".concat(fieldId, " input")); + if ($unqDetail.val() === '') { + $unqDetail.val(frmAdminJs.default_unique); + } + } else { + var $validationBox = $thisField.fadeOut('fast').closest('.frm_validation_box'); + var visibleCount = $validationBox.css('display', 'block').children(":not(.frm_unique_details".concat(fieldId, "):visible")).length; + $validationBox.css('display', ''); + if (visibleCount === 0) { + $thisField.closest('.frm_validation_msg').fadeOut('fast'); + } + } + } + + //Fade confirmation field and validation option in or out + function addConf() { + /*jshint validthis:true */ + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + var val = jQuery(this).val(); + var $thisField = jQuery(document.getElementById("frm_field_id_".concat(fieldId))); + toggleValidationBox(val !== '', ".frm_conf_details".concat(fieldId)); + if (val !== '') { + //Add default validation message if empty + var valMsg = jQuery(".frm_validation_box .frm_conf_details".concat(fieldId, " input")); + if (valMsg.val() === '') { + valMsg.val(frmAdminJs.default_conf); + } + setConfirmationFieldDescriptions(fieldId); + + //Add or remove class for confirmation field styling + if (val === 'inline') { + $thisField.removeClass('frm_conf_below').addClass('frm_conf_inline'); + } else if (val === 'below') { + $thisField.removeClass('frm_conf_inline').addClass('frm_conf_below'); + } + jQuery(".frm-conf-box-".concat(fieldId)).removeClass('frm_hidden'); + } else { + jQuery(".frm-conf-box-".concat(fieldId)).addClass('frm_hidden'); + setTimeout(function () { + $thisField.removeClass('frm_conf_inline frm_conf_below'); + }, 200); + } + } + function setConfirmationFieldDescriptions(fieldId) { + var fieldType = document.getElementsByName("field_options[type_".concat(fieldId, "]"))[0].value; + var fieldDescription = document.getElementById("field_description_".concat(fieldId)); + var hiddenDescName = "field_options[description_".concat(fieldId, "]"); + var newValue = frmAdminJs["enter_".concat(fieldType)]; + maybeSetNewDescription(fieldDescription, hiddenDescName, newValue); + var confFieldDescription = document.getElementById("conf_field_description_".concat(fieldId)); + var hiddenConfName = "field_options[conf_desc_".concat(fieldId, "]"); + var newConfValue = frmAdminJs["confirm_".concat(fieldType)]; + maybeSetNewDescription(confFieldDescription, hiddenConfName, newConfValue); + } + function maybeSetNewDescription(descriptionDiv, hiddenName, newValue) { + if (descriptionDiv.innerHTML === frmAdminJs.desc) { + // Set the visible description value and the hidden description value + descriptionDiv.innerHTML = newValue; + document.getElementsByName(hiddenName)[0].value = newValue; + } + } + function initBulkOptionsOverlay() { + /*jshint validthis:true */ + var $info = initModal('#frm-bulk-modal', '700px'); + if ($info === false) { + return; + } + jQuery('.frm-insert-preset').on('click', insertBulkPreset); + jQuery(builderForm).on('click', 'a.frm-bulk-edit-link', function (event) { + event.preventDefault(); + var content = ''; + var fieldId = jQuery(this).closest('[data-fid]').data('fid'); + var separate = usingSeparateValues(fieldId); + var product = isProductField(fieldId); + var optList = document.getElementById("frm_field_".concat(fieldId, "_opts")); + if (!optList) { + return; + } + var opts = optList.getElementsByTagName('li'); + document.getElementById('bulk-field-id').value = fieldId; + for (var i = 0; i < opts.length; i++) { + var key = opts[i].getAttribute('data-optkey'); + if (key !== '000') { + var label = document.getElementsByName("field_options[options_".concat(fieldId, "][").concat(key, "][label]"))[0]; + if (label !== undefined) { + content += label.value; + if (separate) { + content += "|".concat(document.getElementsByName("field_options[options_".concat(fieldId, "][").concat(key, "][value]"))[0].value); + } + if (product) { + content += "|".concat(document.getElementsByName("field_options[options_".concat(fieldId, "][").concat(key, "][price]"))[0].value); + } + content += '\r\n'; + } + } + if (i >= opts.length - 1) { + document.getElementById('frm_bulk_options').value = content; + } + } + $info.dialog('open'); + return false; + }); + jQuery('#frm-update-bulk-opts').on('click', function () { + var fieldId = document.getElementById('bulk-field-id').value; + var optionType = document.getElementById('bulk-option-type').value; + if (optionType) { + // Use custom handler for custom option type. + return; + } + this.classList.add('frm_loading_button'); + frmAdminBuild.updateOpts(fieldId, document.getElementById('frm_bulk_options').value, $info); + fieldUpdated(); + }); + } + function insertBulkPreset(event) { + /*jshint validthis:true */ + var opts = JSON.parse(this.getAttribute('data-opts')); + event.preventDefault(); + document.getElementById('frm_bulk_options').value = opts.join('\n'); + return false; + } + + //Add new option or "Other" option to radio/checkbox/dropdown + function addFieldOption() { + /*jshint validthis:true */ + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + var newOption = jQuery("#frm_field_".concat(fieldId, "_opts .frm_option_template")).prop('outerHTML'); + var optType = jQuery(this).data('opttype'); + var optKey = 0; + var oldKey = '000'; + var lastKey = getHighestOptKey(fieldId); + if (lastKey !== oldKey) { + optKey = lastKey + 1; + } + + //Update hidden field + if (optType === 'other') { + document.getElementById("other_input_".concat(fieldId)).value = 1; + + //Hide "Add Other" option now if this is radio field + var ftype = jQuery(this).data('ftype'); + if (ftype === 'radio' || ftype === 'select') { + jQuery(this).fadeOut('slow'); + } + var data = { + action: 'frm_add_field_option', + field_id: fieldId, + opt_key: optKey, + opt_type: optType, + nonce: frmGlobal.nonce + }; + jQuery.post(ajaxurl, data, function (msg) { + jQuery(document.getElementById("frm_field_".concat(fieldId, "_opts"))).append(msg); + resetDisplayedOpts(fieldId); + }); + } else { + newOption = newOption.replace(new RegExp("optkey=\"".concat(oldKey, "\""), 'g'), "optkey=\"".concat(optKey, "\"")); + newOption = newOption.replace(new RegExp("-".concat(oldKey, "_"), 'g'), "-".concat(optKey, "_")); + newOption = newOption.replace(new RegExp("-".concat(oldKey, "\""), 'g'), "-".concat(optKey, "\"")); + newOption = newOption.replace(new RegExp("\\[".concat(oldKey, "\\]"), 'g'), "[".concat(optKey, "]")); + newOption = newOption.replace('frm_hidden frm_option_template', ''); + newOption = { + newOption: newOption + }; + addSaveAndDragIconsToOption(fieldId, newOption); + var $thisOption = this.closest('.frm_single_option'); + if ($thisOption) { + $thisOption.after(newOption.newOption); + } else { + // Backwards compatibility "@since 6.24" + // Note: Keep it jQuery since some events are attached to the element + jQuery("#frm_field_".concat(fieldId, "_opts")).append(newOption.newOption); + } + resetDisplayedOpts(fieldId); + } + fieldOptionEnableAllRemoveButtons(this); + fieldUpdated(); + } + + /** + * Enable all remove buttons for field options. + * + * @param {HTMLElement} element The add option button element. + */ + function fieldOptionEnableAllRemoveButtons(element) { + var _element$closest; + // Make sure all remove buttons are enabled + var parentEl = element.classList.contains('frm-add-option-legacy') // Backwards compatibility "@since 6.24" + ? (_element$closest = element.closest('.frm-collapse-me')) === null || _element$closest === void 0 ? void 0 : _element$closest.querySelector('.frm_sortable_field_opts') : element.closest('.frm_sortable_field_opts'); + parentEl === null || parentEl === void 0 || parentEl.querySelectorAll('.frm_remove_tag.frm_disabled').forEach(function (button) { + return button.classList.remove('frm_disabled'); + }); + } + function getHighestOptKey(fieldId) { + var i = 0; + var optKey = 0; + var opts = jQuery("#frm_field_".concat(fieldId, "_opts li")); + var lastKey = 0; + for (i; i < opts.length; i++) { + optKey = opts[i].getAttribute('data-optkey'); + if (opts.length === 1) { + return optKey; + } + if (optKey !== '000') { + optKey = optKey.replace('other_', ''); + optKey = parseInt(optKey, 10); + } + if (!isNaN(lastKey) && (optKey > lastKey || lastKey === '000')) { + lastKey = optKey; + } + } + return lastKey; + } + function toggleMultSel() { + /*jshint validthis:true */ + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + toggleMultiSelect(fieldId, this.value); + } + function toggleMultiSelect(fieldId, value) { + var setting = jQuery(".frm_multiple_cont_".concat(fieldId)); + if (value === 'select') { + setting.fadeIn('fast'); + } else { + setting.fadeOut('fast'); + } + } + function toggleSepValues() { + /*jshint validthis:true */ + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + toggle(jQuery(".field_".concat(fieldId, "_option_key"))); + jQuery(".field_".concat(fieldId, "_option")).toggleClass('frm_with_key'); + } + function toggleImageOptions() { + /*jshint validthis:true */ + var $field = jQuery(this).closest('.frm-single-settings'); + var fieldId = $field.data('fid'); + var displayField = document.getElementById("frm_field_id_".concat(fieldId)); + refreshOptionDisplayNow(jQuery(this)); + toggle(jQuery(".field_".concat(fieldId, "_image_id"))); + toggle(jQuery(".frm_toggle_image_options_".concat(fieldId))); + toggle(jQuery(".frm_image_size_".concat(fieldId))); + toggle(jQuery(".frm_alignment_".concat(fieldId))); + toggle(jQuery(".frm-add-other#frm_add_field_".concat(fieldId))); + var hasImageOptions = imagesAsOptions(fieldId); + if (hasImageOptions) { + setAlignment(fieldId, 'inline'); + removeImageSizeClasses(displayField); + var imageSize = getImageOptionSize(fieldId); + displayField.classList.add('frm_image_options'); + displayField.classList.add("frm_image_size_".concat(imageSize)); + $field.find('.frm-bulk-edit-link').hide(); + } else { + displayField.classList.remove('frm_image_options'); + removeImageSizeClasses(displayField); + setAlignment(fieldId, 'block'); + $field.find('.frm-bulk-edit-link').show(); + } + + /** + * Fires when image options are toggled for a field. + * + * @param {HTMLElement} field The field element. + * @param {boolean} hasImageOptions Whether the field has image options enabled. + */ + wp.hooks.doAction('frm_image_options_toggled', $field[0], hasImageOptions); + } + function removeImageSizeClasses(field) { + field.classList.remove('frm_image_size_', 'frm_image_size_small', 'frm_image_size_medium', 'frm_image_size_large', 'frm_image_size_xlarge'); + } + function setAlignment(fieldId, alignment) { + jQuery("#field_options_align_".concat(fieldId)).val(alignment).trigger('change'); + } + function setImageSize() { + var $field = jQuery(this).closest('.frm-single-settings'); + var fieldId = $field.data('fid'); + var displayField = document.getElementById("frm_field_id_".concat(fieldId)); + refreshOptionDisplay(); + if (imagesAsOptions(fieldId)) { + removeImageSizeClasses(displayField); + displayField.classList.add('frm_image_options'); + displayField.classList.add("frm_image_size_".concat(getImageOptionSize(fieldId))); + } + } + function refreshOptionDisplayNow(object) { + var $field = object.closest('.frm-single-settings'); + var fieldID = $field.data('fid'); + jQuery(".field_".concat(fieldID, "_option")).trigger('change'); + } + function refreshOptionDisplay() { + /*jshint validthis:true */ + refreshOptionDisplayNow(jQuery(this)); + } + function addImageToOption(event) { + var _wp; + var imagePreview = event.target.closest('.frm_image_preview_wrapper'); + if (!((_wp = wp) !== null && _wp !== void 0 && _wp.media) || imagePreview !== null && imagePreview !== void 0 && imagePreview.dataset.upgrade) { + return; + } + event.preventDefault(); + wp.media.model.settings.post.id = 0; + var fileFrame = wp.media.frames.file_frame = wp.media({ + multiple: false, + library: { + type: ['image'] + } + }); + fileFrame.on('select', function () { + var attachment = fileFrame.state().get('selection').first().toJSON(); + var img = imagePreview.querySelector('img'); + img.setAttribute('src', attachment.url); + img.classList.remove('frm_hidden'); + img.removeAttribute('srcset'); // Prevent the old image from sticking around. + + imagePreview.querySelector('.frm_image_preview_frame').style.display = 'block'; + imagePreview.querySelector('.frm_image_preview_title').textContent = attachment.filename; + imagePreview.querySelector('.frm_choose_image_box').style.display = 'none'; + var $imagePreview = jQuery(imagePreview); + $imagePreview.siblings('input[name*="[label]"]').data('frmimgurl', attachment.url); + $imagePreview.find('input.frm_image_id').val(attachment.id).trigger('change'); + wp.media.model.settings.post.id = 0; + }); + fileFrame.open(); + } + function removeImageFromOption(event) { + var $this = jQuery(this); + var previewWrapper = $this.closest('.frm_image_preview_wrapper'); + event.preventDefault(); + event.stopPropagation(); + previewWrapper.find('img').attr('src', ''); + previewWrapper.find('.frm_image_preview_frame').hide(); + previewWrapper.find('.frm_choose_image_box').show(); + previewWrapper.find('input.frm_image_id').val(0).trigger('change'); + } + function toggleMultiselect() { + /*jshint validthis:true */ + var dropdown = jQuery(this).closest('li').find('.frm_form_fields select'); + if (this.checked) { + dropdown.attr('multiple', 'multiple'); + } else { + dropdown.removeAttr('multiple'); + } + } + + /** + * Allow typing on form switcher click without an extra click to search. + */ + function focusSearchBox() { + var searchBox = document.getElementById('dropform-search-input'); + if (searchBox) { + setTimeout(function () { + searchBox.focus(); + }, 100); + } + } + + /** + * Dismiss a warning message and send an AJAX request to update the dismissal state. + * + * @since 6.3 + * + * @param {Event} event The event object associated with the click on the dismiss icon. + */ + function dismissWarningMessage(event) { + var target = event.target; + var warningEl = target.closest('.frm_warning_style'); + jQuery(warningEl).fadeOut(400, function () { + return warningEl.remove(); + }); + var action = target.dataset.action; + var formData = new FormData(); + doJsonPost(action, formData); + } + + /** + * If a field is clicked in the builder, prevent inputs from changing. + * @param {Event} e The event to prevent. + */ + function stopFieldFocus(e) { + e.preventDefault(); + } + + /** + * Delete a field option. + */ + function deleteFieldOption() { + var parentLi = this.parentNode; + var parentUl = parentLi.parentNode; + + // If only 2 visible options, add disabled class to the other delete button + var visibleOptions = parentUl.querySelectorAll('li:not(.frm_hidden)'); + if (visibleOptions.length === 2) { + var _Array$from$find$quer; + (_Array$from$find$quer = Array.from(visibleOptions).find(function (li) { + return li !== parentLi; + }).querySelector('.frm_remove_tag')) === null || _Array$from$find$quer === void 0 || _Array$from$find$quer.classList.add('frm_disabled'); + } + + /*jshint validthis:true */ + var otherInput; + var fieldId = this.getAttribute('data-fid'); + jQuery(parentLi).fadeOut('fast', function () { + wp.hooks.doAction('frm_before_delete_field_option', this); + jQuery(parentLi).remove(); + var hasOther = jQuery(parentUl).find('.frm_other_option'); + if (hasOther.length < 1) { + otherInput = document.getElementById("other_input_".concat(fieldId)); + if (otherInput) { + otherInput.value = 0; + } + jQuery("#other_button_".concat(fieldId)).fadeIn('fast'); + } + }); + fieldUpdated(); + } + + /** + * If a radio button is set as default, allow a click to + * deselect it. + */ + function maybeUncheckRadio() { + /*jshint validthis:true */ + var $self = jQuery(this); + if ($self.is(':checked')) { + var uncheck = function uncheck() { + setTimeout(function () { + $self.prop('checked', false); + }, 0); + }; + var up; // eslint-disable-line prefer-const + var unbind = function unbind() { + $self.off('mouseup', up); + }; + up = function up() { + uncheck(); + unbind(); + }; + $self.on('mouseup', up); + $self.one('mouseout', unbind); + } + } + + /** + * If the field option has the default text, clear it out on click. + */ + function maybeClearOptText() { + /*jshint validthis:true */ + if (this.value === frmAdminJs.new_option) { + this.setAttribute('data-value-on-focus', this.value); + this.value = ''; + } + } + function confirmFieldsDeleteMessage(numberOfFields) { + /* translators: %1$s: Number of fields that are selected to be deleted. */ + return sprintf(__('Are you sure you want to delete these %1$s selected field(s)?', 'formidable'), numberOfFields); + } + function clickDeleteField() { + /*jshint validthis:true */ + var confirmMsg = frmAdminJs.conf_delete; + var maybeDivider = this.parentNode.parentNode.parentNode.parentNode.parentNode; + var li = maybeDivider.parentNode; + var field = jQuery(this).closest('li.form-field'); + var fieldId = field.data('fid'); + if (field.data('ftype') === 'divider') { + var fieldBoxes = document.querySelectorAll('.frm-field-group-hover-target .start_divider .frm_field_box'); + var fieldIdsToDelete = 0; + fieldBoxes.forEach(function (fieldBox) { + var fieldsInsideFieldBox = fieldBox.querySelectorAll('li.form-field'); + if (fieldsInsideFieldBox) { + fieldIdsToDelete += fieldsInsideFieldBox.length; + } + }); + if (fieldIdsToDelete) { + confirmMsg = confirmFieldsDeleteMessage(++fieldIdsToDelete); + } + } + if (li.classList.contains('frm-section-collapsed') || li.classList.contains('frm-page-collapsed')) { + return false; + } + + // If deleting a section, use a special message. + if (maybeDivider.className === 'divider_section_only') { + confirmMsg = frmAdminJs.conf_delete_sec; + } + this.setAttribute('data-frmverify', confirmMsg); + this.setAttribute('data-frmverify-btn', 'frm-button-red'); + this.setAttribute('data-deletefield', fieldId); + closeOpenFieldDropdowns(); + confirmLinkClick(this); + return false; + } + function clickSelectField() { + this.closest('li.form-field').click(); + } + function clickDeleteFieldGroup() { + var hoverTarget = document.querySelector('.frm-field-group-hover-target'); + if (!hoverTarget) { + return; + } + hoverTarget.classList.add('frm-selected-field-group'); + var decoy = document.createElement('div'); + decoy.classList.add('frm-delete-field-groups', 'frm_hidden'); + document.body.append(decoy); + decoy.click(); + } + function duplicateFieldGroup() { + var hoverTarget = document.querySelector('.frm-field-group-hover-target'); + if (!hoverTarget) { + return; + } + var newRowId = "frm_field_group_".concat(getAutoId()); + var placeholderUlChild = document.createTextNode(''); + wrapFieldLiInPlace(placeholderUlChild); + var newRow = jQuery(placeholderUlChild).closest('li').get(0); + newRow.classList.add('frm_hidden'); + var newRowUl = newRow.querySelector('ul'); + newRowUl.id = newRowId; + jQuery(hoverTarget.closest('li.frm_field_box')).after(newRow); + var $fields = getFieldsInRow(jQuery(hoverTarget)); + var syncDetails = []; + var injectedCloneOptions = []; + var expectedLength = $fields.length; + var originalFieldIdByDuplicatedFieldId = {}; + var duplicatedCount = 0; + jQuery(newRow).on('frm_added_duplicated_field_to_row', function (_, args) { + originalFieldIdByDuplicatedFieldId[jQuery(args.duplicatedFieldHtml).attr('data-fid')] = args.originalFieldId; + if (expectedLength > ++duplicatedCount) { + return; + } + var $newRowUl = jQuery(newRowUl); + var $duplicatedFields = getFieldsInRow($newRowUl); + injectedCloneOptions.forEach(function (cloneOption) { + cloneOption.remove(); + }); + for (var index = 0; index < expectedLength; ++index) { + $newRowUl.append($newRowUl.children("li.form-field[frm-field-order=\"".concat(index, "\"]"))); + } + syncLayoutClasses($duplicatedFields.first(), syncDetails); + newRow.classList.remove('frm_hidden'); + updateFieldOrder(); + getFieldsInRow($newRowUl).each(function () { + maybeDuplicateUnsavedSettings(originalFieldIdByDuplicatedFieldId[this.getAttribute('data-fid')], jQuery(this).prop('outerHTML')); + }); + }); + $fields.each(function (index) { + var cloneOption = document.createElement('li'); + cloneOption.classList.add('frm_clone_field'); + cloneOption.setAttribute('frm-target-row-id', newRowId); + cloneOption.setAttribute('frm-field-order', index); + this.append(cloneOption); + cloneOption.click(); + injectedCloneOptions.push(cloneOption); + syncDetails.push(getSizeOfLayoutClass(getLayoutClassName(this.classList))); + }); + } + function clickFieldGroupLayout() { + var hoverTarget = document.querySelector('.frm-field-group-hover-target'); + if (!hoverTarget) { + return; + } + deselectFields(); + var sizeOfFieldGroup = getSizeOfFieldGroupFromChildElement(hoverTarget.querySelector('li.form-field')); + hoverTarget.classList.add('frm-has-open-field-group-popup'); + jQuery(document).on('click', '#frm_builder_page', destroyFieldGroupPopupOnOutsideClick); + var popupWrapper = div(); + popupWrapper.style.position = 'relative'; + popupWrapper.append(getFieldGroupPopup(sizeOfFieldGroup, this)); + this.parentNode.append(popupWrapper); + var firstLayoutOption = popupWrapper.querySelector('.frm-row-layout-option'); + if (firstLayoutOption) { + firstLayoutOption.focus(); + } + } + function destroyFieldGroupPopupOnOutsideClick(event) { + if (event.target.classList.contains('frm-custom-field-group-layout') || event.target.classList.contains('frm-cancel-custom-field-group-layout')) { + return; + } + if (!jQuery(event.target).closest('#frm_field_group_controls').length && !jQuery(event.target).closest('#frm_field_group_popup').length) { + destroyFieldGroupPopup(); + } + } + function getSizeOfFieldGroupFromChildElement(element) { + var $ul = jQuery(element).closest('ul'); + if ($ul.length) { + return getFieldsInRow($ul).length; + } + return getSelectedFieldCount(); + } + function getFieldGroupPopup(sizeOfFieldGroup, childElement) { + var popup = document.getElementById('frm_field_group_popup'); + if (!popup) { + popup = div(); + } else { + popup.innerHTML = ''; + } + popup.id = 'frm_field_group_popup'; + var wrapper = div(); + wrapper.style.padding = '0 24px 12px'; + wrapper.append(getRowLayoutTitle()); + var rowLayoutOptions = getRowLayoutOptions(sizeOfFieldGroup); + var ul = childElement.closest('ul.frm_sorting'); + if (ul) { + maybeMarkRowLayoutAsActive(ul, rowLayoutOptions); + } + wrapper.append(rowLayoutOptions); + popup.append(wrapper); + popup.append(separator()); + if (sizeOfFieldGroup <= 6) { + popup.append(getCustomLayoutOption()); + } + popup.append(getBreakIntoDifferentRowsOption()); + return popup; + } + function maybeMarkRowLayoutAsActive(activeRow, options) { + var length = options.children.length; + for (var index = 0; index < length; ++index) { + var currentRow = options.children[index]; + if (rowLayoutsMatch(currentRow, activeRow)) { + currentRow.classList.add('frm-active-row-layout'); + return; + } + } + } + function separator() { + return document.createElement('hr'); + } + function getCustomLayoutOption() { + var option = div(); + option.textContent = __('Custom layout', 'formidable'); + jQuery(option).prepend(getIconClone('frm_gear_svg')); + option.classList.add('frm-custom-field-group-layout'); + makeTabbable(option); + return option; + } + function makeTabbable(element, ariaLabel) { + element.setAttribute('tabindex', 0); + element.setAttribute('role', 'button'); + if (ariaLabel !== undefined) { + element.setAttribute('aria-label', ariaLabel); + } + } + function getIconClone(iconId) { + var clone = document.getElementById(iconId).cloneNode(true); + clone.id = ''; + return clone; + } + function getBreakIntoDifferentRowsOption() { + var option = div(); + option.textContent = __('Break into rows', 'formidable'); + jQuery(option).prepend(getIconClone('frm_break_field_group_svg')); + option.classList.add('frm-break-field-group'); + makeTabbable(option); + return option; + } + function getRowLayoutTitle() { + var rowLayoutTitle = div(); + rowLayoutTitle.classList.add('frm-row-layout-title'); + rowLayoutTitle.textContent = __('Row Layout', 'formidable'); + return rowLayoutTitle; + } + function getRowLayoutOptions(size) { + var wrapper = getEmptyGridContainer(); + if (size > 6) { + wrapper.append(getRowLayoutOption(size, 'even')); + return wrapper; + } + if (5 !== size) { + wrapper.append(getRowLayoutOption(size, 'even')); + } + if (size % 2 === 1) { + // only include the middle option for odd numbers because even doesn't make a lot of sense. + wrapper.append(getRowLayoutOption(size, 'middle')); + } + if (size < 6) { + wrapper.append(getRowLayoutOption(size, 'left')); + wrapper.append(getRowLayoutOption(size, 'right')); + } else { + var padding = div(); + padding.classList.add('frm_fourth'); + wrapper.prepend(padding); + } + return wrapper; + } + function getRowLayoutOption(size, type) { + var option = div(); + option.classList.add('frm-row-layout-option'); + makeTabbable(option, type); + var useClass; + switch (size) { + case 6: + useClass = 'frm_half'; + break; + case 5: + useClass = 'frm_third'; + break; + default: + if (size > 6) { + // We only show a single option at 6-12, so we use the full width. + useClass = 'frm_full'; + } else { + useClass = size % 2 === 1 ? 'frm_fourth' : 'frm_third'; + } + break; + } + option.classList.add(useClass); + option.setAttribute('layout-type', type); + option.append(getRowForSizeAndType(size, type)); + return option; + } + function rowLayoutsMatch(row1, row2) { + return getRowLayoutAsKey(row1) === getRowLayoutAsKey(row2); + } + function getRowLayoutAsKey(row) { + var $fields; + if (row.classList.contains('frm-row-layout-option')) { + $fields = jQuery(row).find('.frm_grid_container').children(); + } else { + $fields = getFieldsInRow(jQuery(row)); + } + var sizes = []; + $fields.each(function () { + sizes.push(getSizeOfLayoutClass(getLayoutClassName(this.classList))); + }); + return sizes.join('-'); + } + function getRowForSizeAndType(size, type) { + var row = getEmptyGridContainer(); + for (var index = 0; index < size; ++index) { + var block = div(); + block.classList.add(getClassForBlock(size, type, index)); + block.style.height = '16px'; + block.style.background = '#9EA9B8'; + block.style.borderRadius = '1px'; + row.append(block); + } + return row; + } + + /** + * @param {number} size 2-12. + * @param {string} type even, middle, left, or right. + * @param {number} index 0-5. + * @return {string} The class name. + */ + function getClassForBlock(size, type, index) { + if ('even' === type) { + return getEvenClassForSize(size, index); + } else if ('middle' === type) { + if (3 === size) { + return 1 === index ? 'frm6' : 'frm3'; + } + if (5 === size) { + return 2 === index ? 'frm4' : 'frm2'; + } + } else if ('left' === type) { + return 0 === index ? getLargeClassForSize(size) : getSmallClassForSize(size); + } else if ('right' === type) { + return index === size - 1 ? getLargeClassForSize(size) : getSmallClassForSize(size); + } + return 'frm12'; + } + + /** + * @param {number} size 2-12. + * @param {number|undefined} index 0-5. + * @return {string} The class name. + */ + function getEvenClassForSize(size, index) { + if (size > 6) { + return 'frm1'; + } + if ([2, 3, 4, 6].includes(size)) { + return getLayoutClassForSize(12 / size); + } + if (5 === size && index !== undefined) { + return 0 === index ? 'frm4' : 'frm2'; + } + return 'frm12'; + } + function getSmallClassForSize(size) { + switch (size) { + case 2: + case 3: + return 'frm3'; + case 4: + return 'frm2'; + case 5: + return 'frm2'; + case 6: + return 'frm1'; + default: + return 'frm12'; + } + } + function getLargeClassForSize(size) { + switch (size) { + case 2: + return 'frm9'; + case 3: + case 4: + return 'frm6'; + case 5: + return 'frm4'; + case 6: + return 'frm7'; + default: + return 'frm12'; + } + } + function getEmptyGridContainer() { + var wrapper = div(); + wrapper.classList.add('frm_grid_container'); + return wrapper; + } + + /** + * Handle when a field group layout option (that sets grid classes/column sizing) is selected in the "Row Layout" popup. + * + * @return {void} + */ + function handleFieldGroupLayoutOptionClick() { + var row = document.querySelector('.frm-field-group-hover-target'); + if (!row) { + // The field group layout options also get clicked when merging multiple rows. + // The following code isn't required for multiple rows though so just exit early. + return; + } + var type = this.getAttribute('layout-type'); + syncLayoutClasses(getFieldsInRow(jQuery(row)).first(), type); + destroyFieldGroupPopup(); + } + function handleFieldGroupLayoutOptionInsideMergeClick() { + var $ul = mergeSelectedFieldGroups(); + var type = this.getAttribute('layout-type'); + syncLayoutClasses(getFieldsInRow($ul).first(), type); + unselectFieldGroups(); + } + function mergeSelectedFieldGroups() { + var $selectedFieldGroups = jQuery('.frm-selected-field-group'); + var $firstGroupUl = $selectedFieldGroups.first(); + $selectedFieldGroups.not($firstGroupUl).each(function () { + getFieldsInRow(jQuery(this)).each(function () { + var previousParent = this.parentNode; + getFieldsInRow($firstGroupUl).last().after(this); + if (!jQuery(previousParent).children('li.form-field').length) { + // clean up the previous field group if we've removed all of its fields. + previousParent.closest('li.frm_field_box').remove(); + } + }); + }); + updateFieldOrder(); + syncLayoutClasses(getFieldsInRow($firstGroupUl).first()); + return $firstGroupUl; + } + function customFieldGroupLayoutClick() { + if (null !== this.closest('.frm-merge-fields-into-row')) { + return; + } + var $fields = getFieldsInRow(jQuery('.frm-field-group-hover-target')); + setupCustomLayoutOptions($fields); + } + function setupCustomLayoutOptions($fields) { + var size = $fields.length; + var popup = document.getElementById('frm_field_group_popup'); + popup.innerHTML = ''; + var wrapper = div(); + wrapper.style.padding = '0 24px'; + var layoutClass = getEvenClassForSize(5 === size ? 6 : size); + var inputRow = div(); + inputRow.style.padding = '20px 0'; + inputRow.classList.add('frm_grid_container'); + if (5 === size) { + // add a span to pad the inputs by 1 column, to account for the missing 2 columns. + var paddingElement = document.createElement('span'); + paddingElement.classList.add('frm1'); + inputRow.append(paddingElement); + } + var inputValueOverride = getSelectedFieldCount() > 0 ? getSizeOfLayoutClass(getEvenClassForSize(size)) : false; + if (false !== inputValueOverride && inputValueOverride >= 12) { + inputValueOverride = Math.floor(12 / size); + } + for (var index = 0; index < size; ++index) { + var inputField = document.createElement('input'); + inputField.type = 'text'; + inputField.classList.add(layoutClass); + inputField.classList.add('frm-custom-grid-size-input'); + inputField.value = false !== inputValueOverride ? inputValueOverride : getSizeOfLayoutClass(getLayoutClassName($fields.get(index).classList)); + inputRow.append(inputField); + } + var heading = div(); + heading.classList.add('frm-builder-popup-heading'); + heading.textContent = __('Enter number of columns for each field', 'formidable'); + var label = div(); + label.classList.add('frm-builder-popup-subheading'); + label.textContent = __('Layouts are based on a 12-column grid system', 'formidable'); + wrapper.append(heading); + wrapper.append(label); + wrapper.append(inputRow); + var buttonsWrapper = div(); + buttonsWrapper.style.textAlign = 'right'; + var cancelButton = getSecondaryButton(); + cancelButton.textContent = __('Cancel', 'formidable'); + cancelButton.classList.add('frm-cancel-custom-field-group-layout'); + cancelButton.style.marginRight = '10px'; + var saveButton = getPrimaryButton(); + saveButton.textContent = __('Save', 'formidable'); + saveButton.classList.add('frm-save-custom-field-group-layout'); + buttonsWrapper.append(cancelButton); + buttonsWrapper.append(saveButton); + wrapper.append(buttonsWrapper); + popup.append(wrapper); + setTimeout(function () { + var firstInput = popup.querySelector('input.frm-custom-grid-size-input').focus(); + if (firstInput) { + firstInput.focus(); + } + }, 0); + } + function customFieldGroupLayoutInsideMergeClick() { + var $fields = jQuery('.frm-selected-field-group li.form-field'); + setupCustomLayoutOptions($fields); + } + function getPrimaryButton() { + var button = getButton(); + button.classList.add('button-primary', 'frm-button-primary'); + return button; + } + function getSecondaryButton() { + var button = getButton(); + button.classList.add('button-secondary', 'frm-button-secondary'); + return button; + } + function getButton() { + var button = document.createElement('a'); + button.setAttribute('href', '#'); + button.classList.add('button'); + button.style.textDecoration = 'none'; + return button; + } + function getSizeOfLayoutClass(className) { + switch (className) { + case 'frm_half': + return 6; + case 'frm_third': + return 4; + case 'frm_two_thirds': + return 8; + case 'frm_fourth': + return 3; + case 'frm_three_fourths': + return 9; + case 'frm_sixth': + return 2; + default: + if (0 === className.indexOf('frm')) { + return parseInt(className.substr(3)); + } + + // Anything missing a layout class should be a full width row. + return 12; + } + } + function getLayoutClassName(classList) { + var classes = getLayoutClasses(); + for (var index = 0; index < classes.length; ++index) { + var currentClass = classes[index]; + if (classList.contains(currentClass)) { + return currentClass; + } + } + return ''; + } + function getLayoutClassForSize(size) { + return "frm".concat(size); + } + function breakFieldGroupClick() { + var row = document.querySelector('.frm-field-group-hover-target'); + breakRow(row); + destroyFieldGroupPopup(); + } + function breakRow(row) { + var $row = jQuery(row); + getFieldsInRow($row).each(function (index) { + var field = this; + if (0 !== index) { + $row.parent().after(wrapFieldLi(field)); + } + stripLayoutFromFields(jQuery(field)); + }); + } + function stripLayoutFromFields(field) { + syncLayoutClasses(field, 'clear'); + } + function focusFieldGroupInputOnClick() { + this.select(); + } + function cancelCustomFieldGroupClick() { + revertToFieldGroupPopupFirstPage(this); + } + function revertToFieldGroupPopupFirstPage(triggerElement) { + jQuery(document.getElementById('frm_field_group_popup')).replaceWith(getFieldGroupPopup(getSizeOfFieldGroupFromChildElement(triggerElement), triggerElement)); + } + function destroyFieldGroupPopup() { + var popup = document.getElementById('frm_field_group_popup'); + if (!popup) { + return; + } + var wrapper = document.querySelector('.frm-has-open-field-group-popup'); + if (wrapper) { + wrapper.classList.remove('frm-has-open-field-group-popup'); + popup.parentNode.remove(); + } + jQuery(document).off('click', '#frm_builder_page', destroyFieldGroupPopupOnOutsideClick); + } + function saveCustomFieldGroupClick() { + var syncDetails = []; + jQuery(document.getElementById('frm_field_group_popup').querySelectorAll('.frm_grid_container input')).each(function () { + syncDetails.push(parseInt(this.value)); + }); + var $controls = jQuery(document.getElementById('frm_field_group_controls')); + if ($controls.length && 'none' !== $controls.get(0).style.display) { + syncLayoutClasses(getFieldsInRow(jQuery(document.querySelector('.frm-field-group-hover-target'))).first(), syncDetails); + } else { + var $ul = mergeSelectedFieldGroups(); + syncLayoutClasses(getFieldsInRow($ul).first(), syncDetails); + unselectFieldGroups(); + } + destroyFieldGroupPopup(); + } + function fieldGroupClick(e) { + maybeShowFieldGroupMessage(); + if ('ul' !== e.originalEvent.target.nodeName.toLowerCase()) { + // only continue if the group itself was clicked / ignore when a field is clicked. + return; + } + var hoverTarget = document.querySelector('.frm-field-group-hover-target'); + if (!hoverTarget) { + return; + } + var ctrlOrCmdKeyIsDown = e.ctrlKey || e.metaKey; + var shiftKeyIsDown = e.shiftKey; + var groupIsActive = hoverTarget.classList.contains('frm-selected-field-group'); + var $selectedFieldGroups = getSelectedFieldGroups(); + var numberOfSelectedGroups = $selectedFieldGroups.length; + if (ctrlOrCmdKeyIsDown || shiftKeyIsDown) { + // multi-selecting + + var selectedField = getSelectedField(); + if (null !== selectedField && !jQuery(selectedField).siblings('li.form-field').length) { + // count a selected field on its own as a selected field group when multiselecting. + selectedField.parentNode.classList.add('frm-selected-field-group'); + ++numberOfSelectedGroups; + } + if (ctrlOrCmdKeyIsDown) { + if (groupIsActive) { + // unselect if holding ctrl or cmd and the group was already active. + --numberOfSelectedGroups; + hoverTarget.classList.remove('frm-selected-field-group'); + syncAfterMultiSelect(numberOfSelectedGroups); + return; // exit early to avoid adding back frm-selected-field-group + } + ++numberOfSelectedGroups; + } else if (shiftKeyIsDown && !groupIsActive) { + ++numberOfSelectedGroups; // include the one we're selecting right now. + var $firstGroup = $selectedFieldGroups.first(); + var $range; + if ($firstGroup.parent().index() < jQuery(hoverTarget.parentNode).index()) { + $range = $firstGroup.parent().nextUntil(hoverTarget.parentNode); + } else { + $range = $firstGroup.parent().prevUntil(hoverTarget.parentNode); + } + $range.each(function () { + var $fieldGroup = jQuery(this).closest('li').find('ul.frm_sorting'); + if (!$fieldGroup.hasClass('frm-selected-field-group')) { + ++numberOfSelectedGroups; + $fieldGroup.addClass('frm-selected-field-group'); + } + }); + } + } else { + // not multi-selecting + unselectFieldGroups(); + numberOfSelectedGroups = 1; + } + hoverTarget.classList.add('frm-selected-field-group'); + syncAfterMultiSelect(numberOfSelectedGroups); + maybeHideFieldGroupMessage(); + jQuery(document).off('click', unselectFieldGroups); + jQuery(document).on('click', unselectFieldGroups); + } + + /** + * Hide the field group message by manipulating classes. + * + * @param {Element} fieldGroupMessage The field group message element. + * @return {void} + */ + function hideFieldGroupMessage(fieldGroupMessage) { + if (!fieldGroupMessage) { + return; + } + fieldGroupMessage.classList.add('frm_hidden'); + fieldGroupMessage.classList.remove('frm-fadein-up-back'); + } + + /** + * Show the field group message by manipulating classes. + * + * @param {Element} fieldGroupMessage The field group message element. + * @return {void} + */ + function showFieldGroupMessage(fieldGroupMessage) { + if (!fieldGroupMessage) { + return; + } + fieldGroupMessage.classList.remove('frm_hidden'); + fieldGroupMessage.classList.add('frm-fadein-up-back'); + } + + /** + * Maybe show a message if there are at least two rows. + * + * @return {void} + */ + function maybeShowFieldGroupMessage() { + var fieldGroupMessage = document.getElementById('frm-field-group-message'); + var rows = document.querySelectorAll('.edit_form_item:not(.edit_field_type_end_divider)'); + if (rows.length < 2) { + hideFieldGroupMessage(fieldGroupMessage); + return; + } + if (fieldGroupMessage) { + showFieldGroupMessage(fieldGroupMessage); + return; + } + fieldGroupMessage = div({ + id: 'frm-field-group-message', + className: 'frm-flex-center frm-fadein-up-back', + children: [span({ + id: 'frm-field-group-message-dismiss', + className: 'frm-flex-center', + child: svg({ + href: '#frm_close_icon' + }) + })] + }); + + // Insert the field group into the DOM + document.getElementById('post-body-content').append(fieldGroupMessage); + + // Get and add the field group message text + var messageText = getFieldGroupMessageText(); + fieldGroupMessage.prepend(messageText); + + // Set up a click event listener + document.getElementById('frm-field-group-message-dismiss').addEventListener('click', function () { + hideFieldGroupMessage(document.getElementById('frm-field-group-message')); + }); + } + + /** + * Get a span element with text about selecting multiple fields. + * + * @return {HTMLElement} A span element with the message and style classes. + */ + function getFieldGroupMessageText() { + var text = document.createElement('span'); + text.classList.add('frm-field-group-message-text', 'frm-flex-center'); + text.innerHTML = sprintf( + // eslint-disable-line @wordpress/valid-sprintf -- Format string is a localized variable + /* translators: %1$s: Start span HTML, %2$s: end span HTML */ + frm_admin_js.holdShiftMsg, '', ''); + return text; + } + + /** + * Maybe hide the field group message based on the number of selected rows. + * + * @return {void} + */ + function maybeHideFieldGroupMessage() { + var selectedRowCount = document.querySelectorAll('.frm-selected-field-group').length; + if (selectedRowCount < 2) { + return; + } + var fieldGroupMessage = document.getElementById('frm-field-group-message'); + hideFieldGroupMessage(fieldGroupMessage); + } + function getSelectedField() { + return document.getElementById('frm-show-fields').querySelector('li.form-field.selected'); + } + function getSelectedFieldGroups() { + var $fieldGroups = jQuery('.frm-selected-field-group'); + if ($fieldGroups.length) { + return $fieldGroups; + } + var selectedField = getSelectedField(); + if (selectedField) { + // If there is only one field in a group and the field is selected, consider the field's group as selected for multi-select. + var selectedFieldGroup = selectedField.closest('ul'); + if (selectedFieldGroup && 1 === getFieldsInRow(jQuery(selectedFieldGroup)).length) { + selectedFieldGroup.classList.add('frm-selected-field-group'); + return jQuery(selectedFieldGroup); + } + } + return jQuery(); + } + function syncAfterMultiSelect(numberOfSelectedGroups) { + clearSettingsBox(true); // unselect any fields if one is selected. + if (numberOfSelectedGroups >= 2 || 1 === numberOfSelectedGroups && selectedGroupHasMultipleFields()) { + addFieldMultiselectPopup(); + } else { + maybeRemoveMultiselectPopup(); + } + maybeRemoveGroupHoverTarget(); + } + function selectedGroupHasMultipleFields() { + return getFieldsInRow(jQuery(document.querySelector('.frm-selected-field-group'))).length > 1; + } + function unselectFieldGroups(event) { + if (event !== undefined) { + if (null !== event.originalEvent.target.closest('#frm-show-fields')) { + return; + } + if (event.originalEvent.target.classList.contains('frm-merge-fields-into-row')) { + return; + } + if (null !== event.originalEvent.target.closest('.frm-merge-fields-into-row')) { + return; + } + if (event.originalEvent.target.classList.contains('frm-custom-field-group-layout')) { + return; + } + if (event.originalEvent.target.classList.contains('frm-cancel-custom-field-group-layout')) { + return; + } + } + jQuery('.frm-selected-field-group').removeClass('frm-selected-field-group'); + jQuery(document).off('click', unselectFieldGroups); + maybeRemoveMultiselectPopup(); + } + function maybeRemoveMultiselectPopup() { + var popup = document.getElementById('frm_field_multiselect_popup'); + if (popup) { + popup.remove(); + } + } + function addFieldMultiselectPopup() { + getFieldMultiselectPopup(); + } + function getFieldMultiselectPopup() { + var popup = document.getElementById('frm_field_multiselect_popup'); + if (popup) { + popup.classList.toggle('frm-unmergable', !selectedFieldsAreMergeable()); + return popup; + } + popup = div(); + popup.id = 'frm_field_multiselect_popup'; + if (!selectedFieldsAreMergeable()) { + popup.classList.add('frm-unmergable'); + } + var mergeOption = div(); + mergeOption.classList.add('frm-merge-fields-into-row'); + mergeOption.textContent = __('Merge into row', 'formidable'); + var caret = document.createElement('a'); + caret.style.marginLeft = '5px'; + caret.classList.add('frm_icon_font', 'frm_arrowdown6_icon'); + caret.setAttribute('href', '#'); + mergeOption.append(caret); + popup.append(mergeOption); + var verticalSeparator = div(); + verticalSeparator.classList.add('frm-multiselect-popup-separator'); + popup.append(verticalSeparator); + var deleteOption = div(); + deleteOption.classList.add('frm-delete-field-groups'); + deleteOption.append(getIconClone('frm_trash_svg')); + popup.append(deleteOption); + document.getElementById('post-body-content').append(popup); + jQuery(popup).hide().fadeIn(); + return popup; + } + function selectedFieldsAreMergeable() { + var selectedFieldGroups = document.querySelectorAll('.frm-selected-field-group'); + var length = selectedFieldGroups.length; + if (1 === length) { + return false; + } + var totalFieldCount = 0; + for (var index = 0; index < length; ++index) { + var fieldGroup = selectedFieldGroups[index]; + if (null !== fieldGroup.querySelector('.edit_field_type_break, .edit_field_type_hidden')) { + return false; + } + totalFieldCount += getFieldsInRow(jQuery(fieldGroup)).length; + if (totalFieldCount > MAX_FIELD_GROUP_SIZE) { + return false; + } + } + return true; + } + function mergeFieldsIntoRowClick(event) { + if (null !== event.originalEvent.target.closest('#frm_field_group_popup')) { + // prevent clicks within the popup from triggering the button again. + return; + } + if (event.originalEvent.target.classList.contains('frm-custom-field-group-layout')) { + // avoid switching back to the first page when clicking the custom option nested inside of the merge option. + return; + } + var size = getSelectedFieldCount(); + var popup = getFieldGroupPopup(size, document.querySelector('.frm-selected-field-group').firstChild); + this.append(popup); + } + function getSelectedFieldCount() { + var count = 0; + jQuery(document.querySelectorAll('.frm-selected-field-group')).each(function () { + count += getFieldsInRow(jQuery(this)).length; + }); + return count; + } + function deleteFieldGroupsClick() { + var fieldIdsToDelete = getSelectedFieldIds(); + var deleteOnConfirm = getDeleteSelectedFieldGroupsOnConfirmFunction(fieldIdsToDelete); + var multiselectPopup = document.getElementById('frm_field_multiselect_popup'); + if (multiselectPopup) { + multiselectPopup.remove(); + } + this.setAttribute('data-frmverify', confirmFieldsDeleteMessage(fieldIdsToDelete.length)); + confirmLinkClick(this); + var confirmedClick = document.getElementById('frm-confirmed-click'); + + // Remove any previous delete field data so delete confirmation does not attempt + // to delete a field that was already deleted or previously attempted and cancelled. + confirmedClick === null || confirmedClick === void 0 || confirmedClick.removeAttribute('data-deletefield'); + jQuery(confirmedClick).on('click', deleteOnConfirm); + jQuery('#frm_confirm_modal').one('dialogclose', function () { + jQuery(confirmedClick).off('click', deleteOnConfirm); + }); + } + function getSelectedFieldIds() { + var deleteFieldIds = []; + jQuery('.frm-selected-field-group > li.form-field').each(function () { + deleteFieldIds.push(this.dataset.fid); + }); + return deleteFieldIds; + } + function getDeleteSelectedFieldGroupsOnConfirmFunction(deleteFieldIds) { + return function (event) { + event.preventDefault(); + deleteAllSelectedFieldGroups(deleteFieldIds); + }; + } + function deleteAllSelectedFieldGroups(deleteFieldIds) { + deleteFieldIds.forEach(function (fieldId) { + deleteFields(fieldId); + }); + } + function deleteFieldConfirmed() { + /*jshint validthis:true */ + deleteFields(this.getAttribute('data-deletefield')); + } + function deleteFields(fieldId) { + var field = jQuery("#frm_field_id_".concat(fieldId)); + deleteField(fieldId); + if (field.hasClass('edit_field_type_divider')) { + field.find('li.frm_field_box[data-fid]').each(function () { + deleteField(this.getAttribute('data-fid')); + }); + } + toggleSectionHolder(); + } + + /** + * Checks if there is only submit field in the form builder. + * + * @return {boolean} True if only the submit field exists. + */ + function hasOnlySubmitField() { + // If there are at least 2 rows, return false. + if ($newFields.get(0).childElementCount > 1) { + return false; + } + var childUl = $newFields.get(0).firstElementChild.firstElementChild; + + // Use query instead of children because there might be a div inside this ul. + var childLi = childUl.querySelectorAll('li.frm_field_box'); + + // If there are at least 2 items in the row, return false. + if (childLi.length > 1) { + return false; + } + return childLi[0].classList.contains('edit_field_type_submit'); + } + + /** + * Moves open modals out of the field options form. + * + * When a modal is open, it is moved in the DOM and appended to the parent element of the modal trigger input. That + * creates a problem since deleting the field also deletes the modal and this function fixes that problem. + * + * @since 6.22 + * + * @param {Object} settings + * @return {void} + */ + function moveOpenModalsOutOfFieldOptions(settings) { + var openModals = settings[0].querySelectorAll('.frm-inline-modal[data-fills]'); + if (!openModals.length) { + return; + } + openModals.forEach(function (modal) { + modal.classList.add('frm_hidden'); + modal.removeAttribute('data-fills'); + modal.closest('form').append(modal); + }); + } + function deleteField(fieldId) { + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_delete_field', + field_id: fieldId, + nonce: frmGlobal.nonce + }, + success: function success() { + var $thisField = jQuery(document.getElementById("frm_field_id_".concat(fieldId))); + var settings = jQuery("#frm-single-settings-".concat(fieldId)); + + // Remove settings from sidebar. + if (settings.is(':visible')) { + var _document$querySelect2; + (_document$querySelect2 = document.querySelector('.frm-settings-panel .frm-tabs-navs ul > li:first-child')) === null || _document$querySelect2 === void 0 || _document$querySelect2.click(); + document.querySelector('#frm-options-panel .frm-single-settings').classList.remove('frm_hidden'); + } + moveOpenModalsOutOfFieldOptions(settings); + settings.remove(); + $thisField.fadeOut('slow', function () { + var $section = $thisField.closest('.start_divider'); + var type = $thisField.data('type'); + var $adjacentFields = $thisField.siblings('li.form-field'); + var $liWrapper; + if (!$adjacentFields.length) { + if ($thisField.is('.edit_field_type_end_divider')) { + $adjacentFields.length = $thisField.closest('li.form-field').siblings(); + } else { + $liWrapper = $thisField.closest('ul.frm_sorting').parent(); + } + } + $thisField.remove(); + if (type === 'break') { + renumberPageBreaks(); + } else if (type === 'product') { + maybeHideQuantityProductFieldOption(); + // a product field attached to a quantity field earlier might be the one deleted, so re-populate + popAllProductFields(); + } + if ($adjacentFields.length) { + syncLayoutClasses($adjacentFields.first()); + } else { + $liWrapper.remove(); + } + if (jQuery('#frm-show-fields li').length === 0 || hasOnlySubmitField()) { + var formEditorContainer = document.getElementById('frm_form_editor_container'); + formEditorContainer.classList.remove('frm-has-fields'); + formEditorContainer.classList.add('frm-empty-fields'); + } else if ($section.length) { + toggleOneSectionHolder($section); + } + + // prevent "More Options" tooltips from staying around after their target field is deleted. + deleteTooltips(); + }); + if ($thisField.length) { + maybeEnableFieldButtonAtLimit($thisField.data('type')); + wp.hooks.doAction('frm_after_delete_field', $thisField[0]); + } + } + }); + } + + /** + * @since 6.27 + * + * @param {string} type + * @return {void} + */ + function maybeEnableFieldButtonAtLimit(type) { + var button = document.getElementById(type); + if (!button || !button.dataset.limit) { + return; + } + + // Subtract one because the field has not really been removed from the page yet. + var fieldTypeCount = countFieldTypeInForm(type) - 1; + if (fieldTypeCount < button.dataset.limit) { + button.classList.remove('frm_at_limit'); + } + } + function countFieldTypeInForm(type) { + return document.getElementById('frm-show-fields').querySelectorAll("li.form-field[data-ftype=\"".concat(type, "\"]")).length; + } + function addFieldLogicRow() { + /*jshint validthis:true */ + var id = jQuery(this).closest('.frm-single-settings').data('fid'); + var formId = thisFormId; + var logicRows = document.getElementById("frm_logic_row_".concat(id)).querySelectorAll('.frm_logic_row'); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_add_logic_row', + form_id: formId, + field_id: id, + nonce: frmGlobal.nonce, + meta_name: getNewRowId(logicRows, "frm_logic_".concat(id, "_")), + fields: getFieldList() + }, + success: function success(html) { + jQuery(document.getElementById("logic_".concat(id))).fadeOut('fast', function () { + var logicRow = document.getElementById("frm_logic_row_".concat(id)); + logicRow.insertAdjacentHTML('beforeend', html); + var logicRowText = logicRow.querySelector('.frm_logic_row:last-child .frm-logic-rule-text'); + if (logicRowText) { + logicRowText.textContent = logicRow.dataset.ruleText; + } + var logicRows = logicRow.closest('.frm_logic_rows'); + logicRows.style.height = 'auto'; + jQuery(logicRows).fadeIn('fast'); + }); + } + }); + return false; + } + function getNewRowId(rows, replace, defaultValue) { + if (!rows.length) { + return defaultValue !== undefined ? defaultValue : 0; + } + return parseInt(rows[rows.length - 1].id.replace(replace, ''), 10) + 1; + } + function addWatchLookupRow() { + /*jshint validthis:true */ + var id = jQuery(this).closest('.frm-single-settings').data('fid'); + var formId = thisFormId; + var lookupBlockRows = document.getElementById("frm_watch_lookup_block_".concat(id)).children; + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_add_watch_lookup_row', + form_id: formId, + field_id: id, + row_key: getNewRowId(lookupBlockRows, "frm_watch_lookup_".concat(id, "_")), + nonce: frmGlobal.nonce + }, + success: function success(newRow) { + var _document$getElementB2; + var watchRowBlock = jQuery(document.getElementById("frm_watch_lookup_block_".concat(id))); + watchRowBlock.append(newRow); + watchRowBlock.fadeIn('slow'); + + // Show the "Watch Lookup Fields" label if it was hidden + (_document$getElementB2 = document.getElementById("frm_watch_lookup_label_".concat(id))) === null || _document$getElementB2 === void 0 || _document$getElementB2.classList.remove('frm-force-hidden'); + } + }); + return false; + } + function resetOptionTextDetails() { + jQuery('.frm-single-settings ul input[type="text"][name^="field_options[options_"]').filter('[data-value-on-load]').removeAttr('data-value-on-load'); + jQuery('input[type="hidden"][name^=optionmap]').remove(); + } + function optionTextAlreadyExists(input) { + var fieldId = jQuery(input).closest('.frm-single-settings').attr('data-fid'); + var optionInputs = jQuery(input).closest('ul').get(0).querySelectorAll(".field_".concat(fieldId, "_option")); + var index; + var optionInput; + for (index in optionInputs) { + if (Object.hasOwn(optionInputs, index)) { + optionInput = optionInputs[index]; + if (optionInput.id !== input.id && optionInput.value === input.value && optionInput.getAttribute('data-duplicate') !== 'true') { + return true; + } + } + } + return false; + } + function onOptionTextFocus() { + var input; + var fieldId; + if (this.getAttribute('data-value-on-load') === null) { + this.setAttribute('data-value-on-load', this.value); + fieldId = jQuery(this).closest('.frm-single-settings').attr('data-fid'); + input = document.createElement('input'); + input.value = this.value; + input.setAttribute('type', 'hidden'); + input.setAttribute('name', "optionmap[".concat(fieldId, "][").concat(this.value, "]")); + this.parentNode.append(input); + if (optionMap[fieldId] === undefined) { + optionMap[fieldId] = {}; + } + optionMap[fieldId][this.value] = input; + } + if (this.getAttribute('data-duplicate') === 'true') { + this.removeAttribute('data-duplicate'); + + // we want to use original value if actually still a duplicate + if (optionTextAlreadyExists(this)) { + this.setAttribute('data-value-on-focus', this.getAttribute('data-value-on-load')); + return; + } + } + if ('' !== this.value || frmAdminJs.new_option !== this.getAttribute('data-value-on-focus')) { + this.setAttribute('data-value-on-focus', this.value); + } + } + + /** + * Returns an object that has the old and new values and labels, when a field choice is changed. + * + * @param {HTMLElement} input The changed input element. + * @return {Object} Object with oldValue, oldLabel, newValue, newLabel properties. + */ + function getChoiceOldAndNewValues(input) { + var _getChoiceOldValueAnd = getChoiceOldValueAndLabel(input), + oldValue = _getChoiceOldValueAnd.oldValue, + oldLabel = _getChoiceOldValueAnd.oldLabel; + var _getChoiceNewValueAnd = getChoiceNewValueAndLabel(input), + newValue = _getChoiceNewValueAnd.newValue, + newLabel = _getChoiceNewValueAnd.newLabel; + return { + oldValue: oldValue, + oldLabel: oldLabel, + newValue: newValue, + newLabel: newLabel + }; + } + + /** + * Returns an object that has the new value and label, when a field choice is changed. + * + * @param {HTMLElement} choiceElement The changed choice element. + * @return {Object} Object with newValue and newLabel properties. + */ + function getChoiceNewValueAndLabel(choiceElement) { + var singleOptionContainer = choiceElement.closest('.frm_single_option'); + var newValue; + var newLabel; + if (choiceElement.parentElement.classList.contains('frm_single_option')) { + // label changed + newValue = singleOptionContainer.querySelector('.frm_option_key input[type="text"]').value; + newLabel = choiceElement.value; + return { + newValue: newValue, + newLabel: newLabel + }; + } + + // saved value changed + newLabel = singleOptionContainer.querySelector('input[type="text"]').value; + newValue = choiceElement.value; + return { + newValue: newValue, + newLabel: newLabel + }; + } + + /** + * Returns an object that has the old value and label, when a field choice is changed. + * + * @param {HTMLElement} choiceElement The changed choice element. + * @return {Object} Object with oldValue and oldLabel properties. + */ + function getChoiceOldValueAndLabel(choiceElement) { + var _choiceElement$closes, _choiceElement$closes2; + var usingSeparateValues = (_choiceElement$closes = (_choiceElement$closes2 = choiceElement.closest('.frm-single-settings').querySelector('.frm_toggle_sep_values')) === null || _choiceElement$closes2 === void 0 ? void 0 : _choiceElement$closes2.checked) !== null && _choiceElement$closes !== void 0 ? _choiceElement$closes : false; + var singleOptionContainer = choiceElement.closest('.frm_single_option'); + var oldValue; + var oldLabel; + if (usingSeparateValues) { + if (choiceElement.parentElement.classList.contains('frm_single_option')) { + // label changed + oldValue = singleOptionContainer.querySelector('.frm_option_key input[type="text"]').getAttribute('data-value-on-focus'); + oldLabel = choiceElement.getAttribute('data-value-on-focus'); + return { + oldValue: oldValue, + oldLabel: oldLabel + }; + } + } + oldValue = choiceElement.getAttribute('data-value-on-focus'); + oldLabel = singleOptionContainer.querySelector('input[type="text"]').getAttribute('data-value-on-focus'); + return { + oldValue: oldValue, + oldLabel: oldLabel + }; + } + function onOptionTextBlur() { + var fieldIndex; + var settingId; + var setting; + var _getChoiceOldAndNewVa = getChoiceOldAndNewValues(this), + oldValue = _getChoiceOldAndNewVa.oldValue, + oldLabel = _getChoiceOldAndNewVa.oldLabel, + newValue = _getChoiceOldAndNewVa.newValue, + newLabel = _getChoiceOldAndNewVa.newLabel; + if (oldValue === newValue && oldLabel === newLabel) { + return; + } + var singleSettingsContainer = this.closest('.frm-single-settings'); + var fieldId = singleSettingsContainer.getAttribute('data-fid'); + var originalValue = this.getAttribute('data-value-on-load'); + + // check if the newValue is already mapped to another option + // if it is, mark as duplicate and return + if (optionTextAlreadyExists(this)) { + this.setAttribute('data-duplicate', 'true'); + if (optionMap[fieldId] !== undefined && optionMap[fieldId][originalValue] !== undefined) { + // unmap any other change that may have happened before instead of changing it to something unused + optionMap[fieldId][originalValue].value = originalValue; + } + return; + } + if (optionMap[fieldId] !== undefined && optionMap[fieldId][originalValue] !== undefined) { + optionMap[fieldId][originalValue].value = newValue; + } + var fieldIds = []; + var rows = builderPage.querySelectorAll('.frm_logic_row'); + var rowLength = rows.length; + for (var rowIndex = 0; rowIndex < rowLength; rowIndex++) { + var row = rows[rowIndex]; + var opts = row.querySelector('.frm_logic_field_opts'); + if (opts.value !== fieldId) { + continue; + } + var logicId = row.id.split('_')[2]; + var valueSelect = row.querySelector("select[name=\"field_options[hide_opt_".concat(logicId, "][]\"]")); + var optionMatches = void 0; + if ('' === oldValue) { + optionMatches = []; + } else { + optionMatches = valueSelect.querySelectorAll("option[value=\"".concat(oldValue, "\"]")); + } + var option = void 0; + if (!optionMatches.length) { + optionMatches = valueSelect.querySelectorAll("option[value=\"".concat(newValue, "\"]")); + if (!optionMatches.length) { + var _singleSettingsContai; + if (!((_singleSettingsContai = singleSettingsContainer.querySelector('.frm_toggle_sep_values')) !== null && _singleSettingsContai !== void 0 && _singleSettingsContai.checked)) { + option = searchSelectByText(valueSelect, oldValue); // Find conditional logic option with oldValue + } + if (!option) { + option = document.createElement('option'); + valueSelect.append(option); + } + } + } + if (optionMatches.length) { + option = optionMatches[optionMatches.length - 1]; + } + option.setAttribute('value', newValue); + option.textContent = newLabel; + if (!fieldIds.includes(logicId)) { + fieldIds.push(logicId); + } + } + for (fieldIndex in fieldIds) { + if (Object.hasOwn(fieldIds, fieldIndex)) { + settingId = fieldIds[fieldIndex]; + setting = document.getElementById("frm-single-settings-".concat(settingId)); + moveFieldSettings(setting); + } + } + } + + /** + * Returns an option element that matches a string with its text content. + * + * @param {HTMLElement} selectElement The select element to search. + * @param {string} searchText The text to search for. + * @return {HTMLElement|null} Matching option element or null. + */ + function searchSelectByText(selectElement, searchText) { + var options = selectElement.options; + for (var i = 0; i < options.length; i++) { + var option = options[i]; + if (searchText === option.textContent) { + return option; + } + } + return null; + } + function updateGetValueFieldSelection() { + /*jshint validthis:true */ + var fieldID = this.id.replace('get_values_form_', ''); + var fieldSelect = document.getElementById("get_values_field_".concat(fieldID)); + var fieldType = this.getAttribute('data-fieldtype'); + if (this.value === '') { + fieldSelect.options.length = 1; + } else { + var formID = this.value; + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_get_options_for_get_values_field', + form_id: formID, + field_type: fieldType, + nonce: frmGlobal.nonce + }, + success: function success(fields) { + fieldSelect.innerHTML = fields; + } + }); + } + } + + // Clear the Watch Fields option when Lookup field switches to "Text" option + function maybeClearWatchFields() { + /*jshint validthis:true */ + var link; + var lookupBlock; + var fieldID = this.name.replace('field_options[data_type_', '').replace(']', ''); + link = document.getElementById("frm_add_watch_lookup_link_".concat(fieldID)); + if (!link) { + return; + } + link = link.parentNode; + if (this.value === 'text') { + lookupBlock = document.getElementById("frm_watch_lookup_block_".concat(fieldID)); + if (lookupBlock) { + // Clear and hide the Watch Fields option + lookupBlock.innerHTML = ''; + link.classList.add('frm_hidden'); + + // Hide the Watch Fields row + link.previousElementSibling.style.display = 'none'; + link.previousElementSibling.previousElementSibling.style.display = 'none'; + link.previousElementSibling.previousElementSibling.previousElementSibling.style.display = 'none'; + } + } else { + // Show the Watch Fields option + link.classList.remove('frm_hidden'); + } + toggleMultiSelect(fieldID, this.value); + } + + // Number the pages and hide/show the first page as needed. + function renumberPageBreaks() { + var i; + var containerClass; + var pages = document.getElementsByClassName('frm-page-num'); + if (pages.length > 1) { + document.getElementById('frm-fake-page').style.display = 'block'; + for (i = 0; i < pages.length; i++) { + containerClass = pages[i].parentNode.parentNode.parentNode.classList; + if (i === 1) { + // Hide previous button on page 1 + containerClass.add('frm-first-page'); + } else { + containerClass.remove('frm-first-page'); + } + pages[i].textContent = i + 1; + } + } else { + document.getElementById('frm-fake-page').style.display = 'none'; + } + wp.hooks.doAction('frm_renumber_page_breaks', pages); + } + + // The fake field works differently than real fields. + function maybeCollapsePage() { + /*jshint validthis:true */ + var field = jQuery(this).closest('.frm_field_box[data-ftype=break]'); + if (field.length) { + toggleCollapsePage(field); + } else { + toggleCollapseFakePage(); + } + } + + // Find all fields in a page and hide/show them + function toggleCollapsePage(field) { + var toCollapse = getAllFieldsForPage(field.get(0).parentNode.closest('li.frm_field_box').nextElementSibling); + togglePage(field, toCollapse); + } + function toggleCollapseFakePage() { + var topLevel = document.getElementById('frm-fake-page'); + var firstField = document.getElementById('frm-show-fields').firstElementChild; + var toCollapse = getAllFieldsForPage(firstField); + if (firstField.getAttribute('data-ftype') === 'break') { + // Don't collapse if the first field is a page break. + return; + } + togglePage(jQuery(topLevel), toCollapse); + } + function getAllFieldsForPage(firstWrapper) { + var $fieldsForPage; + var currentWrapper; + $fieldsForPage = jQuery(); + if (null === firstWrapper) { + return $fieldsForPage; + } + currentWrapper = firstWrapper; + do { + if (null !== currentWrapper.querySelector('.edit_field_type_break')) { + break; + } + $fieldsForPage = $fieldsForPage.add(jQuery(currentWrapper)); + currentWrapper = currentWrapper.nextElementSibling; + } while (null !== currentWrapper); + return $fieldsForPage; + } + function togglePage(field, toCollapse) { + var i; + var fieldCount = toCollapse.length; + var slide = Math.min(fieldCount, 3); + if (field.hasClass('frm-page-collapsed')) { + field.removeClass('frm-page-collapsed'); + toCollapse.removeClass('frm-is-collapsed'); + for (i = 0; i < slide; i++) { + if (i === slide - 1) { + jQuery(toCollapse[i]).slideDown(150, function () { + toCollapse.show(); + }); + } else { + jQuery(toCollapse[i]).slideDown(150); + } + } + } else { + field.addClass('frm-page-collapsed'); + toCollapse.addClass('frm-is-collapsed'); + for (i = 0; i < slide; i++) { + if (i === slide - 1) { + jQuery(toCollapse[i]).slideUp(150, function () { + toCollapse.css('cssText', 'display:none !important;'); + }); + } else { + jQuery(toCollapse[i]).slideUp(150); + } + } + } + } + function maybeCollapseSection() { + /*jshint validthis:true */ + var parentCont = this.parentNode.parentNode.parentNode.parentNode; + parentCont.classList.toggle('frm-section-collapsed'); + } + function maybeCollapseSettings() { + /*jshint validthis:true */ + + // Restore animation that may have been disabled by showFieldOptions. + if (this.nextElementSibling) { + this.nextElementSibling.style.animation = ''; + } + this.classList.toggle('frm-collapsed'); + + // Toggles the "aria-expanded" attribute + var expanded = this.getAttribute('aria-expanded') === 'true' || false; + this.setAttribute('aria-expanded', !expanded); + addSlideAnimationCssVars(this.nextElementSibling); + } + + /** + * Add slide animation CSS variables to the element + * + * @param {HTMLElement} element The element to add CSS variables to + * @return {void} + */ + function addSlideAnimationCssVars(element) { + if (!element) { + return; + } + var height = element.scrollHeight; + if (height <= 0) { + return; + } + height += 250; + element.style.setProperty('--slide-height', "".concat(height, "px")); + element.style.setProperty('--slide-time', "".concat(Math.ceil(height * 0.8), "ms")); + } + function clickLabel() { + if (!this.id) { + return; + } + + /*jshint validthis:true */ + var setting = document.querySelectorAll("[data-changeme=\"".concat(this.id, "\"]"))[0]; + var fieldId = this.id.replace('field_label_', ''); + var fieldType = document.getElementById("field_options_type_".concat(fieldId)); + var fieldTypeName = fieldType.value; + if (setting !== undefined) { + if (fieldType.tagName === 'SELECT') { + fieldTypeName = fieldType.options[fieldType.selectedIndex].text.toLowerCase(); + } else { + fieldTypeName = fieldTypeName.replace('_', ' '); + } + fieldTypeName = normalizeFieldName(fieldTypeName); + setTimeout(function () { + if (setting.value.toLowerCase() === fieldTypeName) { + setting.select(); + } else { + setting.focus(); + } + }, 50); + } + } + function clickDescription() { + /*jshint validthis:true */ + var setting = document.querySelectorAll("[data-changeme=\"".concat(this.id, "\"]"))[0]; + if (setting !== undefined) { + setTimeout(function () { + setting.focus(); + autoExpandSettings(setting); + }, 50); + } + } + function autoExpandSettings(setting) { + var inSection = setting.closest('.frm-collapse-me'); + if (inSection !== null) { + inSection.previousElementSibling.classList.remove('frm-collapsed'); + } + } + function normalizeFieldName(fieldTypeName) { + if (fieldTypeName === 'divider') { + fieldTypeName = 'section'; + } else if (fieldTypeName === 'range') { + fieldTypeName = 'slider'; + } else if (fieldTypeName === 'data') { + fieldTypeName = 'dynamic'; + } else if (fieldTypeName === 'form') { + fieldTypeName = 'embed form'; + } + return fieldTypeName; + } + function clickVis(e) { + /*jshint validthis:true */ + var currentClass = e.target.classList; + if (currentClass.contains('frm-collapse-page') || currentClass.contains('frm-sub-label') || e.target.closest('.dropdown') !== null) { + return; + } + if (this.closest('.start_divider') !== null) { + e.stopPropagation(); + } + if (this.classList.contains('edit_field_type_divider')) { + var originalList = e.originalEvent.target.closest('ul.frm_sorting'); + if (null !== originalList) { + // prevent section click if clicking a field group within a section. + if (originalList.classList.contains('edit_field_type_divider') || originalList.parentNode.parentNode.classList.contains('start_divider')) { + return; + } + } + } + clickAction(this); + } + + /** + * Update the format input based on the selected format type. + * + * @since 6.9 + * + * @param {Event} event The event object from the format type selection. + * @return {void} + */ + function maybeUpdateFormatInput(event) { + var formatElement = event.target; + var type = formatElement.value; + if ('custom' === type) { + var fieldId = formatElement.dataset.fieldId; + var formatInput = document.getElementById("frm-field-format-custom-".concat(fieldId)).querySelector('.frm_format_opt'); + if ('international' === formatInput.value || 'currency' === formatInput.value || 'number' === formatInput.value) { + formatInput.setAttribute('value', ''); + } + } + setTimeout(function () { + formatElement.querySelectorAll('option').forEach(function (option) { + if (option.selected && option.classList.contains('frm_show_upgrade')) { + formatElement.value = 'none'; + } + }); + }, 0); + } + + /** + * Open Advanced settings on double click. + */ + function openAdvanced() { + var fieldId = this.getAttribute('data-fid'); + autoExpandSettings(document.getElementById("field_options_field_key_".concat(fieldId))); + } + function toggleRepeatButtons() { + /*jshint validthis:true */ + var $thisField = jQuery(this).closest('.frm_field_box'); + $thisField.find('.repeat_icon_links').removeClass('repeat_format repeat_formatboth repeat_formattext').addClass("repeat_format".concat(this.value)); + if (this.value === 'text' || this.value === 'both') { + $thisField.find('.frm_repeat_text').show(); + $thisField.find('.repeat_icon_links a').addClass('frm_button'); + } else { + $thisField.find('.frm_repeat_text').hide(); + $thisField.find('.repeat_icon_links a').removeClass('frm_button'); + } + } + function checkRepeatLimit() { + /*jshint validthis:true */ + var val = this.value; + if (val !== '' && (val < 2 || val > 200)) { + infoModal(frmAdminJs.repeat_limit_min); + this.value = ''; + } + } + function checkCheckboxSelectionsLimit() { + /*jshint validthis:true */ + var val = this.value; + if (val !== '' && (val < 1 || val > 200)) { + infoModal(frmAdminJs.checkbox_limit); + this.value = ''; + } + } + function updateRepeatText(obj, addRemove) { + var $thisField = jQuery(obj).closest('.frm_field_box'); + $thisField.find(".frm_".concat(addRemove, "_form_row .frm_repeat_label")).text(obj.value); + } + function fieldsInSection(id) { + var children = []; + jQuery(document.getElementById("frm_field_id_".concat(id))).find('li.frm_field_box:not(.no_repeat_section .edit_field_type_end_divider)').each(function () { + children.push(jQuery(this).data('fid')); + }); + return children; + } + function toggleFormTax() { + /*jshint validthis:true */ + var id = jQuery(this).closest('.frm-single-settings').data('fid'); + var val = this.value; + var $showFields = document.getElementById("frm_show_selected_fields_".concat(id)); + var $showForms = document.getElementById("frm_show_selected_forms_".concat(id)); + jQuery($showForms).find('select').val(''); + if (val === 'form') { + $showForms.style.display = 'inline'; + empty($showFields); + } else { + $showFields.style.display = 'none'; + $showForms.style.display = 'none'; + getTaxOrFieldSelection(val, id); + } + } + function resetOptOnChange() { + /*jshint validthis:true */ + var field = getFieldKeyFromOpt(this); + if (!field) { + return; + } + var thisOpt = jQuery(this).closest('.frm_single_option'); + resetSingleOpt(field.fieldId, field.fieldKey, thisOpt); + } + function getFieldKeyFromOpt(object) { + var allOpts = jQuery(object).closest('.frm_sortable_field_opts'); + if (!allOpts.length) { + return false; + } + var fieldId = allOpts.attr('id').replace('frm_field_', '').replace('_opts', ''); + var fieldKey = allOpts.data('key'); + return { + fieldId: fieldId, + fieldKey: fieldKey + }; + } + function resetSingleOpt(fieldId, fieldKey, thisOpt) { + var optKey = thisOpt.data('optkey'); + var separateValues = usingSeparateValues(fieldId); + var single = jQuery("label[for=\"field_".concat(fieldKey, "-").concat(optKey, "\"]")); + var baseName = "field_options[options_".concat(fieldId, "][").concat(optKey, "]"); + var label = jQuery("input[name=\"".concat(baseName, "[label]\"]")); + if (single.length < 1) { + resetDisplayedOpts(fieldId); + + // Set the default value. + var _defaultVal = thisOpt.find('input[name^="default_value_"]'); + if (_defaultVal.is(':checked') && label.length > 0) { + jQuery("select[name^=\"item_meta[".concat(fieldId, "]\"]")).val(label.val()); + } + return; + } + var previewInput = single.children('input'); + var saved; + if (label.length < 1) { + // Check for other label. + label = jQuery("input[name=\"".concat(baseName, "\"]")); + saved = label.val(); + } else if (separateValues) { + saved = jQuery("input[name=\"".concat(baseName, "[value]\"]")).val(); + } else { + saved = label.val(); + } + if (label.length < 1) { + return; + } + + // Set the displayed value. + var text = single[0].childNodes; + if (imagesAsOptions(fieldId)) { + var labelForDisplay = getImageDisplayValue(thisOpt, fieldId, label); + var optContainer = single.find('.frm_image_option_container'); + if (optContainer.length > 0) { + optContainer.replaceWith(labelForDisplay); + } else { + text[text.length - 1].nodeValue = ''; + single.append(labelForDisplay); + } + } else { + var firstInputIndex = false; + text.forEach(function (node, index) { + if (firstInputIndex === false) { + if (node.tagName === 'INPUT') { + firstInputIndex = index; + } + } else if (index === firstInputIndex + 1) { + var nodeValue = ''; + if (buttonsAsOptions(fieldId)) { + nodeValue = div({ + className: 'frm_label_button_container', + text: " ".concat(label.val()) + }); + single[0].replaceChild(nodeValue, node); + } else { + node.nodeValue = " ".concat(label.val()); + } + } else { + node.remove(); + } + }); + } + + // Set saved value. + previewInput.val(saved); + + // Set the default value. + defaultVal = thisOpt.find('input[name^="default_value_"]'); + previewInput.prop('checked', defaultVal.is(':checked') ? true : false); + } + function buttonsAsOptions(fieldId) { + var fields = document.getElementsByName("field_options[image_options_".concat(fieldId, "]")); + var result = Array.from(fields).find(function (field) { + return field.checked && 'buttons' === field.value; + }); + return result !== undefined; + } + + /** + * Set the displayed value for an image option. + * @param {HTMLElement} thisOpt The option element. + * @param {number} fieldId The field ID. + * @param {string} label The option label. + */ + function getImageDisplayValue(thisOpt, fieldId, label) { + var image = thisOpt.find('img'); + var imageUrl; + if (image) { + imageUrl = image.attr('src'); + } + var showLabelWithImage = showingLabelWithImage(fieldId); + return getImageLabel(label.val(), showLabelWithImage, imageUrl); + } + function getImageOptionSize(fieldId) { + var val; + var field = document.getElementById("field_options_image_size_".concat(fieldId)); + var size = ''; + if (field) { + val = field.value; + if (val !== '') { + size = val; + } + } + return size; + } + function resetDisplayedOpts(fieldId) { + var input = jQuery("[name^=\"item_meta[".concat(fieldId, "]\"]")); + if (input.length < 1) { + return; + } + if (input.is('select')) { + var placeholder = document.getElementById("frm_placeholder_".concat(fieldId)); + if (!placeholder || placeholder.value === '') { + fillDropdownOpts(input[0], { + sourceID: fieldId + }); + } else { + fillDropdownOpts(input[0], { + sourceID: fieldId, + placeholder: placeholder.value + }); + } + } else { + var opts = getMultipleOpts(fieldId); + jQuery("#field_".concat(fieldId, "_inner_container > .frm_form_fields")).html(''); + var fieldInfo = getFieldKeyFromOpt(jQuery("#frm_delete_field_".concat(fieldId, "-000_container"))); + var container = jQuery("#field_".concat(fieldId, "_inner_container > .frm_form_fields")); + var hasImageOptions = imagesAsOptions(fieldId); + var imageSize = hasImageOptions ? getImageOptionSize(fieldId) : ''; + var imageOptionClass = hasImageOptions ? "frm_image_option frm_image_".concat(imageSize, " ") : ''; + var isProduct = isProductField(fieldId); + var type = 'hidden' === input.attr('type') ? input.data('field-type') : input.attr('type'); + for (var i = 0; i < opts.length; i++) { + container.append(addRadioCheckboxOpt(type, opts[i], fieldId, fieldInfo.fieldKey, isProduct, imageOptionClass)); + } + } + adjustConditionalLogicOptionOrders(fieldId); + } + + /** + * Returns an object that has a value and label for new conditional logic option, for a given option value. + * + * @param {number} fieldId + * @param {string} expectedOption The expected option value. + * @return {Object} Object with value and label for the new option. + */ + function getNewConditionalLogicOption(fieldId, expectedOption) { + var optionsContainer = document.getElementById("frm_field_".concat(fieldId, "_opts")); + var expectedOptionInput = optionsContainer.querySelector("input[value=\"".concat(expectedOption, "\"]")); + if (expectedOptionInput) { + return getChoiceNewValueAndLabel(expectedOptionInput); + } + return { + newValue: expectedOption, + newLabel: expectedOption + }; + } + function adjustConditionalLogicOptionOrders(fieldId, type) { + var rows = builderPage.querySelectorAll('.frm_logic_row'); + var rowLength = rows.length; + var fieldOptions = wp.hooks.applyFilters('frm_conditional_logic_field_options', getFieldOptions(fieldId), { + type: type, + fieldId: fieldId + }); + var optionLength = fieldOptions.length; + for (var rowIndex = 0; rowIndex < rowLength; rowIndex++) { + var row = rows[rowIndex]; + var opts = row.querySelector('.frm_logic_field_opts'); + if (opts.value != fieldId) { + continue; + } + var logicId = row.id.split('_')[2]; + var valueSelect = row.querySelector("select[name=\"field_options[hide_opt_".concat(logicId, "][]\"]")); + var _loop = function _loop() { + var _document$getElementB3; + var expectedOption = fieldOptions[optionIndex]; + var expectedOptionValue = (_document$getElementB3 = document.getElementById("frm_field_".concat(fieldId, "_opts")).querySelector('.frm_option_key input[type="text"]')) === null || _document$getElementB3 === void 0 ? void 0 : _document$getElementB3.value; + if (!expectedOptionValue) { + expectedOptionValue = expectedOption; + } + var optionMatch = valueSelect.querySelector("option[value=\"".concat(expectedOptionValue, "\"]")); + var _getNewConditionalLog = getNewConditionalLogicOption(fieldId, expectedOption), + newValue = _getNewConditionalLog.newValue, + newLabel = _getNewConditionalLog.newLabel; + var fieldChoices = document.querySelectorAll("#frm_field_".concat(fieldId, "_opts input[data-value-on-focus]")); + var expectedChoiceEl = Array.from(fieldChoices).find(function (element) { + return element.value === expectedOption; + }); + if (expectedChoiceEl) { + var oldValue = expectedChoiceEl.dataset.valueOnFocus; + var hasMatch = oldValue && valueSelect.querySelector("option[value=\"".concat(oldValue, "\"]")); + if (hasMatch) { + return 1; // continue + } + } + prependValueSelectWithOptionMatch(valueSelect, optionMatch, newValue, newLabel); + }; + for (var optionIndex = optionLength - 1; optionIndex >= 0; optionIndex--) { + if (_loop()) continue; + } + var optionMatch = valueSelect.querySelector('option[value=""]'); + if (optionMatch !== null) { + valueSelect.prepend(optionMatch); + } + } + } + function prependValueSelectWithOptionMatch(valueSelect, optionMatch, newValue, newLabel) { + if (optionMatch === null && !valueSelect.querySelector("option[value=\"".concat(newValue, "\"]"))) { + optionMatch = frmDom.tag('option', { + text: newLabel + }); + optionMatch.value = newValue; + } + valueSelect.prepend(optionMatch); + } + function getFieldOptions(fieldId) { + var options = []; + var optsContainer = document.getElementById("frm_field_".concat(fieldId, "_opts")); + if (!optsContainer) { + return options; + } + var listItems = optsContainer.querySelectorAll('.frm_single_option'); + var length = listItems.length; + for (var index = 0; index < length; index++) { + var li = listItems[index]; + if (li.classList.contains('frm_hidden')) { + continue; + } + var input = li.querySelector(".field_".concat(fieldId, "_option")); + options.push(input.value); + } + return options; + } + function addRadioCheckboxOpt(type, opt, fieldId, fieldKey, isProduct, classes) { + var single = ''; + var isOther = opt.key.includes('other'); + var id = "field_".concat(fieldKey, "-").concat(opt.key); + var inputType = type === 'scale' ? 'radio' : type; + var other = ""); + this.getSingle = function () { + /** + * Get single option template. + * + * @param {Object} option Object containing the option data. + * @param {string} type The field type. + * @param {string} fieldId The field id. + * @param {string} classes The option clasnames. + * @param {string} id The input id attribute. + */ + single = wp.hooks.applyFilters('frm_admin.build_single_option_template', single, { + opt: opt, + type: type, + fieldId: fieldId, + classes: classes, + id: id + }); + if ('' !== single) { + return single; + } + return "
        \n\t\t\t\t\t\n\t\t\t\t\t").concat(isOther ? other : '', "\n\t\t\t\t
        "); + }; + return this.getSingle(); + } + function fillDropdownOpts(field, atts) { + if (!field) { + return; + } + var sourceID = atts.sourceID; + var placeholder = atts.placeholder; + var isProduct = isProductField(sourceID); + var showOther = atts.other; + removeDropdownOpts(field); + var opts = getMultipleOpts(sourceID, field.id.includes('frm_field_logic_opt')); + var hasPlaceholder = placeholder !== undefined; + for (var i = 0; i < opts.length; i++) { + var label = opts[i].label; + var isOther = opts[i].key.includes('other'); + if (hasPlaceholder && label !== '') { + addBlankSelectOption(field, placeholder); + } else if (hasPlaceholder) { + label = placeholder; + } + hasPlaceholder = false; + if (!isOther || showOther) { + var opt = document.createElement('option'); + opt.value = opts[i].saved; + opt.innerHTML = purifyHtml(label); + if (isProduct) { + opt.setAttribute('data-price', opts[i].price); + } + field.append(opt); + } + } + } + function addBlankSelectOption(field, placeholder) { + var opt = document.createElement('option'); + var firstChild = field.firstChild; + opt.value = ''; + opt.innerHTML = placeholder; + if (firstChild !== null) { + firstChild.before(opt); + field.selectedIndex = 0; + } else { + field.append(opt); + } + } + + /** + * Get multiple options for a field. + * + * @param {string} fieldId The field id. + * @param {boolean} showValueAsLabel Whether to show the value as label for empty labels. + */ + function getMultipleOpts(fieldId) { + var showValueAsLabel = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; + var i; + var saved; + var labelName; + var label; + var key; + var optObj; + var checked = false; + var opts = []; + var imageUrl = ''; + var optVals = jQuery("input[name^=\"field_options[options_".concat(fieldId, "]\"]")).filter('[name$="[label]"], [name*="[other_"]'); + var isProduct = isProductField(fieldId); + var showLabelWithImage = showingLabelWithImage(fieldId); + var hasImageOptions = imagesAsOptions(fieldId); + var separateValues = usingSeparateValues(fieldId); + for (i = 0; i < optVals.length; i++) { + if (optVals[i].name.indexOf('[000]') > 0) { + continue; + } + saved = optVals[i].value; + label = saved; + key = optVals[i].name.replace("field_options[options_".concat(fieldId, "]["), '').replace('[label]', '').replace(']', ''); + if (separateValues) { + labelName = optVals[i].name.replace('[label]', '[value]'); + saved = jQuery("input[name=\"".concat(labelName, "\"]")).val(); + if (showValueAsLabel && '' === label) { + label = '' !== saved ? saved : frm_admin_js.no_label; + } + } + if (hasImageOptions) { + imageUrl = getImageUrlFromInput(optVals[i]); + label = getImageLabel(label, showLabelWithImage, imageUrl); + } + + /** + * @since 5.0.04 + */ + label = frmAdminBuild.hooks.applyFilters('frm_choice_field_label', label, fieldId, optVals[i], hasImageOptions); + checked = getChecked(optVals[i].id); + optObj = { + saved: saved, + label: label, + checked: checked, + key: key + }; + if (isProduct) { + labelName = optVals[i].name.replace('[label]', '[price]'); + optObj.price = jQuery("input[name=\"".concat(labelName, "\"]")).val(); + } + opts.push(optObj); + } + return opts; + } + function getImageUrlFromInput(optVal) { + var wrapper = jQuery(optVal).siblings('.frm_image_preview_wrapper'); + if (!wrapper.length) { + return ''; + } + var img = wrapper.find('img'); + if (!img.length) { + return ''; + } + return img.attr('src'); + } + function purifyHtml(html) { + if (html instanceof Element || html instanceof Document) { + html = html.outerHTML; + } + var clean = jQuery.parseHTML(html).reduce(function (total, currentNode) { + var cleanNode = frmDom.cleanNode(currentNode); + if ('#text' === cleanNode.nodeName) { + return total + cleanNode.textContent; + } + return total + cleanNode.outerHTML; + }, ''); + if (clean !== html) { + // Clean it until nothing changes, in case the stripped result is now unsafe. + return purifyHtml(clean); + } + return clean; + } + function getImageLabel(label, showLabelWithImage, imageUrl) { + var originalLabel = label; + originalLabel = purifyHtml(originalLabel); + var labelImage; + if (imageUrl) { + labelImage = img({ + src: imageUrl, + alt: originalLabel + }); + } else { + labelImage = div({ + className: 'frm_empty_url' + }); + labelImage.innerHTML = frmAdminJs.image_placeholder_icon; + } + var imageLabelClass = showLabelWithImage ? ' frm_label_with_image' : ''; + var imageLabel = tag('span', { + className: 'frm_text_label_for_image_inner' + }); + imageLabel.innerHTML = originalLabel; + var labelNode = tag('span', { + className: "frm_image_option_container".concat(imageLabelClass), + children: [labelImage, tag('span', { + className: 'frm_text_label_for_image', + child: imageLabel + })] + }); + return labelNode; + } + function getChecked(id) { + var field = jQuery("#".concat(id)); + if (field.length === 0) { + return false; + } + var checkbox = field.siblings('input[type=checkbox]'); + return checkbox.length && checkbox.prop('checked'); + } + function removeDropdownOpts(field) { + var i; + if (field.options === undefined) { + return; + } + for (i = field.options.length - 1; i >= 0; i--) { + field.remove(i); + } + } + + /** + * Is the box checked to use separate values? + * @param {number} fieldId The field ID. + */ + function usingSeparateValues(fieldId) { + return isChecked("separate_value_".concat(fieldId)); + } + + /** + * Is the box checked to use images as options? + * @param {number} fieldId The field ID. + */ + function imagesAsOptions(fieldId) { + var checked = false; + var field = document.getElementsByName("field_options[image_options_".concat(fieldId, "]")); + for (var i = 0; i < field.length; i++) { + if (field[i].checked) { + checked = '0' !== field[i].value; + } + } + + /** + * @since 5.0.04 + */ + return frmAdminBuild.hooks.applyFilters('frm_choice_field_images_as_options', checked, fieldId); + } + function showingLabelWithImage(fieldId) { + var isShowing = !isChecked("hide_image_text_".concat(fieldId)); + + /** + * @since 5.0.04 + */ + return frmAdminBuild.hooks.applyFilters('frm_choice_field_showing_label_with_image', isShowing, fieldId); + } + function isChecked(id) { + var field = document.getElementById(id); + if (!field) { + return false; + } + return field.checked; + } + function checkUniqueOpt(targetInput) { + var settingsContainer = targetInput.closest('.frm-single-settings'); + var fieldId = settingsContainer.getAttribute('data-fid'); + var areValuesSeparate = settingsContainer.querySelector("[name=\"field_options[separate_value_".concat(fieldId, "]\"]")).checked; + if (areValuesSeparate && !targetInput.name.endsWith('[value]')) { + return; + } + var container = document.getElementById("frm_field_".concat(fieldId, "_opts")); + var conflicts = Array.from(container.querySelectorAll('input[type="text"]')).filter(function (input) { + return input.id !== targetInput.id && areValuesSeparate === input.name.endsWith('[value]') && input.value === targetInput.value; + }); + if (conflicts.length) { + /* translators: %s: The detected option value. */ + infoModal(sprintf(__('Duplicate option value "%s" detected', 'formidable'), purifyHtml(targetInput.value))); + } + } + function getFieldValues() { + /*jshint validthis:true */ + var isTaxonomy; + var val = this.value; + if (val) { + var parentIDs = this.parentNode.id.replace('frm_logic_', '').split('_'); + var fieldID = parentIDs[0]; + var metaKey = parentIDs[1]; + var valueField = document.getElementById("frm_field_id_".concat(val)); + var valueFieldType = valueField.getAttribute('data-ftype'); + var fill = document.getElementById("frm_show_selected_values_".concat(fieldID, "_").concat(metaKey)); + var optionName = "field_options[hide_opt_".concat(fieldID, "][]"); + var optionID = "frm_field_logic_opt_".concat(fieldID); + var input = false; + var showSelect = valueFieldType === 'select' || valueFieldType === 'checkbox' || valueFieldType === 'radio'; + var showText = valueFieldType === 'text' || valueFieldType === 'email' || valueFieldType === 'phone' || valueFieldType === 'url' || valueFieldType === 'number'; + if (showSelect) { + isTaxonomy = document.getElementById("frm_has_hidden_options_".concat(val)); + if (isTaxonomy) { + // get the category options with ajax + showSelect = false; + } + } + if (showSelect || showText) { + var comparison = document.querySelector("#frm_logic_".concat(fieldID, "_").concat(metaKey, " [name=\"field_options[hide_field_cond_").concat(fieldID, "][]\"]")).value; + fill.innerHTML = ''; + var creatingValuesDropdown = showSelect && !['LIKE', 'not LIKE', 'LIKE%', '%LIKE'].includes(comparison); + if (creatingValuesDropdown) { + input = document.createElement('select'); + } else { + input = document.createElement('input'); + input.type = 'text'; + } + input.name = optionName; + input.id = "".concat(optionID, "_").concat(metaKey); + fill.append(input); + if (creatingValuesDropdown) { + var fillField = document.getElementById(input.id); + fillDropdownOpts(fillField, { + sourceID: val, + placeholder: '', + other: true + }); + } + } else { + var thisType = this.getAttribute('data-type'); + var callback = function callback() { + var event = new CustomEvent('frm_logic_options_loaded'); + event.frmData = { + valueFieldType: valueFieldType, + fieldID: fieldID, + metaKey: metaKey + }; + document.dispatchEvent(event); + }; + frmGetFieldValues(val, fieldID, metaKey, thisType, undefined, callback); + } + } + } + function getFieldSelection() { + /*jshint validthis:true */ + var formId = this.value; + if (formId) { + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + getTaxOrFieldSelection(formId, fieldId); + } + } + function getTaxOrFieldSelection(formId, fieldId) { + if (formId) { + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_get_field_selection', + field_id: fieldId, + form_id: formId, + nonce: frmGlobal.nonce + }, + success: function success(msg) { + var $selectedFields = jQuery("#frm_show_selected_fields_".concat(fieldId)); + $selectedFields.toggleClass('frm6', !msg.includes('frm-inline-message')); + $selectedFields.html(msg).show(); + } + }); + } + } + function updateFieldOrder() { + var self = this; + this.initOnceInAllInstances = function () { + if (updateFieldOrder.prototype.orderFieldsObject !== undefined) { + return; + } + + // It will store the order input fields ( input[name="field_options[field_order_{fieldId}]"] ). + // It will help to reduce the DOM searches based on fieldId. + // The same object data is used across all "updateFieldOrder" instances. + updateFieldOrder.prototype.orderFieldsObject = {}; + + // Get the Form group that will handle the fields settings. + // Perform a single DOM search and use it across all "updateFieldOrder" instances. + updateFieldOrder.prototype.fieldSettingsForm = document.getElementById('frm-end-form-marker').closest('form'); + }; + this.getFieldOrderInputById = function (fieldId, parent) { + var field; + var orderFieldsObject = updateFieldOrder.prototype.orderFieldsObject; + var fieldSettingsForm = updateFieldOrder.prototype.fieldSettingsForm; + if (orderFieldsObject[fieldId] === undefined) { + field = fieldSettingsForm.querySelector("input[name=\"field_options[field_order_".concat(fieldId, "]\"]")); + if (!field) { + field = parent.querySelector("input[name=\"field_options[field_order_".concat(fieldId, "]\"]")); + } + orderFieldsObject[fieldId] = field; + return field; + } + return orderFieldsObject[fieldId]; + }; + this.initOnceInAllInstances(); + renumberPageBreaks(); + return function () { + var fieldId; + var field; + var currentOrder; + var newOrder; + var i; + var singleField; + var moveFieldsClass = new moveFieldSettings(); + var fields = jQuery('li.frm_field_box', jQuery('#frm-show-fields')); + for (i = 0; i < fields.length; i++) { + fieldId = fields[i].getAttribute('data-fid'); + field = self.getFieldOrderInputById(fieldId, fields[i]); + + // get current field order, make sure we don't get the "field" reference as the "field" value will get updated later. + currentOrder = field ? Object.assign({}, field.value)[0] : null; + newOrder = i + 1; + if (currentOrder != newOrder && null !== currentOrder) { + field.value = newOrder; + singleField = fields[i].querySelector("#frm-single-settings-".concat(fieldId)); + + // add field that needs to be moved to "updateFieldOrder.prototype.fieldSettingsForm" + moveFieldsClass.append(singleField); + fieldUpdated(); + } + } + // move all appended fields + moveFieldsClass.moveFields(); + }(); + } + function toggleSectionHolder() { + document.querySelectorAll('.start_divider').forEach(function (divider) { + toggleOneSectionHolder(jQuery(divider)); + }); + } + function toggleOneSectionHolder($section) { + if (!$section.length) { + return; + } + var $rows = $section.find('ul.frm_sorting'); + var sectionHasFields = false; + var length = $rows.length; + for (var index = 0; index < length; ++index) { + if (0 !== getFieldsInRow(jQuery($rows.get(index))).length) { + sectionHasFields = true; + break; + } + } + var noSectionFields = $section.parent().children('.frm_no_section_fields').get(0); + noSectionFields.classList.toggle('frm_block', !sectionHasFields); + } + function handleShowPasswordLiveUpdate() { + frmDom.util.documentOn('change', '.frm_show_password_setting_input', function (event) { + var fieldId = event.target.getAttribute('data-fid'); + var fieldEl = document.getElementById("frm_field_id_".concat(fieldId)); + if (!fieldEl) { + return; + } + fieldEl.classList.toggle('frm_disabled_show_password', !event.target.checked); + }); + } + function slideDown() { + /*jshint validthis:true */ + var id = jQuery(this).data('slidedown'); + var $thisId = jQuery(document.getElementById(id)); + if ($thisId.is(':hidden')) { + $thisId.slideDown('fast'); + this.style.display = 'none'; + } + return false; + } + function slideUp() { + /*jshint validthis:true */ + var id = jQuery(this).data('slideup'); + var $thisId = jQuery(document.getElementById(id)); + $thisId.slideUp('fast'); + $thisId.siblings('a').show(); + return false; + } + function adjustVisibilityValuesForEveryoneValues(element, option) { + if ('' === option.getAttribute('value')) { + onEveryoneOptionSelected(jQuery(this)); + } else { + unselectEveryoneOptionIfSelected(jQuery(this)); + } + } + function onEveryoneOptionSelected($select) { + $select.val(''); + $select.next('.btn-group').find('.multiselect-container input[value!=""]').prop('checked', false); + } + function unselectEveryoneOptionIfSelected($select) { + var selectedValues = $select.val(); + if (selectedValues === null) { + $select.next('.btn-group').find('.multiselect-container input[value=""]').prop('checked', true); + onEveryoneOptionSelected($select); + return; + } + var index = selectedValues.indexOf(''); + if (index >= 0) { + selectedValues.splice(index, 1); + $select.val(selectedValues); + $select.next('.btn-group').find('.multiselect-container input[value=""]').prop('checked', false); + } + } + + /** + * Get rid of empty container that inserts extra space. + */ + function hideEmptyEle() { + jQuery('.frm-hide-empty').each(function () { + if (jQuery(this).text().trim().length === 0) { + jQuery(this).remove(); + } + }); + } + + /* Change the classes in the builder */ + function changeFieldClass(field, setting) { + var classes; + var replace; + var alignField; + var replaceWith = " ".concat(setting.value); + var fieldId = field.getAttribute('data-fid'); + + // Include classes from multiple settings. + if (fieldId !== undefined) { + if (setting.classList.contains('field_options_align')) { + replaceWith += " ".concat(document.getElementById("frm_classes_".concat(fieldId)).value); + } else if (setting.classList.contains('frm_classes')) { + alignField = document.getElementById("field_options_align_".concat(fieldId)); + if (alignField) { + replaceWith += " ".concat(alignField.value); + } + } + } + replaceWith += ' '; + + // Allow for the column number dropdown. + replaceWith = replaceWith.replace(' block ', ' vertical_radio ').replace(' inline ', ' horizontal_radio '); + classes = field.className.split(' frmstart ')[1]; + classes = 0 === classes.indexOf('frmend ') ? '' : classes.split(' frmend ')[0]; + if (classes.trim() === '') { + replace = ' frmstart frmend '; + if (!field.className.includes(replace)) { + replace = ' frmstart frmend '; + } + replaceWith = " frmstart ".concat(replaceWith.trim(), " frmend "); + } else { + replace = classes.trim(); + replaceWith = replaceWith.trim(); + } + field.className = field.className.replace(replace, replaceWith); + } + function maybeShowInlineModal(e) { + /*jshint validthis:true */ + e.preventDefault(); + showInlineModal(this, undefined, e); + } + function showInlineModal(icon, input, event) { + var box = document.getElementById(icon.getAttribute('data-open')); + var container = jQuery(icon).closest('p,ul'); + var inputTrigger = input !== undefined; + if (container.hasClass('frm-open')) { + container.removeClass('frm-open'); + box.classList.add('frm_hidden'); + } else { + if (!inputTrigger) { + input = getInputForIcon(icon); + } + if (input) { + if (!inputTrigger) { + var key = event.key; + if (key !== 'Enter' && key !== ' ') { + input.focus(); + } + } + container.after(box); + box.setAttribute('data-fills', input.id.replace('-proxy-input', '')); + if (box.id.indexOf('frm-calc-box') === 0) { + popCalcFields(box, true); + } + } + container.addClass('frm-open'); + box.classList.remove('frm_hidden'); + + /** + * @since 6.4.1 + */ + wp.hooks.doAction('frm_show_inline_modal', box, icon); + } + } + function dismissInlineModal(e) { + /*jshint validthis:true */ + e.preventDefault(); + this.parentNode.classList.add('frm_hidden'); + jQuery(".frm-open [data-open=\"".concat(this.parentNode.id, "\"]")).closest('.frm-open').removeClass('frm-open'); + } + + /** + * Close frm-modal-no-dismiss element when clicking outside of it + * + * @param {Event} event The click event + */ + function closeModalOnOutsideClick(_ref3) { + var target = _ref3.target; + if (target.closest('.frm-inline-modal.frm-modal-no-dismiss') || target.closest('.frm-show-inline-modal') || target.closest('#frm_adv_info') || target.closest('.frm-token-proxy-input')) { + return; + } + + // Close all inline modals (without close button) that are not hidden + document.querySelectorAll('.frm-inline-modal.frm-modal-no-dismiss:not(.frm_hidden)').forEach(function (modal) { + modal.classList.add('frm_hidden'); + modal.previousElementSibling.classList.remove('frm-open'); + }); + } + function changeInputtedValue() { + /*jshint validthis:true */ + var i; + var action = this.getAttribute('data-frmchange').split(','); + for (i = 0; i < action.length; i++) { + if (action[i] === 'updateOption') { + changeHiddenSeparateValue(this); + } else if (action[i] === 'updateDefault') { + changeDefaultRadioValue(this); + } else if (action[i] === 'checkUniqueOpt') { + checkUniqueOpt(this); + } else { + this.value = this.value[action[i]](); + } + } + } + + /** + * When the saved value is changed, update the default value radio. + * @param {HTMLElement} input The changed input element. + */ + function changeDefaultRadioValue(input) { + var parentLi = getOptionParent(input); + var key = parentLi.getAttribute('data-optkey'); + var fieldId = getOptionFieldId(parentLi, key); + var defaultRadio = parentLi.querySelector("input[name=\"default_value_".concat(fieldId, "\"]")); + if (defaultRadio !== null) { + defaultRadio.value = input.value; + } + } + + /** + * If separate values are not enabled, change the saved value when + * the displayed value is changed. + * @param {HTMLElement} input The changed input element. + */ + function changeHiddenSeparateValue(input) { + var savedVal; + var parentLi = getOptionParent(input); + var key = parentLi.getAttribute('data-optkey'); + var fieldId = getOptionFieldId(parentLi, key); + var sep = document.getElementById("separate_value_".concat(fieldId)); + if (sep && sep.checked === false) { + // If separate values are not turned on. + savedVal = document.getElementById("field_key_".concat(fieldId, "-").concat(key)); + savedVal.value = input.value; + changeDefaultRadioValue(savedVal); + } + } + function getOptionParent(input) { + var parentLi = input.parentNode; + if (parentLi.tagName !== 'LI') { + parentLi = parentLi.parentNode; + } + return parentLi; + } + function getOptionFieldId(li, key) { + var liId = li.id; + return liId.replace('frm_delete_field_', '').replace("-".concat(key, "_container"), ''); + } + function submitBuild() { + /*jshint validthis:true */ + var $thisEle = this; + if (showNameYourFormModal()) { + return; + } + preFormSave(this); + var $form = jQuery(builderForm); + var v = JSON.stringify($form.serializeArray()); + jQuery(document.getElementById('frm_compact_fields')).val(v); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_save_form', + frm_compact_fields: v, + nonce: frmGlobal.nonce + }, + success: function success(msg) { + afterFormSave($thisEle); + var $postStuff = document.getElementById('post-body-content'); + var $html = document.createElement('div'); + $html.setAttribute('class', 'frm_updated_message'); + $html.innerHTML = msg; + $postStuff.insertBefore($html, $postStuff.firstChild); + reloadIfAddonActivatedAjaxSubmitOnly(); + }, + error: function error() { + triggerSubmit(document.getElementById('frm_js_build_form')); + } + }); + } + function triggerSubmit(form) { + var button = form.ownerDocument.createElement('input'); + button.style.display = 'none'; + button.type = 'submit'; + form.append(button); + button.click(); + button.remove(); + } + function triggerChange(element) { + jQuery(element).trigger('change'); + } + function submitNoAjax() { + /*jshint validthis:true */ + if (showNameYourFormModal()) { + return; + } + preFormSave(this); + var form = jQuery(builderForm); + jQuery(document.getElementById('frm_compact_fields')).val(JSON.stringify(form.serializeArray())); + triggerSubmit(document.getElementById('frm_js_build_form')); + } + + /** + * Display a modal dialog for naming a new form template, if applicable. + * + * @return {boolean} True if the modal is successfully initialized and displayed; false otherwise. + */ + function showNameYourFormModal() { + // Exit early if the 'new_template' URL parameter is not set to 'true' + if (!shouldShowNameYourFormNameModal()) { + return false; + } + var modalWidget = initModal('#frm-form-templates-modal', '440px'); + if (!modalWidget) { + return false; + } + + // Set the vertical offset for the modal and open it + offsetModalY(modalWidget, '72px'); + modalWidget.dialog('open'); + return true; + } + + /** + * Returns true if 'Name Your Form' modal should be displayed. + * + * @return {boolean} True if the modal should be displayed. + */ + function shouldShowNameYourFormNameModal() { + var _document$querySelect3; + var formNameInput = document.getElementById('frm_form_name'); + if (formNameInput && formNameInput.value.trim() !== '') { + return false; + } + return 'true' === urlParams.get('new_template') && ((_document$querySelect3 = document.querySelector('#frm_top_bar #frm_bs_dropdown .frm_bstooltip')) === null || _document$querySelect3 === void 0 ? void 0 : _document$querySelect3.textContent.trim()) === frm_admin_js.noTitleText; + } + + /** + * Manages event handling for the 'Name your form' modal. + * + * Attaches click and keydown event listeners to the save button and input field. + * + * @return {void} + */ + function addFormNameModalEvents() { + var saveFormNameButton = document.getElementById('frm-save-form-name-button'); + var newFormNameInput = document.getElementById('frm_new_form_name_input'); + + // Attach click event listener + onClickPreventDefault(saveFormNameButton, onSaveFormNameButton); + + // Attach keydown event listener + newFormNameInput.addEventListener('keydown', function (event) { + if (event.key === 'Enter') { + onSaveFormNameButton(event); + } + }); + } + + /** + * Handles the click event on the save form name button. + * + * @param {Event} event The click event object. + * @return {void} + */ + var onSaveFormNameButton = function onSaveFormNameButton(event) { + var newFormName = document.getElementById('frm_new_form_name_input').value.trim(); + + // Prepare FormData for the POST request + var formData = new FormData(); + formData.append('form_id', urlParams.get('id')); + formData.append('form_name', newFormName); + + // Perform the POST request + doJsonPost('rename_form', formData).then(function (data) { + // Remove the 'new_template' parameter from the URL and update the browser history + urlParams.delete('new_template'); + currentURL.search = urlParams.toString(); + history.replaceState({}, '', currentURL.toString()); + if (null !== document.getElementById('frm_notification_settings')) { + document.getElementById('frm_form_name').value = newFormName; + document.getElementById('frm_form_key').value = data.form_key; + } + + // Trigger the 'Save' button click using jQuery + jQuery('#frm-publishing').find('.frm_button_submit').trigger('click'); + }); + }; + function preFormSave(b) { + removeWPUnload(); + if (jQuery('form.inplace_form').length) { + jQuery('.inplace_save, .postbox').trigger('click'); + } + if (b.classList.contains('frm_button_submit')) { + b.classList.add('frm_loading_form'); + } else { + b.classList.add('frm_loading_button'); + } + b.setAttribute('aria-busy', 'true'); + adjustFormatInputBeforeSave(); + } + + /** + * Updates the format input based on the selected format type from dropdowns during the form save process. + * + * @since 6.9 + * + * @return {void} + */ + function adjustFormatInputBeforeSave() { + var formatTypes = document.querySelectorAll('.frm_format_dropdown, .frm_phone_type_dropdown'); + var valueMap = { + none: '', + international: 'international', + currency: 'currency', + number: 'number' + }; + formatTypes.forEach(function (formatType) { + var value = formatType.value; + if (value in valueMap) { + var formatInput = document.getElementById("frm_format_".concat(formatType.dataset.fieldId)); + formatInput.value = valueMap[value]; + } + }); + } + function afterFormSave(button) { + button.classList.remove('frm_loading_form'); + button.classList.remove('frm_loading_button'); + resetOptionTextDetails(); + fieldsUpdated = 0; + button.setAttribute('aria-busy', 'false'); + setTimeout(function () { + jQuery('.frm_updated_message').fadeOut('slow', function () { + this.remove(); + }); + }, 5000); + } + function initUpgradeModal() { + var upgradePopup = __webpack_require__(/*! ./upgrade-popup */ "./js/src/admin/upgrade-popup.js"); + upgradePopup.initUpgradeModal(); + } + function addOneClick(element, type, upgradeLabel) { + var upgradePopup = __webpack_require__(/*! ./upgrade-popup */ "./js/src/admin/upgrade-popup.js"); + upgradePopup.addOneClick(element, type, upgradeLabel); + } + + /** + * Opens a basic modal with the given title and content. + * + * @param {Event} event The event object. + * @return {void} + */ + function showBasicModal(event) { + var _event$target$dataset; + var button = (_event$target$dataset = event.target.dataset) !== null && _event$target$dataset !== void 0 && _event$target$dataset.modalTitle ? event.target : event.target.closest('[data-modal-title]'); + if (!button) { + return; + } + var _button$dataset = button.dataset, + modalTitle = _button$dataset.modalTitle, + modalContent = _button$dataset.modalContent; + if (!modalTitle || !modalContent) { + return; + } + event.preventDefault(); + frmDom.modal.maybeCreateModal('frmBasicModal', { + title: modalTitle, + content: div({ + className: 'inside', + child: span(modalContent) + }) + }); + } + function getRequiredLicenseFromTrigger(element) { + if (element.dataset.requires) { + return element.dataset.requires; + } + return 'Pro'; + } + function populateUpgradeTab(element) { + var title = element.dataset.upgrade; + var tab = element.getAttribute('href').replace('#', ''); + var container = document.querySelector(".frm_".concat(tab)) || document.querySelector(".".concat(tab)); + if (!container) { + return; + } + if (container.querySelector('.frm-upgrade-message')) { + // Tab has already been populated. + return; + } + var h2 = container.querySelector('h2'); + h2.style.borderBottom = 'none'; + + /* translators: %s: Form Setting section name (ie Form Permissions, Form Scheduling). */ + h2.textContent = sprintf(__('%s are not installed', 'formidable'), title); + container.classList.add('frmcenter'); + var upgradeModal = document.getElementById('frm_upgrade_modal'); + appendClonedModalElementToContainer('frm-oneclick'); + appendClonedModalElementToContainer('frm-addon-status'); + + // Borrow the call to action from the Upgrade upgradeModal which should exist on the settings page (it is still used for other upgrades including Actions). + var upgradeModalLink = upgradeModal.querySelector('.frm-upgrade-link'); + if (upgradeModalLink) { + var _upgradeModalLink$nex; + var upgradeButton; + var upgradeActions = upgradeModalLink.closest('.frm-upgrade-modal-actions'); + if (upgradeActions) { + upgradeActions = upgradeActions.cloneNode(true); + upgradeButton = upgradeActions.querySelector('.frm-upgrade-link'); + } else { + upgradeButton = upgradeModalLink.cloneNode(true); + } + var level = upgradeButton.querySelector('.license-level'); + if (level) { + level.textContent = getRequiredLicenseFromTrigger(element); + } + container.append(upgradeActions || upgradeButton); + + // Maybe append the secondary "Already purchased?" link from the upgradeModal as well. + if ((_upgradeModalLink$nex = upgradeModalLink.nextElementSibling) !== null && _upgradeModalLink$nex !== void 0 && _upgradeModalLink$nex.querySelector('.frm-link-secondary')) { + container.append(upgradeModalLink.nextElementSibling.cloneNode(true)); + } + appendClonedModalElementToContainer('frm-oneclick-button'); + } + appendClonedModalElementToContainer('frm-upgrade-message'); + var upgradeLabel = element.dataset.message; + if (upgradeLabel === undefined) { + upgradeLabel = element.dataset.upgrade; + } + addOneClick(element, 'tab', upgradeLabel); + if (element.dataset.screenshot) { + container.append(getScreenshotWrapper(element.dataset.screenshot)); + } + function appendClonedModalElementToContainer(className) { + container.append(upgradeModal.querySelector(".".concat(className)).cloneNode(true)); + } + } + function getScreenshotWrapper(screenshot) { + var folderUrl = "".concat(frmGlobal.url, "/images/screenshots/"); + var wrapper = div({ + className: 'frm-settings-screenshot-wrapper', + children: [getToolbar(), div({ + child: img({ + src: folderUrl + screenshot + }) + })] + }); + function getToolbar() { + var children = getColorIcons(); + children.push(img({ + src: "".concat(frmGlobal.url, "/images/tab.svg") + })); + return div({ + className: 'frm-settings-screenshot-toolbar', + children: children + }); + } + function getColorIcons() { + return ['#ED8181', '#EDE06A', '#80BE30'].map(function (color) { + var circle = div({ + className: 'frm-minmax-icon' + }); + circle.style.backgroundColor = color; + return circle; + }); + } + return wrapper; + } + + /* Form settings */ + + function showInputIcon(parentClass) { + if (parentClass === undefined) { + parentClass = ''; + } + maybeAddFieldSelection(parentClass); + jQuery("".concat(parentClass, " .frm_has_shortcodes:not(.frm-with-right-icon) input,").concat(parentClass, " .frm_has_shortcodes:not(.frm-with-right-icon) textarea")).wrap('').before(''); + } + + /** + * For reverse compatibility. Check for fields that were + * using the old sidebar. + * @param {string} parentClass The parent CSS class selector. + */ + function maybeAddFieldSelection(parentClass) { + var i; + var missingClass = jQuery("".concat(parentClass, " :not(.frm_has_shortcodes) .frm_not_email_message, ").concat(parentClass, " :not(.frm_has_shortcodes) .frm_not_email_to, ").concat(parentClass, " :not(.frm_has_shortcodes) .frm_not_email_subject")); + for (i = 0; i < missingClass.length; i++) { + missingClass[i].parentNode.classList.add('frm_has_shortcodes'); + } + } + function showSuccessOpt() { + /*jshint validthis:true */ + var c = 'success'; + if (this.name === 'options[edit_action]') { + c = 'edit'; + } + var v = jQuery(this).val(); + jQuery(".".concat(c, "_action_box")).hide(); + if (v === 'redirect') { + jQuery(".".concat(c, "_action_redirect_box.").concat(c, "_action_box")).fadeIn('slow'); + } else if (v === 'page') { + jQuery(".".concat(c, "_action_page_box.").concat(c, "_action_box")).fadeIn('slow'); + } else { + jQuery(".".concat(c, "_action_message_box.").concat(c, "_action_box")).fadeIn('slow'); + } + } + function copyFormAction(event) { + if (waitForActionToLoadBeforeCopy(event.target)) { + return; + } + var targetSettings = event.target.closest('.frm_form_action_settings'); + var wysiwygs = targetSettings.querySelectorAll('.wp-editor-area'); + if (wysiwygs.length) { + // Temporary remove TinyMCE before cloning to avoid TinyMCE conflicts. + wysiwygs.forEach(function (wysiwyg) { + tinymce.EditorManager.execCommand('mceRemoveEditor', true, wysiwyg.id); + }); + } + var $action = jQuery(targetSettings).clone(); + var currentID = $action.attr('id').replace('frm_form_action_', ''); + var newID = newActionId(currentID); + $action.find('.frm_action_id, .frm-btn-group').remove(); + $action.find("input[name$=\"[".concat(currentID, "][ID]\"]")).val(''); + $action.find('.widget-inside').hide(); + + // the .html() gets original values, so they need to be set + $action.find('input[type=text], textarea, input[type=number]').prop('defaultValue', function () { + return this.value; + }); + $action.find('input[type=checkbox], input[type=radio]').prop('defaultChecked', function () { + return this.checked; + }); + var rename = new RegExp("\\[".concat(currentID, "\\]"), 'g'); + var reid = new RegExp("_".concat(currentID, "\""), 'g'); + var reclass = new RegExp("-".concat(currentID, "\""), 'g'); + var revalue = new RegExp("\"".concat(currentID, "\""), 'g'); // if a field id matches, this could cause trouble + + var html = $action.html().replace(rename, "[".concat(newID, "]")).replace(reid, "_".concat(newID, "\"")); + html = html.replace(reclass, "-".concat(newID, "\"")).replace(revalue, "\"".concat(newID, "\"")); + var newAction = div({ + id: "frm_form_action_".concat(newID), + className: $action.get(0).className + }); + newAction.setAttribute('data-actionkey', newID); + newAction.innerHTML = html; + newAction.querySelectorAll('.wp-editor-wrap, .wp-editor-wrap *').forEach(function (element) { + if ('string' === typeof element.className) { + element.className = element.className.replace(currentID, newID); + } + element.id = element.id.replace(currentID, newID); + }); + newAction.classList.remove('open'); + document.getElementById('frm_notification_settings').append(newAction); + if (wysiwygs.length) { + // Re-initialize the original wysiwyg which was removed before cloning. + wysiwygs.forEach(function (wysiwyg) { + frmDom.wysiwyg.init(wysiwyg); + }); + newAction.querySelectorAll('.wp-editor-area').forEach(function (wysiwyg) { + frmDom.wysiwyg.init(wysiwyg); + }); + } + if (newAction.classList.contains('frm_single_on_submit_settings')) { + var autocompleteInput = newAction.querySelector('input.frm-page-search'); + if (autocompleteInput) { + initAutocomplete(newAction); + } + } + initiateMultiselect(); + var hookName = 'frm_after_duplicate_action'; + wp.hooks.doAction(hookName, newAction); + } + function waitForActionToLoadBeforeCopy(element) { + var $trigger = jQuery(element); + var $original = $trigger.closest('.frm_form_action_settings'); + var $inside = $original.find('.widget-inside'); + if ($inside.find('p, div, table').length) { + return false; + } + var $top = $original.find('.widget-top'); + $top.on('frm-action-loaded', function () { + $trigger.trigger('click'); + $original.removeClass('open'); + $inside.hide(); + }); + $top.trigger('click'); + return true; + } + function newActionId(currentID) { + var newID = parseInt(currentID, 10) + 11; + var exists = document.getElementById("frm_form_action_".concat(newID)); + if (exists) { + newID++; + newID = newActionId(newID); + } + return newID; + } + function addFormAction() { + /*jshint validthis:true */ + var type = jQuery(this).data('actiontype'); + if (isAtLimitForActionType(type)) { + return; + } + var actionId = getNewActionId(); + var formId = thisFormId; + var placeholderSetting = document.createElement('div'); + placeholderSetting.classList.add("frm_single_".concat(type, "_settings")); + var actionsList = document.getElementById('frm_notification_settings'); + actionsList.append(placeholderSetting); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_add_form_action', + type: type, + list_id: actionId, + form_id: formId, + nonce: frmGlobal.nonce + }, + success: handleAddFormActionSuccess + }); + function handleAddFormActionSuccess(html) { + fieldUpdated(); + placeholderSetting.remove(); + closeOpenActions(); + var newActionContainer = div(); + newActionContainer.innerHTML = html; + var widgetTop = newActionContainer.querySelector('.widget-top'); + Array.from(newActionContainer.children).forEach(function (child) { + return actionsList.append(child); + }); + jQuery('.frm_form_action_settings').fadeIn('slow'); + var newAction = document.getElementById("frm_form_action_".concat(actionId)); + newAction.classList.add('open'); + document.getElementById('post-body-content').scroll({ + top: newAction.offsetTop + 10, + left: 0, + behavior: 'smooth' + }); + + // Check if icon should be active + checkActiveAction(type); + showInputIcon("#frm_form_action_".concat(actionId)); + initiateMultiselect(); + initAutocomplete(newAction); + if (widgetTop) { + jQuery(widgetTop).trigger('frm-action-loaded'); + } + + /** + * Fires after added a new form action. + * + * @since 5.5.4 + * + * @param {HTMLElement} formAction Form action element. + */ + frmAdminBuild.hooks.doAction('frm_added_form_action', newAction); + } + } + function closeOpenActions() { + document.querySelectorAll('.frm_form_action_settings.open').forEach(function (setting) { + return setting.classList.remove('open'); + }); + } + function toggleActionGroups() { + /*jshint validthis:true */ + var actions = document.getElementById('frm_email_addon_menu').classList; + var search = document.getElementById('actions-search-input'); + if (actions.contains('frm-all-actions')) { + actions.remove('frm-all-actions'); + actions.add('frm-limited-actions'); + } else { + actions.add('frm-all-actions'); + actions.remove('frm-limited-actions'); + } + + // Reset search. + search.value = ''; + triggerEvent(search, 'input'); + } + function getNewActionId() { + var actionSettings = document.querySelectorAll('.frm_form_action_settings'); + var len = getNewRowId(actionSettings, 'frm_form_action_'); + if (document.getElementById("frm_form_action_".concat(len)) !== undefined) { + len = len + 100; + } + if (lastNewActionIdReturned >= len) { + len = lastNewActionIdReturned + 1; + } + lastNewActionIdReturned = len; + return len; + } + function clickAction(obj) { + var $thisobj = jQuery(obj); + if (obj.className.includes('selected')) { + return; + } + if (obj.className.includes('edit_field_type_end_divider') && $thisobj.closest('.edit_field_type_divider').hasClass('no_repeat_section')) { + return; + } + deselectFields(); + $thisobj.addClass('selected'); + showFieldOptions(obj); + } + + /** + * When a field is selected, show the field settings in the sidebar. + * @param {HTMLElement} obj The selected field element. + */ + function showFieldOptions(obj) { + var _document$querySelect4; + var i; + var fieldId = obj.getAttribute('data-fid'); + var fieldType = obj.getAttribute('data-type'); + var allFieldSettings = document.querySelectorAll('.frm-single-settings:not(.frm_hidden)'); + for (i = 0; i < allFieldSettings.length; i++) { + allFieldSettings[i].classList.add('frm_hidden'); + } + var singleField = document.getElementById("frm-single-settings-".concat(fieldId)); + moveFieldSettings(singleField); + if (fieldType && 'quantity' === fieldType) { + popProductFields(jQuery(singleField).find('.frmjs_prod_field_opt')[0]); + } + + // Scroll settings panel to top + (_document$querySelect4 = document.querySelector('.frm-settings-panel.frm-scrollbar-wrapper')) === null || _document$querySelect4 === void 0 || _document$querySelect4.scrollTo({ + top: 0, + behavior: 'instant' + }); + singleField.classList.remove('frm_hidden'); + + // Cancel slide animation on expanded sections so screen readers + // can immediately access inputs after DOM re-insertion. + singleField.querySelectorAll('h3:not(.frm-collapsed) + .frm-collapse-me').forEach(function (section) { + return section.style.animation = 'none'; + }); + document.getElementById('frm-options-panel-tab').click(); + var editor = singleField.querySelector('.wp-editor-area'); + if (editor) { + frmDom.wysiwyg.init(editor, { + setupCallback: setupTinyMceEventHandlers + }); + } + wp.hooks.doAction('frmShowedFieldSettings', obj, singleField); + maybeAddShortcodesModalTriggerIcon(fieldType, fieldId, singleField); + } + function maybeAddShortcodesModalTriggerIcon(fieldType, fieldId, singleField) { + var _singleField$querySel; + if (!shouldAddShortcodesModalTriggerIcon(fieldType)) { + return; + } + var fieldSettingsSelector = "#frm-single-settings-".concat(fieldId); + if (document.querySelector("".concat(fieldSettingsSelector, " .frm-show-box"))) { + return; + } + (_singleField$querySel = singleField.querySelector('.wp-editor-container')) === null || _singleField$querySel === void 0 || _singleField$querySel.classList.add('frm_has_shortcodes'); + var wrapTextareaWithIconContainer = function wrapTextareaWithIconContainer() { + var textareas = document.querySelectorAll("".concat(fieldSettingsSelector, " .frm_has_shortcodes textarea")); + textareas.forEach(function (textarea) { + var wrapperSpan = span({ + className: 'frm-with-right-icon' + }); + textarea.parentNode.insertBefore(wrapperSpan, textarea); + wrapperSpan.append(createModalTriggerIcon()); + wrapperSpan.append(textarea); + }); + }; + var createModalTriggerIcon = function createModalTriggerIcon() { + return frmDom.svg({ + href: '#frm_more_horiz_solid_icon', + classList: ['frm-show-box'] + }); + }; + wrapTextareaWithIconContainer(); + } + function shouldAddShortcodesModalTriggerIcon(fieldType) { + var fieldsWithShortcodesBox = wp.hooks.applyFilters('frm_fields_with_shortcode_popup', ['html']); + return fieldsWithShortcodesBox.includes(fieldType); + } + function setupTinyMceEventHandlers(editor) { + editor.on('Change', function () { + handleTinyMceChange(editor); + }); + } + function handleTinyMceChange(editor) { + if (!isTinyMceActive() || tinyMCE.activeEditor.isHidden()) { + return; + } + editor.targetElm.value = editor.getContent(); + jQuery(editor.targetElm).trigger('change'); + } + function isTinyMceActive() { + var activeSettings = document.querySelector('.frm-single-settings:not(.frm_hidden)'); + if (!activeSettings) { + return false; + } + var wrapper = activeSettings.querySelector('.wp-editor-wrap'); + return wrapper && wrapper.classList.contains('tmce-active'); + } + + /** + * Move the settings to the sidebar the first time they are changed or selected. + * Keep the end marker at the end of the form. + * @param {HTMLElement} singleField The field settings element to move. + */ + function moveFieldSettings(singleField) { + var self = this; + if (!singleField) { + // The field may have not been loaded yet via ajax. + return; + } + this.fragment = document.createDocumentFragment(); + this.initOnceInAllInstances = function () { + if (moveFieldSettings.prototype.endMarker !== undefined) { + return; + } + // perform a single search in the DOM and use it across all moveFieldSettings instances + moveFieldSettings.prototype.endMarker = document.getElementById('frm-end-form-marker'); + }; + this.append = function (field) { + var classname = field ? field.parentElement.classList : ''; + if (!field || !classname.contains('frm_field_box') && !classname.contains('divider_section_only')) { + return; + } + self.fragment.append(field); + }; + this.moveFields = function () { + builderForm.insertBefore(self.fragment, moveFieldSettings.prototype.endMarker); + }; + this.initOnceInAllInstances(); + + // Move the field if function is called as function with a singleField passed as arg. + // In this particular case only 1 field is needed to be moved so the field will get instantly moved. + // "singleField" may be undefined when it's called as a constructor instead of a function. Use the constructor to add multiple fields which are passed through "append" and move these all at once via "moveFields". + if (singleField !== undefined) { + this.append(singleField); + this.moveFields(); + return; + } + return { + append: this.append, + moveFields: this.moveFields + }; + } + function showEmailRow() { + /*jshint validthis:true */ + var actionKey = jQuery(this).closest('.frm_form_action_settings').data('actionkey'); + var rowType = this.getAttribute('data-emailrow'); + jQuery("#frm_form_action_".concat(actionKey, " .frm_").concat(rowType, "_row")).fadeIn('slow'); + jQuery(this).fadeOut('slow'); + } + function hideEmailRow() { + /*jshint validthis:true */ + var actionBox = jQuery(this).closest('.frm_form_action_settings'); + var rowType = this.getAttribute('data-emailrow'); + var emailRowSelector = ".frm_".concat(rowType, "_row"); + var emailButtonSelector = ".frm_".concat(rowType, "_button"); + jQuery(actionBox).find(emailButtonSelector).fadeIn('slow'); + jQuery(actionBox).find(emailRowSelector).fadeOut('slow', function () { + jQuery(actionBox).find("".concat(emailRowSelector, " input")).val(''); + }); + } + function showEmailWarning() { + /*jshint validthis:true */ + var actionBox = jQuery(this).closest('.frm_form_action_settings'); + var emailRowSelector = '.frm_from_to_match_row'; + var fromVal = actionBox.find('input[name$="[post_content][from]"]').val(); + var toVal = actionBox.find('input[name$="[post_content][email_to]"]').val(); + if (fromVal === toVal) { + jQuery(actionBox).find(emailRowSelector).fadeIn('slow'); + } else { + jQuery(actionBox).find(emailRowSelector).fadeOut('slow'); + } + } + function checkActiveAction(type) { + var actionTriggers = document.querySelectorAll(".frm_".concat(type, "_action")); + if (isAtLimitForActionType(type)) { + var addAlreadyUsedClass = getLimitForActionType(type) > 0; + markActionTriggersInactive(actionTriggers, addAlreadyUsedClass); + return; + } + markActionTriggersActive(actionTriggers); + } + function markActionTriggersActive(triggers) { + triggers.forEach(function (trigger) { + if (trigger.querySelector('.frm_show_upgrade')) { + // Prevent disabled action becoming active. + return; + } + trigger.classList.remove('frm_inactive_action', 'frm_already_used'); + trigger.classList.add('frm_active_action'); + }); + } + function markActionTriggersInactive(triggers, addAlreadyUsedClass) { + triggers.forEach(function (trigger) { + trigger.classList.remove('frm_active_action'); + trigger.classList.add('frm_inactive_action'); + if (addAlreadyUsedClass) { + trigger.classList.add('frm_already_used'); + } + }); + } + function isAtLimitForActionType(type) { + var atLimit = getNumberOfActionsForType(type) >= getLimitForActionType(type); + var hookName = 'frm_action_at_limit'; + var hookArgs = { + type: type + }; + atLimit = wp.hooks.applyFilters(hookName, atLimit, hookArgs); + return atLimit; + } + function getLimitForActionType(type) { + return parseInt(jQuery(".frm_".concat(type, "_action")).data('limit'), 10); + } + function getNumberOfActionsForType(type) { + return jQuery(".frm_single_".concat(type, "_settings")).length; + } + function actionLimitMessage() { + var message = frmAdminJs.only_one_action; + var limit = this.dataset.limit; + if (limit !== undefined) { + limit = parseInt(limit); + if (limit > 1) { + message = message.replace(1, limit).trim(); + } else { + message += " ".concat(frmAdminJs.edit_action_text); + } + } + infoModal(message); + } + function addFormLogicRow() { + /*jshint validthis:true */ + var id = jQuery(this).data('emailkey'); + var type = jQuery(this).closest('.frm_form_action_settings').find('.frm_action_name').val(); + var formId = document.getElementById('form_id').value; + var logicRowsContainer = document.getElementById("frm_logic_row_".concat(id)); + var logicRows = logicRowsContainer.querySelectorAll('.frm_logic_row'); + var newRowID = getNewRowId(logicRows, "frm_logic_".concat(id, "_")); + var placeholder = div({ + id: "frm_logic_".concat(id, "_").concat(newRowID), + className: 'frm_logic_row frm_hidden' + }); + logicRowsContainer.append(placeholder); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_add_form_logic_row', + email_id: id, + form_id: formId, + meta_name: newRowID, + type: type, + nonce: frmGlobal.nonce + }, + success: function success(html) { + jQuery(document.getElementById("logic_link_".concat(id))).fadeOut('slow', function () { + placeholder.insertAdjacentHTML('beforebegin', html); + placeholder.remove(); + + // Show conditional logic options after "Add Conditional Logic" is clicked. + jQuery(logicRowsContainer).parent('.frm_logic_rows').fadeIn('slow'); + }); + } + }); + return false; + } + function checkDupPost() { + /*jshint validthis:true */ + var postField = jQuery('select.frm_single_post_field'); + postField.css('border-color', ''); + var $t = this; + var v = jQuery($t).val(); + if (v === '' || v === 'checkbox') { + return false; + } + postField.each(function () { + if (jQuery(this).val() === v && this.name !== $t.name) { + this.style.borderColor = 'red'; + jQuery($t).val(''); + infoModal(frmAdminJs.field_already_used); + return false; + } + }); + } + function togglePostContent() { + /*jshint validthis:true */ + var v = jQuery(this).val(); + if ('' === v) { + jQuery('.frm_post_content_opt, select.frm_dyncontent_opt').hide().val(''); + jQuery('.frm_dyncontent_opt').hide(); + } else if ('post_content' === v) { + jQuery('.frm_post_content_opt').show(); + jQuery('.frm_dyncontent_opt').hide(); + jQuery('select.frm_dyncontent_opt').val(''); + } else { + jQuery('.frm_post_content_opt').hide().val(''); + jQuery('select.frm_dyncontent_opt, .frm_form_field.frm_dyncontent_opt').show(); + } + } + function fillDyncontent() { + /*jshint validthis:true */ + var v = jQuery(this).val(); + var $dyn = jQuery(document.getElementById('frm_dyncontent')); + if ('' === v || 'new' === v) { + $dyn.val(''); + jQuery('.frm_dyncontent_opt').show(); + } else { + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_display_get_content', + id: v, + nonce: frmGlobal.nonce + }, + success: function success(val) { + $dyn.val(val); + jQuery('.frm_dyncontent_opt').show(); + } + }); + } + } + function switchPostType() { + /*jshint validthis:true */ + // update all rows of categories/taxonomies + var curSelect; + var newSelect; + var catRows = document.getElementById('frm_posttax_rows').childNodes; + var postParentField = document.querySelector('.frm_post_parent_field'); + var postMenuOrderField = document.querySelector('.frm_post_menu_order_field'); + var postType = this.value; + + // Get new category/taxonomy options + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_replace_posttax_options', + post_type: postType, + nonce: frmGlobal.nonce + }, + success: function success(html) { + // Loop through each category row, and replace the first dropdown + for (var i = 0; i < catRows.length; i++) { + // Check if current element is a div + if (catRows[i].tagName !== 'DIV') { + continue; + } + + // Get current category select + curSelect = catRows[i].getElementsByTagName('select')[0]; + + // Set up new select + newSelect = document.createElement('select'); + newSelect.innerHTML = html; + newSelect.className = curSelect.className; + newSelect.name = curSelect.name; + + // Replace the old select with the new select + catRows[i].replaceChild(newSelect, curSelect); + } + } + }); + + // Get new post parent option. + if (postParentField) { + getActionOption(postParentField, postType, 'frm_get_post_parent_option', function (response, optName) { + // The replaced string is declared in FrmProFormActionController::ajax_get_post_menu_order_option() in the pro version. + postParentField.querySelector('.frm_post_parent_opt_wrapper').innerHTML = response.replaceAll('REPLACETHISNAME', optName); + initAutocomplete(postParentField); + }); + } + if (postMenuOrderField) { + getActionOption(postMenuOrderField, postType, 'frm_should_use_post_menu_order_option'); + } + } + function getActionOption(field, postType, action, successHandler) { + var opt = field.querySelector('.frm_autocomplete_value_input') || field.querySelector('select'); + var optName = opt.getAttribute('name'); + jQuery.ajax({ + url: ajaxurl, + method: 'POST', + data: { + action: action, + post_type: postType, + _wpnonce: frmGlobal.nonce + }, + success: function success(response) { + if ('string' !== typeof response) { + console.error(response); + return; + } + if ('0' === response) { + // This post type does not support this field. + field.classList.add('frm_hidden'); + field.value = ''; + return; + } + field.classList.remove('frm_hidden'); + if ('function' === typeof successHandler) { + successHandler(response, optName); + } + }, + error: function error(response) { + return console.error(response); + } + }); + } + function addPosttaxRow() { + /*jshint validthis:true */ + addPostRow('tax', this); + } + function addPostmetaRow() { + /*jshint validthis:true */ + addPostRow('meta', this); + } + function addPostRow(type, button) { + var name; + var id = jQuery('input[name="id"]').val(); + var settings = jQuery(button).closest('.frm_form_action_settings'); + var key = settings.data('actionkey'); + var postType = settings.find('.frm_post_type').val(); + var metaName = 0; + var postTypeRows = document.querySelectorAll(".frm_post".concat(type, "_row")); + if (postTypeRows.length) { + name = postTypeRows[postTypeRows.length - 1].id.replace("frm_post".concat(type, "_"), ''); + if (isNumeric(name)) { + metaName = 1 + parseInt(name, 10); + } else { + metaName = 1; + } + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: "frm_add_post".concat(type, "_row"), + form_id: id, + meta_name: metaName, + tax_key: metaName, + post_type: postType, + action_key: key, + nonce: frmGlobal.nonce + }, + success: function success(html) { + var cfOpts; + var optIndex; + jQuery(document.getElementById("frm_post".concat(type, "_rows"))).append(html); + jQuery(".frm_add_post".concat(type, "_row.button")).hide(); + if (type === 'meta') { + jQuery('.frm_name_value').show(); + cfOpts = document.querySelectorAll('.frm_toggle_cf_opts'); + for (optIndex = 0; optIndex < cfOpts.length - 1; ++optIndex) { + cfOpts[optIndex].style.display = 'none'; + } + } else if (type === 'tax') { + jQuery('.frm_posttax_labels').show(); + } + } + }); + } + function isNumeric(value) { + return !isNaN(parseFloat(value)) && isFinite(value); + } + function changePosttaxRow() { + /*jshint validthis:true */ + if (!jQuery(this).closest('.frm_posttax_row').find('.frm_posttax_opt_list').length) { + return; + } + jQuery(this).closest('.frm_posttax_row').find('.frm_posttax_opt_list').html('
        '); + var postType = jQuery(this).closest('.frm_form_action_settings').find('select[name$="[post_content][post_type]"]').val(); + var actionKey = jQuery(this).closest('.frm_form_action_settings').data('actionkey'); + var taxKey = jQuery(this).closest('.frm_posttax_row').attr('id').replace('frm_posttax_', ''); + var metaName = jQuery(this).val(); + var showExclude = jQuery(document.getElementById("".concat(taxKey, "_show_exclude"))).is(':checked') ? 1 : 0; + var fieldId = jQuery("select[name$=\"[post_category][".concat(taxKey, "][field_id]\"]")).val(); + var id = jQuery('input[name="id"]').val(); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_add_posttax_row', + form_id: id, + post_type: postType, + tax_key: taxKey, + action_key: actionKey, + meta_name: metaName, + field_id: fieldId, + show_exclude: showExclude, + nonce: frmGlobal.nonce + }, + success: function success(html) { + var $tax = jQuery(document.getElementById("frm_posttax_".concat(taxKey))); + $tax.replaceWith(html); + } + }); + } + function toggleCfOpts() { + /*jshint validthis:true */ + var row = jQuery(this).closest('.frm_postmeta_row'); + var cancel = row.find('.frm_cancelnew'); + var select = row.find('.frm_enternew'); + if (row.find('select.frm_cancelnew').is(':visible')) { + cancel.hide(); + select.show(); + } else { + cancel.show(); + select.hide(); + } + row.find('input.frm_enternew, select.frm_cancelnew').val(''); + return false; + } + function toggleFormOpts() { + /*jshint validthis:true */ + var changedOpt = jQuery(this); + var val = changedOpt.val(); + if (changedOpt.attr('type') === 'checkbox') { + if (this.checked === false) { + val = ''; + } + } + var toggleClass = changedOpt.data('toggleclass'); + if (val === '') { + jQuery(".".concat(toggleClass)).hide(); + } else { + jQuery(".".concat(toggleClass)).show(); + jQuery(".hide_".concat(toggleClass, "_").concat(val)).hide(); + } + } + function submitSettings() { + if (showNameYourFormModal()) { + return; + } + + /*jshint validthis:true */ + preFormSave(this); + triggerSubmit(document.querySelector('.frm_form_settings')); + } + + /* Customization Panel */ + function insertCode(e) { + /*jshint validthis:true */ + e.preventDefault(); + insertFieldCode(jQuery(this), this.getAttribute('data-code')); + return false; + } + function insertFieldCode(element, variable) { + var rich = false; + var elementId = element; + if (_typeof(element) === 'object') { + if (element.hasClass('frm_noallow')) { + return; + } + elementId = jQuery(element).closest('[data-fills]').attr('data-fills'); + if (elementId === undefined) { + elementId = element.closest('div').attr('class'); + if (elementId !== undefined) { + elementId = elementId.split(' ')[1]; + } + } + } + if (elementId === undefined) { + var active = document.activeElement; + if (active.type === 'search') { + // If the search field has focus, find the correct field. + elementId = active.id.replace('-search-input', ''); + if (elementId.match(/\d/gi) === null) { + active = jQuery(".frm-single-settings:visible .".concat(elementId)); + elementId = active.attr('id'); + } + } else { + elementId = active.id; + } + } + if (elementId) { + rich = jQuery("#wp-".concat(elementId, "-wrap.wp-editor-wrap")).length > 0; + } + var contentBox = jQuery(document.getElementById(elementId)); + if (element.attr('data-shortcode') === undefined && (!contentBox.length || contentBox.attr('data-shortcode') === undefined)) { + // this helps to exclude those that don't want shortcode-like inserted content e.g. frm-pro's summary field + var doShortcode = element.parents('ul.frm_code_list').attr('data-shortcode'); + if (doShortcode === 'undefined' || doShortcode !== 'no') { + variable = "[".concat(variable, "]"); + } + } + if (rich) { + wpActiveEditor = elementId; + } + if (!contentBox.length) { + return false; + } + if (variable === '[default-html]' || variable === '[default-plain]') { + var p = 0; + if (variable === '[default-plain]') { + p = 1; + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_get_default_html', + form_id: jQuery('input[name="id"]').val(), + plain_text: p, + nonce: frmGlobal.nonce + }, + elementId: elementId, + success: function success(msg) { + if (rich) { + var _p = document.createElement('p'); + _p.innerText = msg; + send_to_editor(_p.innerHTML); + } else { + insertContent(contentBox, msg); + } + } + }); + } else { + variable = maybeAddSanitizeUrlToShortcodeVariable(variable, element, contentBox); + if (rich) { + send_to_editor(variable); + } else { + insertContent(contentBox, variable); + } + } + return false; + } + function maybeAddSanitizeUrlToShortcodeVariable(variable, element, contentBox) { + if ('object' !== _typeof(element) || !(element instanceof jQuery) || 0 !== contentBox[0].id.indexOf('success_url_')) { + return variable; + } + element = element[0]; + if (!element.closest('#frm-insert-fields-box')) { + // Only add sanitize_url=1 to field shortcodes. + return variable; + } + if (!element.parentNode.classList.contains('frm_insert_url')) { + variable = variable.replace(']', ' sanitize_url=1]'); + } + return variable; + } + function insertContent(contentBox, variable) { + if (document.selection) { + contentBox[0].focus(); + document.selection.createRange().text = variable; + } else { + var obj = contentBox[0]; + var e = obj.selectionEnd; + variable = maybeFormatInsertedContent(contentBox, variable, obj.selectionStart, e); + obj.value = obj.value.substr(0, obj.selectionStart) + variable + obj.value.substr(obj.selectionEnd, obj.value.length); + var _s = e + variable.length; + maybeRemoveLayoutClasses(obj, variable); + obj.focus(); + obj.setSelectionRange(_s, _s); + } + triggerChange(contentBox); + } + + /** + * When a layout class is added, remove any previous layout classes to avoid conflicts. + * We only expect one layout class to exist for a given field. + * For example, if a field has frm_half and we set it to frm_third, frm_half will be removed. + * + * @since 6.11 + * + * @param {HTMLElement} obj + * @param {string} variable + * @return {void} + */ + function maybeRemoveLayoutClasses(obj, variable) { + if (!obj.classList.contains('frm_classes') || !isALayoutClass(variable)) { + return; + } + var removeClasses = obj.value.split(' ').filter(isALayoutClass); + if (removeClasses.length) { + obj.value = maybeRemoveClasses(obj.value, removeClasses, variable.trim()); + } + } + + /** + * Check if a given class is a layout class. + * + * @since 6.11 + * + * @param {string} className The class name to check. + * @return {boolean} True if the class is a layout class. + */ + function isALayoutClass(className) { + var layoutClasses = ['frm_half', 'frm_third', 'frm_two_thirds', 'frm_fourth', 'frm_three_fourths', 'frm_fifth', 'frm_sixth', 'frm2', 'frm3', 'frm4', 'frm6', 'frm8', 'frm9', 'frm10', 'frm12']; + return layoutClasses.includes(className.trim()); + } + + /** + * @since 6.11 + * + * @param {string} beforeValue The original value string. + * @param {Array} removeClasses Classes to remove. + * @param {string} variable The CSS variable name. + * @return {string} The value with specified classes removed. + */ + function maybeRemoveClasses(beforeValue, removeClasses, variable) { + var currentClasses = beforeValue.split(' ').filter(function (currentClass) { + currentClass = currentClass.trim(); + return currentClass.length && !removeClasses.includes(currentClass); + }); + if (!currentClasses.includes(variable)) { + currentClasses.push(variable); + } + return currentClasses.join(' '); + } + function maybeFormatInsertedContent(input, textToInsert, selectionStart, selectionEnd) { + var separator = input.data('sep'); + if (undefined === separator) { + return textToInsert; + } + var value = input.val(); + if (!value.trim().length) { + return textToInsert; + } + var startPattern = new RegExp("".concat(separator, "\\s*$")); + var endPattern = new RegExp("^\\s*".concat(separator)); + if (value.substr(0, selectionStart).trim().length && false === startPattern.test(value.substr(0, selectionStart))) { + textToInsert = separator + textToInsert; + } + if (value.substr(selectionEnd, value.length).trim().length && false === endPattern.test(value.substr(selectionEnd, value.length))) { + textToInsert += separator; + } + return textToInsert; + } + function resetLogicBuilder() { + /*jshint validthis:true */ + var id = document.getElementById('frm-id-condition'); + var key = document.getElementById('frm-key-condition'); + if (this.value === 'id') { + id.classList.remove('frm_hidden'); + key.classList.add('frm_hidden'); + triggerEvent(key, 'change'); + } else { + id.classList.add('frm_hidden'); + key.classList.remove('frm_hidden'); + triggerEvent(id, 'change'); + } + } + function setLogicExample() { + var idKey = document.getElementById('frm-id-key-condition-id').checked ? 'frm-id-condition' : 'frm-key-condition'; + var is = document.getElementById('frm-is-condition').value; + var text = document.getElementById('frm-text-condition').value; + var result = document.getElementById('frm-insert-condition'); + idKey = document.getElementById(idKey); + var field = idKey.options[idKey.selectedIndex].value; + var code = "if ".concat(field, " ").concat(is, "=\"").concat(text, "\"]"); + result.setAttribute('data-code', "".concat(code + frmAdminJs.conditional_text, "[/if ").concat(field)); + result.innerHTML = "[".concat(code, "[/if ").concat(field, "]"); + } + + /** + * Gets data from href or xlink:href of the given element. + * + * @param {HTMLElement} element HTML element. + * + * @return {string} The href attribute value. + */ + function getSVGHref(element) { + return element.getAttribute('href') || element.getAttributeNS('http://www.w3.org/1999/xlink', 'href'); + } + function maybeShowModal(input) { + var moreIcon; + if (input.parentNode.parentNode.classList.contains('frm_has_shortcodes')) { + hideShortcodes(); + moreIcon = getIconForInput(input); + if (moreIcon.tagName === 'use') { + moreIcon = moreIcon.firstElementChild; + if (!getSVGHref(moreIcon).includes('frm_close_icon')) { + showShortcodeBox(moreIcon, 'nofocus'); + } + } else if (!moreIcon.classList.contains('frm_close_icon')) { + showShortcodeBox(moreIcon, 'nofocus'); + } + } + } + function showShortcodes(e) { + /*jshint validthis:true */ + e.preventDefault(); + e.stopPropagation(); + showShortcodeBox(this); + } + + /** + * Handles 'change' event on the document. + * + * @since 6.16.3 + * + * @param {Event} event + * @return {void} + */ + function handleBuilderChangeEvent(event) { + maybeShowSaveAndReloadModal(event.target); + } + + /** + * Shows 'Save and Reload' modal if the target field's type is changed. + * + * @since 6.16.3 + * + * @param {HTMLElement} target + * @return {void} + */ + function maybeShowSaveAndReloadModal(target) { + var _document$querySelect5; + if (!target.id.startsWith('field_options_type_')) { + return; + } + var idParts = target.id.split('_'); + var fieldId = idParts.length && idParts[idParts.length - 1]; + if ((_document$querySelect5 = document.querySelector("#frm-single-settings-".concat(fieldId))) !== null && _document$querySelect5 !== void 0 && _document$querySelect5.classList.contains("frm-type-".concat(target.value))) { + // Do not show modal if the field type is reverted back to the original type when builder is loaded. + return; + } + showSaveAndReloadModal(); + } + + /** + * Shows 'Save and Reload' modal with the given message. + * + * @since 6.16.3 + * + * @param {string} message + * @return {void} + */ + function showSaveAndReloadModal(message) { + if (message === undefined) { + message = __('You are changing the field type. Not all field settings will appear as expected until you reload the page. Would you like to reload the page now?', 'formidable'); + } + frmDom.modal.maybeCreateModal('frmSaveAndReloadModal', { + title: __('Save and Reload?', 'formidable'), + content: getModalContent(), + footer: getModalFooter() + }); + function getModalContent() { + var modalContent = div(message); + modalContent.style.padding = 'var(--gap-md)'; + return modalContent; + } + function getModalFooter() { + var continueButton = frmDom.modal.footerButton({ + text: __('Save and Reload', 'formidable'), + buttonType: 'primary' + }); + onClickPreventDefault(continueButton, function () { + saveAndReloadFormBuilder(); + }); + var cancelButton = frmDom.modal.footerButton({ + text: __('Cancel', 'formidable'), + buttonType: 'cancel' + }); + cancelButton.classList.add('dismiss'); + return frmDom.div({ + children: [cancelButton, continueButton] + }); + } + } + function updateShortcodesPopupPosition(target) { + var moreIcon; + if (target instanceof Event) { + var useElements = document.querySelectorAll('.frm-single-settings .frm-show-box.frmsvg use'); + var openTrigger = Array.from(useElements).find(function (use) { + return use.getAttribute('href') === '#frm_close_icon'; + }); + if (openTrigger === undefined) { + return; + } + moreIcon = openTrigger.parentElement; + } else { + moreIcon = target; + } + var moreIconPosition = moreIcon.getBoundingClientRect(); + var shortCodesPopup = document.getElementById('frm_adv_info'); + var parentPos = shortCodesPopup.parentElement.getBoundingClientRect(); + shortCodesPopup.style.top = "".concat(moreIconPosition.top - parentPos.top + 32, "px"); + shortCodesPopup.style.left = "".concat(moreIconPosition.left - parentPos.left - 280, "px"); + } + function showShortcodeBox(moreIcon, shouldFocus) { + var input = getInputForIcon(moreIcon); + var box = document.getElementById('frm_adv_info'); + var classes = moreIcon.className; + if (moreIcon.tagName === 'svg') { + moreIcon = moreIcon.firstElementChild; + } + if (moreIcon.tagName === 'use') { + classes = getSVGHref(moreIcon); + } + if (classes.includes('frm_close_icon')) { + hideShortcodes(box); + } else { + updateShortcodesPopupPosition(moreIcon); + jQuery('.frm_code_list a').removeClass('frm_noallow'); + if (input.classList.contains('frm_not_email_to')) { + jQuery('#frm-insert-fields-box .frm_code_list li:not(.show_frm_not_email_to) a').addClass('frm_noallow'); + } else if (input.classList.contains('frm_not_email_subject')) { + jQuery('.frm_code_list li.hide_frm_not_email_subject a').addClass('frm_noallow'); + } + box.setAttribute('data-fills', input.id); + box.style.display = 'block'; + if (moreIcon.tagName === 'use') { + if (moreIcon.hasAttributeNS('http://www.w3.org/1999/xlink', 'href')) { + moreIcon.setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_close_icon'); + } else { + var newMoreIcon = document.createElementNS('http://www.w3.org/2000/svg', 'use'); + newMoreIcon.setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_close_icon'); + moreIcon.parentNode.replaceChild(newMoreIcon, moreIcon); + } + } else { + moreIcon.className = classes.replace('frm_more_horiz_solid_icon', 'frm_close_icon'); + } + if (shouldFocus !== 'nofocus') { + if ('none' !== input.style.display) { + input.focus(); + } else { + jQuery(tinymce.get(input.id)).trigger('focus'); + } + } + showOrHideContextualShortcodes(input); + } + } + + /** + * Returns true if a shortcode could be shown in the search result. + * + * @since 6.16.3 + * + * @param {HTMLElement} item + * @return {boolean} True if the shortcode can be shown. + */ + function checkContextualShortcode(item) { + if (frmAdminJs.contextualShortcodes.length === 0) { + return true; + } + return !isContextualShortcode(item) || canShowContextualShortcode(item); + } + + /** + * Returns true if a shortcode is contextual to fields. + * + * @since 6.16.3 + * + * @param {HTMLElement} item + * @return {boolean} True if the shortcode is contextual. + */ + function isContextualShortcode(item) { + var anchor = item.querySelector('a'); + if (!anchor) { + return false; + } + var shortcode = anchor.dataset.code; + return frmAdminJs.contextualShortcodes.address.includes(shortcode) || frmAdminJs.contextualShortcodes.body.includes(shortcode); + } + + /** + * @since 6.16.3 + * + * @param {HTMLElement} item The shortcode list item. + * @return {boolean} True if the contextual shortcode can be shown. + */ + function canShowContextualShortcode(item) { + var shortcode = item.querySelector('a').dataset.code; + var inputId = document.getElementById('frm_adv_info').dataset.fills; + var input = document.getElementById(inputId); + var contextualShortcodes = frmAdminJs.contextualShortcodes; + if (contextualShortcodes.address.includes(shortcode)) { + return input.matches(contextualShortcodes.addressSelector); + } + return input.matches(contextualShortcodes.bodySelector); + } + + /** + * @since 6.16.3 + * + * @param {HTMLElement} input + * @return {void} + */ + function showOrHideContextualShortcodes(input) { + ['address', 'body'].forEach(function (type) { + toggleContextualShortcodes(input, type); + }); + } + + /** + * @since 6.16.3 + * + * @param {HTMLElement} input + * @param {string} type + * + * @return {void} + */ + function toggleContextualShortcodes(input, type) { + var selector = frmAdminJs.contextualShortcodes["".concat(type, "Selector")]; + var contextualShortcodes = frmAdminJs.contextualShortcodes[type]; + var shouldShowShortcodes = input.matches(selector); + var _iterator = _createForOfIteratorHelper(contextualShortcodes), + _step; + try { + for (_iterator.s(); !(_step = _iterator.n()).done;) { + var _document$querySelect6; + var shortcode = _step.value; + var shortcodeLi = (_document$querySelect6 = document.querySelector("#frm-adv-info-tab .frm_code_list [data-code=\"".concat(shortcode, "\"]"))) === null || _document$querySelect6 === void 0 ? void 0 : _document$querySelect6.closest('li'); + shortcodeLi === null || shortcodeLi === void 0 || shortcodeLi.classList.toggle('frm_hidden', !shouldShowShortcodes); + } + } catch (err) { + _iterator.e(err); + } finally { + _iterator.f(); + } + } + + /** + * Returns shortcodes that are contextual to the current input field. + * + * @since 6.16.3 + * + * @return {Array} Array of contextual shortcode data. + */ + function getContextualShortcodes() { + var _document$getElementB4; + var contextualShortcodes = (_document$getElementB4 = document.getElementById('frm_adv_info')) === null || _document$getElementB4 === void 0 ? void 0 : _document$getElementB4.dataset.contextualShortcodes; + if (!contextualShortcodes) { + return []; + } + contextualShortcodes = JSON.parse(contextualShortcodes); + contextualShortcodes.addressSelector = '[id^=email_to], [id^=from_], [id^=cc], [id^=bcc]'; + contextualShortcodes.bodySelector = '[id^=email_message_]'; + return contextualShortcodes; + } + function fieldUpdated() { + if (!fieldsUpdated) { + fieldsUpdated = 1; + window.addEventListener('beforeunload', confirmExit); + } + } + function buildSubmittedNoAjax() { + // set fieldsUpdated to 0 to avoid the unsaved changes pop up + fieldsUpdated = 0; + } + function settingsSubmitted() { + // set fieldsUpdated to 0 to avoid the unsaved changes pop up + fieldsUpdated = 0; + } + function resetFieldsUpdated() { + fieldsUpdated = 0; + } + function reloadIfAddonActivatedAjaxSubmitOnly() { + var submitButton = document.getElementById('frm_submit_side_top'); + if (submitButton.hasAttribute('data-new-addon-installed') && 'true' === submitButton.getAttribute('data-new-addon-installed')) { + submitButton.removeAttribute('data-new-addon-installed'); + window.location.reload(); + } + } + function saveAndReloadFormBuilder() { + var submitButton = document.getElementById('frm_submit_side_top'); + if (submitButton.classList.contains('frm_submit_ajax')) { + submitButton.setAttribute('data-new-addon-installed', true); + } + submitButton.click(); + } + function confirmExit(event) { + if (fieldsUpdated) { + event.preventDefault(); + event.returnValue = ''; + } + } + function offsetModalY($modal, amount) { + var position = { + my: 'top', + at: "top+".concat(amount), + of: window + }; + $modal.dialog('option', 'position', position); + } + + /** + * Get the input box for the selected icon or calculation field. + * + * @param {Element} moreIcon The icon element + * @return {Element} The associated input or textarea + */ + function getInputForIcon(moreIcon) { + if (moreIcon.classList.contains('frm-input-icon')) { + return moreIcon.previousElementSibling; + } + + // For regular fields + var input = moreIcon.nextElementSibling; + while (input && (input.tagName !== 'INPUT' && input.tagName !== 'TEXTAREA' || input.classList.contains('frm-token-input-field'))) { + input = getInputForIcon(input); + } + + // For calculation fields + if (!input) { + var _moreIcon$closest; + input = (_moreIcon$closest = moreIcon.closest('.frm-field-formula')) === null || _moreIcon$closest === void 0 ? void 0 : _moreIcon$closest.querySelector('.frm-calc-field'); + } + return input; + } + + /** + * Get the ... icon for the selected input box. + * @param {HTMLElement} input The input element. + */ + function getIconForInput(input) { + var _input$nextElementSib; + if ((_input$nextElementSib = input.nextElementSibling) !== null && _input$nextElementSib !== void 0 && _input$nextElementSib.classList.contains('frm-input-icon')) { + return input.nextElementSibling; + } + var moreIcon = input.previousElementSibling; + while (moreIcon !== null && moreIcon.tagName !== 'I' && moreIcon.tagName !== 'svg') { + moreIcon = getIconForInput(moreIcon); + } + return moreIcon; + } + function hideShortcodes(box) { + if (box === undefined) { + box = document.getElementById('frm_adv_info'); + if (!box) { + return; + } + } + if (document.getElementById('frm_dyncontent') !== null) { + // Don't run when in the sidebar. + return; + } + box.style.display = 'none'; + var closeIcons = document.querySelectorAll('.frm-show-box.frm_close_icon'); + for (var iconIndex = 0; iconIndex < closeIcons.length; iconIndex++) { + closeIcons[iconIndex].classList.remove('frm_close_icon'); + closeIcons[iconIndex].classList.add('frm_more_horiz_solid_icon'); + } + var closeSvg = document.querySelectorAll('.frm_has_shortcodes use'); + for (var svgIndex = 0; svgIndex < closeSvg.length; svgIndex++) { + if (getSVGHref(closeSvg[svgIndex]) === '#frm_close_icon') { + if (closeSvg[svgIndex].closest('.frm_remove_field')) { + // Don't change the icon for the email fields remove button. + continue; + } + closeSvg[svgIndex].setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_more_horiz_solid_icon'); + } + } + } + function toggleAllowedHTML(input) { + var id = input.id; + if (id === undefined || id.includes('-search-input')) { + return; + } + jQuery('#frm-adv-info-tab').attr('data-fills', id.trim()); + if (input.classList.contains('field_custom_html')) { + id = 'field_custom_html'; + } + var htmlFieldIds = ['after_html', 'before_html', 'submit_html', 'field_custom_html']; + if (jQuery.inArray(id, htmlFieldIds) >= 0) { + jQuery(".frm_code_list li:not(.show_".concat(id, ")")).addClass('frm_hidden'); + jQuery(".frm_code_list li.show_".concat(id)).removeClass('frm_hidden'); + } + } + function toggleKeyID(switchTo, e) { + e.stopPropagation(); + jQuery('.frm_code_list .frmids, .frm_code_list .frmkeys').addClass('frm_hidden'); + jQuery(".frm_code_list .".concat(switchTo)).removeClass('frm_hidden'); + jQuery('.frmids, .frmkeys').removeClass('current'); + jQuery(".".concat(switchTo)).addClass('current'); + } + function onActionLoaded(event) { + var settings = event.target.closest('.frm_form_action_settings'); + if (settings && (settings.classList.contains('frm_single_email_settings') || settings.classList.contains('frm_single_on_submit_settings'))) { + initWysiwygOnActionLoaded(settings); + } + } + function initWysiwygOnActionLoaded(settings) { + settings.querySelectorAll('.wp-editor-area').forEach(function (wysiwyg) { + frmDom.wysiwyg.init(wysiwyg, { + height: 160, + addFocusEvents: true + }); + }); + } + + /* Global settings page */ + function loadSettingsTab(anchor) { + var holder = anchor.replace('#', ''); + var holderContainer = jQuery(".frm_".concat(holder, "_ajax")); + if (holderContainer.length) { + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: 'frm_settings_tab', + tab: holder.replace('_settings', ''), + nonce: frmGlobal.nonce + }, + success: function success(html) { + holderContainer.replaceWith(html); + } + }); + } + } + function uninstallNow() { + /*jshint validthis:true */ + if (confirmLinkClick(this) === true) { + jQuery('.frm_uninstall .frm-wait').css('visibility', 'visible'); + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: "action=frm_uninstall&nonce=".concat(frmGlobal.nonce), + success: function success(msg) { + jQuery('.frm_uninstall').fadeOut('slow'); + window.location = msg; + } + }); + } + return false; + } + function saveAddonLicense() { + /*jshint validthis:true */ + var button = jQuery(this); + var buttonName = this.name; + var pluginSlug = this.getAttribute('data-plugin'); + var action = buttonName.replace("edd_".concat(pluginSlug, "_license_"), ''); + var license = document.getElementById("edd_".concat(pluginSlug, "_license_key")).value; + button.get(0).disabled = true; + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + dataType: 'json', + data: { + action: "frm_addon_".concat(action), + license: license, + plugin: pluginSlug, + nonce: frmGlobal.nonce + }, + success: function success(msg) { + button.get(0).disabled = false; + var thisRow = button.closest('.edd_frm_license_row'); + if (action === 'deactivate') { + license = ''; + document.getElementById("edd_".concat(pluginSlug, "_license_key")).value = ''; + } + thisRow.find('.edd_frm_license').html(license); + var eddWrapper = button.get(0).closest('.frm_form_field'); + var actionIsSuccess = msg.success === true; + eddWrapper.querySelector('.frm_icon_font.frm_action_success').classList.toggle('frm_hidden', !actionIsSuccess || action === 'deactivate'); + eddWrapper.querySelector('.frm_icon_font.frm_action_error').classList.toggle('frm_hidden', actionIsSuccess); + var messageBox = thisRow.find('.frm_license_msg'); + messageBox.html(msg.message); + if (msg.message !== '') { + setTimeout(function () { + messageBox.html(''); + thisRow.find('.frm_icon_font').addClass('frm_hidden'); + if (actionIsSuccess) { + var actionIsActivate = action === 'activate'; + thisRow.get(0).querySelector('.edd_frm_unauthorized').classList.toggle('frm_hidden', actionIsActivate); + thisRow.get(0).querySelector('.edd_frm_authorized').classList.toggle('frm_hidden', !actionIsActivate); + } + }, 2000); + } + } + }); + } + + /* Import/Export page */ + + function startFormMigration(event) { + event.preventDefault(); + var checkedBoxes = jQuery(event.target).find('input:checked'); + if (!checkedBoxes.length) { + return; + } + var ids = []; + checkedBoxes.each(function (i) { + ids[i] = this.value; + }); + + // Begin the import process. + importForms(ids, event.target); + } + + /** + * Begins the process of importing the forms. + * @param {Array} forms The form IDs to import. + * @param {HTMLElement} targetForm The form element that triggered the import. + */ + function importForms(forms, targetForm) { + // Hide the form select section. + var $form = jQuery(targetForm); + var $processSettings = $form.next('.frm-importer-process'); + + // Display total number of forms we have to import. + $processSettings.find('.form-total').text(forms.length); + $processSettings.find('.form-current').text('1'); + $form.hide(); + + // Show processing status. + // '.process-completed' might have been shown earlier during a previous import, so hide now. + $processSettings.find('.process-completed').hide(); + $processSettings.show(); + + // Create global import queue. + s.importQueue = forms; + s.imported = 0; + + // Import the first form in the queue. + importForm($processSettings); + } + + /** + * Imports a single form from the import queue. + * @param {jQuery} $processSettings The jQuery wrapped process settings element. + */ + function importForm($processSettings) { + var formID = s.importQueue[0]; + var provider = jQuery('#welcome-panel').find('input[name="slug"]').val(); + var data = { + action: "frm_import_".concat(provider), + form_id: formID, + nonce: frmGlobal.nonce + }; + + // Trigger AJAX import for this form. + jQuery.post(ajaxurl, data, function (res) { + if (res.success) { + var statusUpdate; + if (res.data.error) { + statusUpdate = "

        ".concat(res.data.name, ": ").concat(res.data.msg, "

        "); + } else { + statusUpdate = "

        Imported ").concat(res.data.name, "

        "); + } + $processSettings.find('.status').prepend(statusUpdate); + $processSettings.find('.status').show(); + + // Remove this form ID from the queue. + s.importQueue = jQuery.grep(s.importQueue, function (value) { + return value != formID; + }); + s.imported++; + if (s.importQueue.length === 0) { + $processSettings.find('.process-count').hide(); + $processSettings.find('.forms-completed').text(s.imported); + $processSettings.find('.process-completed').show(); + } else { + // Import next form in the queue. + $processSettings.find('.form-current').text(s.imported + 1); + importForm($processSettings); + } + } + }); + } + function validateExport(e) { + /*jshint validthis:true */ + e.preventDefault(); + var s = false; + var $exportForms = jQuery('input[name="frm_export_forms[]"]'); + if (!jQuery('input[name="frm_export_forms[]"]:checked').val()) { + $exportForms.closest('.frm-table-box').addClass('frm_blank_field'); + s = 'stop'; + } + var $exportType = jQuery('input[name="type[]"]'); + if (!jQuery('input[name="type[]"]:checked').val() && $exportType.attr('type') === 'checkbox') { + $exportType.closest('p').addClass('frm_blank_field'); + s = 'stop'; + } + if (s === 'stop') { + return false; + } + e.stopPropagation(); + this.submit(); + } + function removeExportError() { + /*jshint validthis:true */ + var t = jQuery(this).closest('.frm_blank_field'); + if (t === undefined) { + return; + } + var $thisName = this.name; + if ($thisName === 'type[]' && jQuery('input[name="type[]"]:checked').val()) { + t.removeClass('frm_blank_field'); + } else if ($thisName === 'frm_export_forms[]' && jQuery(this).val()) { + t.removeClass('frm_blank_field'); + } + } + function checkCSVExtension() { + /*jshint validthis:true */ + var f = jQuery(this).val(); + var re = /\.csv$/i; + if (f.match(re) !== null) { + jQuery('.show_csv').fadeIn(); + } else { + jQuery('.show_csv').fadeOut(); + } + } + function getExportOption() { + var exportFormatSelect = document.querySelector('select[name="format"]'); + if (exportFormatSelect) { + return exportFormatSelect.value; + } + return ''; + } + function exportTypeChanged(event) { + var value = event.target.value; + showOrHideRepeaters(value); + checkExportTypes.call(event.target); + checkSelectedAllFormsCheckbox(value); + } + function checkSelectedAllFormsCheckbox(exportType) { + var selectAllCheckbox = document.getElementById('frm-export-select-all'); + if (exportType === 'csv') { + selectAllCheckbox.checked = false; + selectAllCheckbox.disabled = true; + } else { + selectAllCheckbox.disabled = false; + } + } + function checkExportTypes() { + /*jshint validthis:true */ + var $dropdown = jQuery(this); + var $selected = $dropdown.find(':selected'); + var s = $selected.data('support'); + var multiple = s.indexOf('|'); + jQuery('input[name="type[]"]').each(function () { + this.checked = false; + if (s.includes(this.value)) { + this.disabled = false; + if (multiple === -1) { + this.checked = true; + } + } else { + this.disabled = true; + } + }); + if ($dropdown.val() === 'csv') { + jQuery('.csv_opts').show(); + jQuery('.xml_opts').hide(); + } else { + jQuery('.csv_opts').hide(); + jQuery('.xml_opts').show(); + } + var c = $selected.data('count'); + var exportField = jQuery('input[name="frm_export_forms[]"]'); + if (c === 'single') { + exportField.prop('multiple', false); + exportField.prop('checked', false); + } else { + exportField.prop('multiple', true); + exportField.prop('disabled', false); + } + $dropdown.trigger('change'); + } + function showOrHideRepeaters(exportOption) { + if (exportOption === '') { + return; + } + var repeaters = document.querySelectorAll('.frm-is-repeater'); + if (!repeaters.length) { + return; + } + if (exportOption === 'csv') { + repeaters.forEach(function (form) { + form.classList.remove('frm_hidden'); + }); + } else { + repeaters.forEach(function (form) { + form.classList.add('frm_hidden'); + }); + } + searchContent.call(document.querySelector('.frm-auto-search')); + } + function preventMultipleExport() { + var type = jQuery('select[name=format]'); + var selected = type.find(':selected'); + var count = selected.data('count'); + var exportField = jQuery('input[name="frm_export_forms[]"]'); + if (count === 'single') { + // Disable all other fields to prevent multiple selections. + if (this.checked) { + exportField.prop('disabled', true); + this.removeAttribute('disabled'); + } else { + exportField.prop('disabled', false); + } + } else { + exportField.prop('disabled', false); + } + } + function initiateMultiselect() { + jQuery('.frm_multiselect').hide().each(frmDom.bootstrap.multiselect.init); + } + + /* Addons page */ + function installMultipleAddons(e) { + e.preventDefault(); + toggleAddonState(this, 'frm_multiple_addons'); + } + function activateAddon(e) { + e.preventDefault(); + toggleAddonState(this, 'frm_activate_addon'); + } + function installAddon(e) { + e.preventDefault(); + toggleAddonState(this, 'frm_install_addon'); + } + function toggleAddonState(clicked, action) { + var addonState = __webpack_require__(/*! ./addon-state */ "./js/src/admin/addon-state.js"); + addonState.toggleAddonState(clicked, action); + } + + /* Templates */ + function showActiveCampaignForm() { + loadApiEmailForm(); + } + function handleApiFormError(inputId, errorId, type, message) { + var $error = jQuery(errorId); + $error.removeClass('frm_hidden').attr('frm-error', type); + if (message !== undefined) { + $error.find("span[frm-error=\"".concat(type, "\"]")).text(message); + } + jQuery(inputId).one('keyup', function () { + $error.addClass('frm_hidden'); + }); + } + function handleEmailAddressError(type) { + handleApiFormError('#frm_leave_email', '#frm_leave_email_error', type); + } + function loadApiEmailForm() { + var formContainer = document.getElementById('frmapi-email-form'); + jQuery.ajax({ + dataType: 'json', + url: formContainer.getAttribute('data-url'), + success: function success(json) { + var form = json.renderedHtml; + form = form.replace(/]*(formidableforms.css|action=frmpro_css)[^>]*>/gi, ''); + formContainer.innerHTML = form; + } + }); + } + function initAutocomplete(container) { + frmDom.autocomplete.initSelectionAutocomplete(container); + } + function nextInstallStep(thisStep) { + thisStep.classList.add('frm_grey'); + thisStep.nextElementSibling.classList.remove('frm_grey'); + } + function installTemplateFieldset(e) { + /*jshint validthis:true */ + var fieldset = this.parentNode.parentNode; + var action = fieldset.elements.type.value; + var button = this; + e.preventDefault(); + button.classList.add('frm_loading_button'); + installNewForm(fieldset, action, button); + } + function installTemplate(e) { + /*jshint validthis:true */ + var action = this.elements.type.value; + var button = this.querySelector('button'); + e.preventDefault(); + button.classList.add('frm_loading_button'); + installNewForm(this, action, button); + } + function installNewForm(form, action, button) { + var formData = formToData(form); + var formName = formData.template_name; + var formDesc = formData.template_desc; + var link = form.elements.link.value; + var data = { + action: action, + xml: link, + name: formName, + desc: formDesc, + form: JSON.stringify(formData), + nonce: frmGlobal.nonce + }; + var hookName = 'frm_before_install_new_form'; + var filterArgs = { + formData: formData + }; + data = wp.hooks.applyFilters(hookName, data, filterArgs); + postAjax(data, function (response) { + if (response.redirect !== undefined) { + var redirect = response.redirect; + if (form.elements.redirect === undefined) { + window.location = redirect; + } else { + var href = document.getElementById('frm-redirect-link'); + if (link !== undefined && href) { + // Show the next installation step. + href.setAttribute('href', redirect); + href.classList.remove('frm_grey', 'disabled'); + nextInstallStep(form.parentNode.parentNode); + button.classList.add('frm_grey', 'disabled'); + } + } + } else { + jQuery('.spinner').css('visibility', 'hidden'); + + // Show response.message + if ('string' === typeof response.message) { + showInstallFormErrorModal(response.message); + } + } + button.classList.remove('frm_loading_button'); + }); + } + function showInstallFormErrorModal(message) { + var modalContent = div(message); + modalContent.style.padding = '20px 40px'; + var modal = frmDom.modal.maybeCreateModal('frmInstallFormErrorModal', { + title: __('Unable to install template', 'formidable'), + content: modalContent + }); + modal.classList.add('frm_common_modal'); + } + function handleCaptchaTypeChange(e) { + var thresholdContainer = document.getElementById('frm_captcha_threshold_container'); + if (thresholdContainer) { + thresholdContainer.classList.toggle('frm_hidden', 'v3' !== e.target.value); + } + } + function trashTemplate(e) { + /*jshint validthis:true */ + var id = this.getAttribute('data-id'); + e.preventDefault(); + var data = { + action: 'frm_forms_trash', + id: id, + nonce: frmGlobal.nonce + }; + postAjax(data, function () { + var card = document.getElementById("frm-template-custom-".concat(id)); + fadeOut(card, function () { + card.remove(); + }); + }); + } + function searchContent() { + /*jshint validthis:true */ + var i; + var regEx = false; + var searchText = this.value.toLowerCase(); + var toSearch = this.getAttribute('data-tosearch'); + var items = document.getElementsByClassName(toSearch); + if (this.tagName === 'SELECT') { + searchText = selectedOptions(this); + searchText = searchText.join('|').toLowerCase(); + regEx = true; + } + if (toSearch === 'frm-action' && searchText !== '') { + var addons = document.getElementById('frm_email_addon_menu').classList; + addons.remove('frm-all-actions'); + addons.add('frm-limited-actions'); + } + for (i = 0; i < items.length; i++) { + var innerText = items[i].innerText.toLowerCase(); + var itemCanBeShown = !(getExportOption() === 'xml' && items[i].classList.contains('frm-is-repeater')); + if (searchText === '') { + if (itemCanBeShown && checkContextualShortcode(items[i])) { + items[i].classList.remove('frm_hidden'); + } + items[i].classList.remove('frm-search-result'); + } else if (regEx && new RegExp(searchText).test(innerText) || innerText.includes(searchText) || textMatchesPlural(innerText, searchText)) { + if (itemCanBeShown && checkContextualShortcode(items[i])) { + items[i].classList.remove('frm_hidden'); + } + items[i].classList.add('frm-search-result'); + } else { + items[i].classList.add('frm_hidden'); + items[i].classList.remove('frm-search-result'); + } + } + + // Updates the visibility of category headings based on search results. + updateCatHeadingVisibility(); + jQuery(this).trigger('frmAfterSearch'); + } + + /** + * Allow a search for "signatures" to still match "signature" for example when searching fields. + * + * @since 6.15 + * + * @param {string} text The text in the element we are checking for a match. + * @param {string} searchText The text value that is being searched. + * @return {boolean} True if the text matches when pluralized. + */ + function textMatchesPlural(text, searchText) { + if (searchText === 's') { + // Don't match everything when just "s" is searched. + return false; + } + if (text[text.length - 1] === 's') { + // Do not match something with double s if the text already ends in s. + return false; + } + return "".concat(text, "s").includes(searchText); + } + + /** + * Updates the visibility of category headings based on search results. + * If all associated fields are hidden (indicating no search matches), + * the heading is hidden. + * + * @since 6.4.1 + */ + function updateCatHeadingVisibility() { + var insertFieldsElement = document.querySelector('#frm-insert-fields'); + if (!insertFieldsElement) { + return; + } + var headingElements = insertFieldsElement.querySelectorAll(':scope > .frm-with-line'); + headingElements.forEach(function (heading) { + var fieldsListElement = heading.nextElementSibling; + if (!fieldsListElement) { + return; + } + var listItemElements = fieldsListElement.querySelectorAll(':scope > li.frmbutton'); + var allHidden = Array.from(listItemElements).every(function (li) { + return li.classList.contains('frm_hidden'); + }); + + // Add or remove class based on `allHidden` condition + heading.classList.toggle('frm_hidden', allHidden); + }); + } + function stopPropagation(e) { + e.stopPropagation(); + } + + /* Helpers */ + + function selectedOptions(select) { + var opt; + var result = []; + var options = select === null || select === void 0 ? void 0 : select.options; + for (var i = 0, iLen = options === null || options === void 0 ? void 0 : options.length; i < iLen; i++) { + opt = options[i]; + if (opt.selected) { + result.push(opt.value); + } + } + return result; + } + function triggerEvent(element, event) { + var evt = document.createEvent('HTMLEvents'); + evt.initEvent(event, false, true); + element.dispatchEvent(evt); + } + function postAjax(data, success) { + var response; + var xmlHttp = new XMLHttpRequest(); + var params = typeof data === 'string' ? data : Object.keys(data).map(function (k) { + return "".concat(encodeURIComponent(k), "=").concat(encodeURIComponent(data[k])); + }).join('&'); + xmlHttp.open('post', ajaxurl, true); + xmlHttp.onreadystatechange = function () { + if (xmlHttp.readyState > 3 && xmlHttp.status == 200) { + response = xmlHttp.responseText; + try { + response = JSON.parse(response); + } catch (e) { + // The response may not be JSON, so just return it. + } + success(response); + } + }; + xmlHttp.setRequestHeader('X-Requested-With', 'XMLHttpRequest'); + xmlHttp.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); + xmlHttp.send(params); + return xmlHttp; + } + function fadeOut(element, success) { + element.classList.add('frm-fade'); + setTimeout(success, 1000); + } + function invisible(classes) { + jQuery(classes).css('visibility', 'hidden'); + } + function visible(classes) { + jQuery(classes).css('visibility', 'visible'); + } + function initModal(id, width) { + var upgradePopup = __webpack_require__(/*! ./upgrade-popup */ "./js/src/admin/upgrade-popup.js"); + return upgradePopup.initModal(id, width); + } + function toggle(cname, id) { + if (id === '#') { + var cont = document.getElementById(cname); + var hidden = cont.style.display; + if (hidden === 'none') { + cont.style.display = 'block'; + } else { + cont.style.display = 'none'; + } + } else { + var vis = cname.is(':visible'); + if (vis) { + cname.hide(); + } else { + cname.show(); + } + } + } + function removeWPUnload() { + window.onbeforeunload = null; + var w = jQuery(window); + w.off('beforeunload.widgets'); + w.off('beforeunload.edit-post'); + } + function addMultiselectLabelListener() { + var clickListener = function clickListener(e) { + if ('LABEL' !== e.target.nodeName) { + return; + } + var labelFor = e.target.getAttribute('for'); + if (!labelFor) { + return; + } + var input = document.getElementById(labelFor); + if (!input || !input.nextElementSibling) { + return; + } + var buttonToggle = input.nextElementSibling.querySelector('button.dropdown-toggle.multiselect'); + if (!buttonToggle) { + return; + } + var triggerMultiselectClick = function triggerMultiselectClick() { + return buttonToggle.click(); + }; + setTimeout(triggerMultiselectClick, 0); + }; + document.addEventListener('click', clickListener); + } + function maybeChangeEmbedFormMsg() { + var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); + var fieldItem = document.getElementById("frm_field_id_".concat(fieldId)); + if (!fieldItem || 'form' !== fieldItem.dataset.type) { + return; + } + fieldItem = jQuery(fieldItem); + if (this.options[this.selectedIndex].value) { + fieldItem.find('.frm-not-set')[0].classList.add('frm_hidden'); + var embedMsg = fieldItem.find('.frm-embed-message'); + embedMsg.html(embedMsg.data('embedmsg') + this.options[this.selectedIndex].text); + fieldItem.find('.frm-embed-field-placeholder')[0].classList.remove('frm_hidden'); + } else { + fieldItem.find('.frm-not-set')[0].classList.remove('frm_hidden'); + fieldItem.find('.frm-embed-field-placeholder')[0].classList.add('frm_hidden'); + } + } + function toggleProductType() { + var settings = jQuery(this).closest('.frm-single-settings'); + var container = settings.find('.frmjs_product_choices'); + var heading = settings.find('.frm_prod_options_heading'); + var currentVal = this.options[this.selectedIndex].value; + container.removeClass('frm_prod_type_single frm_prod_type_user_def'); + heading.removeClass('frm_prod_user_def'); + if ('single' === currentVal) { + container.addClass('frm_prod_type_single'); + } else if ('user_def' === currentVal) { + container.addClass('frm_prod_type_user_def'); + heading.addClass('frm_prod_user_def'); + } + } + + /** + * @param {number | string} fieldId + * @return {boolean} True if the field is a product field. + */ + function isProductField(fieldId) { + var field = document.getElementById("frm_field_id_".concat(fieldId)); + if (!field) { + return false; + } + return 'product' === field.getAttribute('data-type'); + } + + /** + * Serialize form data with vanilla JS. + * @param {HTMLElement} form The form element to serialize. + */ + function formToData(form) { + var subKey; + var i; + var object = {}; + var formData = form.elements; + for (i = 0; i < formData.length; i++) { + var input = formData[i]; + var key = input.name; + var value = input.value; + var names = key.match(/(.*)\[(.*)\]/); + if ((input.type === 'radio' || input.type === 'checkbox') && !input.checked) { + continue; + } + if (names !== null) { + key = names[1]; + subKey = names[2]; + if (!Reflect.has(object, key)) { + object[key] = {}; + } + object[key][subKey] = value; + continue; + } + + // Reflect.has in favor of: object.hasOwnProperty(key) + if (!Reflect.has(object, key)) { + object[key] = value; + continue; + } + if (!Array.isArray(object[key])) { + object[key] = [object[key]]; + } + object[key].push(value); + } + return object; + } + + /** + * Show, hide, and sort subfields of Name field on form builder. + * + * @since 4.11 + */ + function handleNameFieldOnFormBuilder() { + /** + * Gets subfield element from cache. + * + * @param {string} fieldId Field ID. + * @param {string} key Cache key. + * @return {HTMLElement|undefined} Return the element from cache or undefined if not found. + */ + var getSubFieldElFromCache = function getSubFieldElFromCache(fieldId, key) { + window.frmCachedSubFields = window.frmCachedSubFields || {}; + window.frmCachedSubFields[fieldId] = window.frmCachedSubFields[fieldId] || {}; + return window.frmCachedSubFields[fieldId][key]; + }; + + /** + * Sets subfield element to cache. + * + * @param {string} fieldId Field ID. + * @param {string} key Cache key. + * @param {HTMLElement} el Element. + */ + var setSubFieldElToCache = function setSubFieldElToCache(fieldId, key, el) { + window.frmCachedSubFields = window.frmCachedSubFields || {}; + window.frmCachedSubFields[fieldId] = window.frmCachedSubFields[fieldId] || {}; + window.frmCachedSubFields[fieldId][key] = el; + }; + + /** + * Gets column class from the number of columns. + * + * @param {number} colCount Number of columns. + * @return {string} The column CSS class name. + */ + var getColClass = function getColClass(colCount) { + return "frm".concat(parseInt(12 / colCount)); + }; + var colClasses = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12].map(function (num) { + return "frm".concat(num); + }); + var allSubFieldNames = ['first', 'middle', 'last']; + + /** + * Handles name layout change. + * + * @param {Event} event Event object. + */ + var onChangeLayout = function onChangeLayout(event) { + var value = event.target.value; + var subFieldNames = value.split('_'); + var fieldId = event.target.dataset.fieldId; + + /* + * Live update form on the form builder. + */ + var container = document.querySelector("#field_".concat(fieldId, "_inner_container .frm_combo_inputs_container")); + var newColClass = getColClass(subFieldNames.length); + + // Set all sub field elements to cache and hide all of them first. + allSubFieldNames.forEach(function (name) { + var subFieldEl = container.querySelector("[data-sub-field-name=\"".concat(name, "\"]")); + if (subFieldEl) { + var _subFieldEl$classList; + subFieldEl.classList.add('frm_hidden'); + (_subFieldEl$classList = subFieldEl.classList).remove.apply(_subFieldEl$classList, _toConsumableArray(colClasses)); + setSubFieldElToCache(fieldId, name, subFieldEl); + } + }); + subFieldNames.forEach(function (subFieldName) { + var subFieldEl = getSubFieldElFromCache(fieldId, subFieldName); + if (!subFieldEl) { + return; + } + subFieldEl.classList.remove('frm_hidden'); + subFieldEl.classList.add(newColClass); + container.append(subFieldEl); + }); + + /* + * Live update subfield options. + */ + // Hide all subfield options. + allSubFieldNames.forEach(function (name) { + var optionsEl = document.querySelector(".frm_sub_field_options-".concat(name, "[data-field-id=\"").concat(fieldId, "\"]")); + if (optionsEl) { + optionsEl.classList.add('frm_hidden'); + setSubFieldElToCache(fieldId, "".concat(name, "_options"), optionsEl); + } + }); + subFieldNames.forEach(function (subFieldName) { + var optionsEl = getSubFieldElFromCache(fieldId, "".concat(subFieldName, "_options")); + if (!optionsEl) { + return; + } + optionsEl.classList.remove('frm_hidden'); + }); + }; + var dropdownSelector = '.frm_name_layout_dropdown'; + document.addEventListener('change', function (event) { + if (event.target.matches(dropdownSelector)) { + onChangeLayout(event); + } + }, false); + } + function debounce(func) { + var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100; + return frmDom.util.debounce(func, wait); + } + function addSaveAndDragIconsToOption(fieldId, liObject) { + var li; + var useTag; + var useTagHref; + var hasDragIcon = false; + var hasSaveIcon = false; + if (liObject.newOption) { + var parser = new DOMParser(); + li = parser.parseFromString(liObject.newOption, 'text/html').body.childNodes[0]; + } else { + li = liObject; + } + var liIcons = li.querySelectorAll('svg'); + liIcons.forEach(function (svg) { + useTag = svg.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'use')[0]; + if (!useTag) { + return; + } + useTagHref = getSVGHref(useTag); + if (useTagHref === '#frm_drag_icon') { + hasDragIcon = true; + } + if (useTagHref === '#frm_save_icon') { + hasSaveIcon = true; + } + }); + if (!hasDragIcon) { + li.prepend(icons.drag.cloneNode(true)); + } + if (li.querySelector("[id^=field_key_".concat(fieldId, "-]")) && !hasSaveIcon) { + li.querySelector("[id^=field_key_".concat(fieldId, "-]")).after(icons.save.cloneNode(true)); + } + if (liObject.newOption) { + liObject.newOption = li; + } + } + function maybeAddSaveAndDragIcons(fieldId) { + var fieldOptions = document.querySelectorAll("[id^=frm_delete_field_".concat(fieldId, "-]")); + // return if there are no options. + if (fieldOptions.length < 2) { + return; + } + var options = _toConsumableArray(fieldOptions).slice(1); + options.forEach(function (li, _key) { + if (li.classList.contains('frm_other_option')) { + return; + } + addSaveAndDragIconsToOption(fieldId, li); + }); + } + + /** + * Enforce the maximum number of entries list columns dynamically. + * + * @since 6.24 + * + * @return {void} + */ + function maybeInitEntriesListPage() { + if (!document.body.classList.contains('frm-admin-page-entries')) { + return; + } + var screenOptionsWrapper = document.getElementById('screen-options-wrap'); + if (!screenOptionsWrapper) { + return; + } + var maxSelectionsNote = div({ + className: 'frm_warning_style', + text: __('Only 10 columns can be selected at a time.', 'formidable') + }); + maxSelectionsNote.style.margin = 0; + var legend = screenOptionsWrapper.querySelector('legend'); + legend.parentNode.insertBefore(maxSelectionsNote, legend.nextElementSibling); + var checkboxes = Array.from(screenOptionsWrapper.querySelectorAll('input[type="checkbox"]')); + var maximumColumns = 10; + var getSelectedCount = function getSelectedCount() { + return checkboxes.reduce(function (count, checkbox) { + return checkbox.checked ? count + 1 : count; + }, 0); + }; + var disableCheckboxesIfAtMax = function disableCheckboxesIfAtMax() { + if (getSelectedCount() >= maximumColumns) { + maxSelectionsNote.classList.remove('frm_hidden'); + checkboxes.forEach(function (checkbox) { + if (!checkbox.checked) { + checkbox.parentNode.classList.add('frm_noallow'); + checkbox.disabled = true; + } + }); + } else { + maxSelectionsNote.classList.add('frm_hidden'); + } + }; + var addCheckboxListeners = function addCheckboxListeners() { + checkboxes.forEach(function (checkbox) { + checkbox.addEventListener('change', function (event) { + if (event.target.checked) { + disableCheckboxesIfAtMax(); + } else { + maxSelectionsNote.classList.add('frm_hidden'); + + // Enable all checkboxes when a checkbox is unchecked. + checkboxes.forEach(function (checkbox) { + checkbox.parentNode.classList.remove('frm_noallow'); + checkbox.disabled = false; + }); + } + }); + }); + }; + disableCheckboxesIfAtMax(); + addCheckboxListeners(); + } + function initOnSubmitAction() { + var onChangeType = function onChangeType(event) { + if (!event.target.checked) { + return; + } + var actionEl = event.target.closest('.frm_form_action_settings'); + actionEl.querySelectorAll('.frm_on_submit_dependent_setting:not(.frm_hidden)').forEach(function (el) { + el.classList.add('frm_hidden'); + }); + var activeEls = actionEl.querySelectorAll(".frm_on_submit_dependent_setting[data-show-if-".concat(event.target.value, "]")); + activeEls.forEach(function (activeEl) { + activeEl.classList.remove('frm_hidden'); + }); + actionEl.setAttribute('data-on-submit-type', event.target.value); + }; + frmDom.util.documentOn('change', '.frm_on_submit_type input[type="radio"]', onChangeType); + } + + /** + * Listen for click events for an API-loaded email collection form. + * + * This is used for the Active Campaign sign-up form in the inbox page (when there are no messages). + */ + function initAddMyEmailAddress() { + jQuery(document).on('click', '#frm-add-my-email-address', function (event) { + event.preventDefault(); + addMyEmailAddress(); + }); + var emptyInbox = document.getElementById('frm_empty_inbox'); + var leaveEmailInput = document.getElementById('frm_leave_email'); + if (emptyInbox && leaveEmailInput) { + var leaveEmailModal = document.getElementById('frm-leave-email-modal'); + leaveEmailModal.classList.remove('frm_hidden'); + leaveEmailModal.querySelector('.frm_modal_footer').classList.add('frm_hidden'); + leaveEmailInput.addEventListener('keyup', function (event) { + if ('Enter' === event.key) { + var button = document.getElementById('frm-add-my-email-address'); + if (button) { + button.click(); + } + } + }); + } + } + function addMyEmailAddress() { + var email = document.getElementById('frm_leave_email').value.trim(); + if ('' === email) { + handleEmailAddressError('empty'); + return; + } + var regex = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i; + if (regex.test(email) === false) { + handleEmailAddressError('invalid'); + return; + } + var $hiddenForm = jQuery('#frmapi-email-form').find('form'); + var $hiddenEmailField = $hiddenForm.find('[type="email"]').not('.frm_verify'); + if (!$hiddenEmailField.length) { + return; + } + var emptyInbox = document.getElementById('frm_empty_inbox'); + if (emptyInbox) { + document.getElementById('frm-add-my-email-address').remove(); + var emailWrapper = document.getElementById('frm_leave_email_wrapper'); + if (emailWrapper) { + emailWrapper.classList.add('frm_hidden'); + var spinner = span({ + className: 'frm-wait frm_spinner' + }); + spinner.style.visibility = 'visible'; + spinner.style.float = 'none'; + spinner.style.width = 'unset'; + emailWrapper.parentElement.insertBefore(spinner, emailWrapper.nextElementSibling); + } + } + $hiddenEmailField.val(email); + jQuery.ajax({ + type: 'POST', + url: $hiddenForm.attr('action'), + data: "".concat($hiddenForm.serialize(), "&action=frm_forms_preview") + }).done(function (data) { + var message = jQuery(data).find('.frm_message').text().trim(); + if (!message.includes('Thanks!')) { + handleEmailAddressError('invalid'); + return; + } + var apiForm = document.getElementById('frmapi-email-form'); + var spinner = apiForm.parentElement.querySelector('.frm_spinner'); + if (spinner) { + spinner.remove(); + } + var showSuccessMessage = wp.hooks.applyFilters('frm_thank_you_on_signup', true); + if (showSuccessMessage) { + // Handle successful form submission. + // handle the Active Campaign form on the inbox page. + document.getElementById('frm_leave_email_wrapper').replaceWith(span(__('Thank you for signing up!', 'formidable'))); + } + }); + } + + /** + * Adds footer links to the admin body content. + * + * @return {void} + */ + function addAdminFooterLinks() { + var _document$querySelect7; + var footerLinks = document.querySelector('.frm-admin-footer-links'); + var container = (_document$querySelect7 = document.querySelector('.frm_page_container')) !== null && _document$querySelect7 !== void 0 ? _document$querySelect7 : document.getElementById('wpbody-content'); + if (!footerLinks || !container) { + return; + } + container.append(footerLinks); + footerLinks.classList.remove('frm_hidden'); + } + + /** + * Apply zebra striping to a table while ignoring empty rows. + * + * @param {string} tableSelector The CSS selector for the table. + * @param {string} emptyRowClass The class name used to identify empty rows. + */ + function applyZebraStriping(tableSelector, emptyRowClass) { + // Get all non-empty table rows within the specified table + var rows = document.querySelectorAll("".concat(tableSelector, " tr").concat(emptyRowClass ? ":not(.".concat(emptyRowClass, ")") : '')); + if (rows.length < 1) { + return; + } + var isOdd = true; + rows.forEach(function (row) { + // Clean old "frm-odd" or "frm-even" classes and add the appropriate new class + row.classList.remove('frm-odd', 'frm-even'); + row.classList.add(isOdd ? 'frm-odd' : 'frm-even'); + isOdd = !isOdd; + }); + var tables = document.querySelectorAll(tableSelector); + tables.forEach(function (table) { + return table.classList.add('frm-zebra-striping'); + }); + } + function maybeHideShortcodes(e) { + var _e$target$parentEleme; + if (!builderPage) { + e.stopPropagation(); + } + if (e.target.classList.contains('frm-show-box') || (_e$target$parentEleme = e.target.parentElement) !== null && _e$target$parentEleme !== void 0 && _e$target$parentEleme.classList.contains('frm-show-box')) { + return; + } + var sidebar = document.getElementById('frm_adv_info'); + if (!sidebar) { + return; + } + if (sidebar.dataset.fills === e.target.id && e.target.id !== undefined) { + return; + } + var isChild = e.target.closest('#frm_adv_info'); + if (!isChild && sidebar.style.display !== 'none') { + hideShortcodes(sidebar); + } + } + + /** + * Initializes and manages the visibility of dependent elements based on the selected options in dropdowns with the 'frm_select_with_dependency' class. + * It sets up initial visibility at page load and updates it on each dropdown change. + * + * @since 6.9 + * + * @return {void} + */ + function initSelectDependencies() { + var selects = document.querySelectorAll('select.frm_select_with_dependency'); + + /** + * Toggles the visibility of dependent elements associated with a select element based on its current selection. + * + * @since 6.9 + * + * @param {HTMLElement} select The select element whose dependencies need to be managed. + * @return {void} + */ + function toggleDependencyVisibility(select) { + var selectedOption = select.options[select.selectedIndex]; + select.querySelectorAll('option[data-dependency]:not([data-dependency-skip])').forEach(function (option) { + var dependencyElement = document.querySelector(option.dataset.dependency); + dependencyElement === null || dependencyElement === void 0 || dependencyElement.classList.toggle('frm_hidden', selectedOption !== option); + }); + } + + // Initial setup: Show dependencies based on the current selection in each dropdown + selects.forEach(toggleDependencyVisibility); + + // Update dependencies visibility on dropdown change + frmDom.util.documentOn('change', 'select.frm_select_with_dependency', function (event) { + return toggleDependencyVisibility(event.target); + }); + } + + /** + * Moves the focus to the next single option input field in the list and positions the cursor at the end of the text. + * + * @param {HTMLElement} currentInput The currently focused input element. + */ + function focusNextSingleOptionInput(currentInput) { + var optionsList = currentInput.closest('.frm_single_option').parentElement; + var inputs = optionsList.querySelectorAll('.frm_single_option input[name^="field_options[" ], .frm_single_option input[name^="rows_"]'); + var inputsArray = Array.from(inputs); + + // Find the index of the currently focused input + var currentIndex = inputsArray.indexOf(currentInput); + if (currentIndex < 0) { + return; + } + + // Find the next visible input field + var nextInput = inputsArray.slice(currentIndex + 1).find(function (input) { + return input.offsetParent !== null; + }); + if (nextInput) { + nextInput.focus(); + + // Move the cursor to the end of the text in the next input field + var textLength = nextInput.value.length; + nextInput.setSelectionRange(textLength, textLength); + } + } + return { + init: function init() { + initAddMyEmailAddress(); + addAdminFooterLinks(); + document.addEventListener('show.bs.dropdown', function () { + // Fixes issues with tooltips lingering after a dropdown is shown. + deleteTooltips(); + }); + s = {}; + + // Bootstrap dropdown button + jQuery('.wp-admin').on('click', function (e) { + var t = jQuery(e.target); + var $openDrop = jQuery('.dropdown.open'); + if ($openDrop.length && !t.hasClass('dropdown') && !t.closest('.dropdown').length) { + $openDrop.removeClass('open'); + } + }); + jQuery('#frm_bs_dropdown:not(.open) a').on('click', focusSearchBox); + if (thisFormId === undefined) { + thisFormId = jQuery(document.getElementById('form_id')).val(); + } + + // Add event listener for dismissible warning messages. + document.querySelectorAll('.frm-warning-dismiss').forEach(function (dismissIcon) { + onClickPreventDefault(dismissIcon, dismissWarningMessage); + }); + frmAdminBuild.inboxBannerInit(); + if ($newFields.length > 0) { + // only load this on the form builder page + frmAdminBuild.buildInit(); + } else if (document.getElementById('frm_notification_settings') !== null) { + // only load on form settings page + frmAdminBuild.settingsInit(); + } else if (document.getElementById('frm_styling_form') !== null) { + // load styling settings js + frmAdminBuild.styleInit(); + } else if (document.getElementById('form_global_settings') !== null) { + // global settings page + frmAdminBuild.globalSettingsInit(); + } else if (document.getElementById('frm_export_xml') !== null) { + // import/export page + frmAdminBuild.exportInit(); + } else if (null !== document.querySelector('.frm-inbox-wrapper')) { + // Dashboard page inbox. + frmAdminBuild.inboxInit(); + } else if (document.getElementById('frm-welcome') !== null) { + // Solution install page + frmAdminBuild.solutionInit(); + } else { + maybeInitEntriesListPage(); + initAutocomplete(); + jQuery('[data-frmprint]').on('click', function () { + window.print(); + return false; + }); + } + jQuery(document).on('change', 'select[data-toggleclass], input[data-toggleclass]', toggleFormOpts); + initSelectDependencies(); + var $advInfo = jQuery(document.getElementById('frm_adv_info')); + if ($advInfo.length > 0 || jQuery('.frm_field_list').length > 0) { + // only load on the form, form settings, and view settings pages + frmAdminBuild.panelInit(); + } + loadTooltips(); + initUpgradeModal(); + frmDom.util.documentOn('click', '[data-modal-title]', showBasicModal); + + // used on build, form settings, and view settings + var $shortCodeDiv = jQuery(document.getElementById('frm_shortcodediv')); + if ($shortCodeDiv.length > 0) { + jQuery('a.edit-frm_shortcode').on('click', function () { + if ($shortCodeDiv.is(':hidden')) { + $shortCodeDiv.slideDown('fast'); + this.style.display = 'none'; + } + return false; + }); + jQuery('.cancel-frm_shortcode', '#frm_shortcodediv').on('click', function () { + $shortCodeDiv.slideUp('fast'); + $shortCodeDiv.siblings('a.edit-frm_shortcode').show(); + return false; + }); + } + + // tabs + jQuery(document).on('click', '#frm-nav-tabs a', clickNewTab); + jQuery('.post-type-frm_display .frm-nav-tabs a, .frm-category-tabs a').on('click', function () { + var showUpgradeTab = this.classList.contains('frm_show_upgrade_tab'); + if (this.classList.contains('frm_noallow') && !showUpgradeTab) { + return; + } + if (showUpgradeTab) { + populateUpgradeTab(this); + } + clickTab(this); + return false; + }); + clickTab(jQuery('.starttab a'), 'auto'); + + // submit the search form with dropdown + jQuery(document).on('click', '#frm-fid-search-menu a', function () { + var val = this.id.replace('fid-', ''); + jQuery('select[name="fid"]').val(val); + triggerSubmit(document.getElementById('posts-filter')); + return false; + }); + jQuery('.frm_select_box').on('click focus', function () { + this.select(); + }); + jQuery(document).on('input search change', '.frm-auto-search:not(#frm-form-templates-page #template-search-input)', searchContent); + jQuery(document).on('focusin click', '.frm-auto-search', stopPropagation); + var autoSearch = jQuery('.frm-auto-search'); + if (autoSearch.val() !== '') { + autoSearch.trigger('keyup'); + } + + // Initialize Formidable Connection. + FrmFormsConnect.init(); + jQuery(document).on('click', '.frm-install-addon', installAddon); + jQuery(document).on('click', '.frm-activate-addon', activateAddon); + jQuery(document).on('click', '.frm-solution-multiple', installMultipleAddons); + + // prevent annoying confirmation message from WordPress + jQuery('button, input[type=submit]').on('click', removeWPUnload); + addMultiselectLabelListener(); + frmAdminBuild.hooks.addFilter('frm_before_embed_modal', function (ids, _ref4) { + var element = _ref4.element, + type = _ref4.type; + if ('form' !== type) { + return ids; + } + var formId; + var formKey; + var row = element.closest('tr'); + if (row) { + // Embed icon on form index. + formId = parseInt(row.querySelector('.column-id').textContent); + formKey = row.querySelector('.column-form_key').textContent; + } else { + // Embed button in form builder / form settings. + formId = document.getElementById('form_id').value; + var formKeyInput = document.getElementById('frm_form_key'); + if (formKeyInput) { + formKey = formKeyInput.value; + } else { + var previewDrop = document.getElementById('frm-previewDrop'); + if (previewDrop) { + formKey = previewDrop.nextElementSibling.querySelector('.dropdown-item a').getAttribute('href').split('form=')[1]; + } + } + } + return [formId, formKey]; + }); + document.querySelectorAll('#frm-show-fields > li, .frm_grid_container li').forEach(function (el, _key) { + el.addEventListener('click', function () { + var _this$querySelector; + var fieldId = ((_this$querySelector = this.querySelector('li')) === null || _this$querySelector === void 0 ? void 0 : _this$querySelector.dataset.fid) || this.dataset.fid; + maybeAddSaveAndDragIcons(fieldId); + }); + }); + var smallScreenProceedButton = document.getElementById('frm_small_screen_proceed_button'); + if (smallScreenProceedButton) { + onClickPreventDefault(smallScreenProceedButton, function () { + var _document$getElementB5; + (_document$getElementB5 = document.getElementById('frm_small_device_message_container')) === null || _document$getElementB5 === void 0 || _document$getElementB5.remove(); + doJsonPost('small_screen_proceed', new FormData()); + }); + } + var saleBanner = document.getElementById('frm_sale_banner'); + var saleDismiss = saleBanner === null || saleBanner === void 0 ? void 0 : saleBanner.querySelector('.dismiss'); + if (saleBanner) { + onClickPreventDefault(saleBanner, function (event) { + var target = event.target; + if (target.closest('.dismiss')) { + return; + } + window.location.href = saleBanner.getAttribute('data-url'); + }); + if (saleDismiss) { + onClickPreventDefault(saleDismiss, function () { + saleBanner.remove(); + var formData = new FormData(); + doJsonPost('sale_banner_dismiss', formData); + }); + } + } + }, + buildInit: function buildInit() { + jQuery('#frm_builder_page').on('mouseup', '*:not(.frm-show-box)', maybeHideShortcodes); + var loadFieldId; + debouncedSyncAfterDragAndDrop = debounce(syncAfterDragAndDrop, 10); + postBodyContent = document.getElementById('post-body-content'); + $postBodyContent = jQuery(postBodyContent); + if (jQuery('.frm_field_loading').length) { + loadFieldId = jQuery('.frm_field_loading').first().attr('id'); + loadFields(loadFieldId); + } + setupSortable('ul.frm_sorting'); + document.querySelectorAll('.field_type_list > li:not(.frm_show_upgrade):not(.frm_show_update)').forEach(makeDraggable); + jQuery('ul.field_type_list, .field_type_list li, ul.frm_code_list, .frm_code_list li, .frm_code_list li a, #frm_adv_info #category-tabs li, #frm_adv_info #category-tabs li a').disableSelection(); + jQuery('.frm_submit_ajax').on('click', submitBuild); + jQuery('.frm_submit_no_ajax').on('click', submitNoAjax); + addFormNameModalEvents(); + jQuery('a.edit-form-status').on('click', slideDown); + jQuery('.cancel-form-status').on('click', slideUp); + jQuery('.save-form-status').on('click', function () { + var newStatus = jQuery(document.getElementById('form_change_status')).val(); + jQuery('input[name="new_status"]').val(newStatus); + jQuery(document.getElementById('form-status-display')).html(newStatus); + jQuery('.cancel-form-status').trigger('click'); + return false; + }); + jQuery('.frm_form_builder form').first().on('submit', function () { + jQuery('.inplace_field').trigger('blur'); + }); + initiateMultiselect(); + renumberPageBreaks(); + var $builderForm = jQuery(builderForm); + var builderArea = document.getElementById('frm_form_editor_container'); + $builderForm.on('click', '.frm_add_logic_row', addFieldLogicRow); + $builderForm.on('click', '.frm_add_watch_lookup_row', addWatchLookupRow); + $builderForm.on('change', '.frm_get_values_form', updateGetValueFieldSelection); + $builderForm.on('change', '.frm_logic_field_opts', getFieldValues); + $builderForm.on('frm-multiselect-changed', 'select[name^="field_options[admin_only_"]', adjustVisibilityValuesForEveryoneValues); + jQuery(document.getElementById('frm-insert-fields')).on('click', '.frm_add_field', addFieldClick); + $newFields.on('click', '.frm_clone_field', duplicateField); + $builderForm.on('blur', 'input[id^="frm_calc"]', checkCalculationCreatedByUser); + $builderForm.on('change', 'input.frm_format_opt, input.frm_max_length_opt', toggleInvalidMsg); + $builderForm.on('change click', '[data-changeme]', liveChanges); + $builderForm.on('click', 'input.frm_req_field', markRequired); + $builderForm.on('click', '.frm_mark_unique', markUnique); + $builderForm.on('change', '.frm_repeat_format', toggleRepeatButtons); + $builderForm.on('change', '.frm_repeat_limit', checkRepeatLimit); + $builderForm.on('change', '.frm_js_checkbox_limit', checkCheckboxSelectionsLimit); + $builderForm.on('input', 'input[name^="field_options[add_label_"]', function () { + updateRepeatText(this, 'add'); + }); + $builderForm.on('input', 'input[name^="field_options[remove_label_"]', function () { + updateRepeatText(this, 'remove'); + }); + $builderForm.on('change', 'select[name^="field_options[data_type_"]', maybeClearWatchFields); + jQuery(builderArea).on('click', '.frm-collapse-page', maybeCollapsePage); + jQuery(builderArea).on('click', '.frm-collapse-section', maybeCollapseSection); + $builderForm.on('click', '.frm-single-settings h3, .frm-single-settings h4.frm-collapsible', maybeCollapseSettings); + $builderForm.on('keydown', '.frm-single-settings h3, .frm-single-settings h4.frm-collapsible', function (event) { + // If so, only proceed if the key pressed was 'Enter' or 'Space' + if (event.key === 'Enter' || event.key === ' ') { + event.preventDefault(); + maybeCollapseSettings.call(this, event); + } + }); + jQuery(builderArea).on('show.bs.dropdown hide.bs.dropdown', changeSectionStyle); + $builderForm.on('click', '.frm_toggle_sep_values', toggleSepValues); + $builderForm.on('click', '.frm_toggle_image_options', toggleImageOptions); + $builderForm.on('click', '.frm_remove_image_option', removeImageFromOption); + $builderForm.on('click', '.frm_choose_image_box', addImageToOption); + $builderForm.on('change', '.frm_hide_image_text', refreshOptionDisplay); + $builderForm.on('change', '.frm_field_options_image_size', setImageSize); + $builderForm.on('click', '.frm_multiselect_opt', toggleMultiselect); + $newFields.on('mousedown', 'input, textarea, select', stopFieldFocus); + $newFields.on('click', 'input[type=radio], input[type=checkbox]', stopFieldFocus); + $newFields.on('click', '.frm_delete_field', clickDeleteField); + $newFields.on('click', '.frm_select_field', clickSelectField); + jQuery(document).on('click', '.frm_delete_field_group', clickDeleteFieldGroup); + jQuery(document).on('click', '.frm_clone_field_group', duplicateFieldGroup); + jQuery(document).on('click', '#frm_field_group_controls > span:first-child', clickFieldGroupLayout); + jQuery(document).on('click', '.frm-row-layout-option', handleFieldGroupLayoutOptionClick); + jQuery(document).on('click', '.frm-merge-fields-into-row .frm-row-layout-option', handleFieldGroupLayoutOptionInsideMergeClick); + jQuery(document).on('click', '.frm-custom-field-group-layout', customFieldGroupLayoutClick); + jQuery(document).on('click', '.frm-merge-fields-into-row .frm-custom-field-group-layout', customFieldGroupLayoutInsideMergeClick); + jQuery(document).on('click', '.frm-break-field-group', breakFieldGroupClick); + $newFields.on('click', '#frm_field_group_popup .frm_grid_container input', focusFieldGroupInputOnClick); + jQuery(document).on('click', '.frm-cancel-custom-field-group-layout', cancelCustomFieldGroupClick); + jQuery(document).on('click', '.frm-save-custom-field-group-layout', saveCustomFieldGroupClick); + $newFields.on('click', 'ul.frm_sorting', fieldGroupClick); + jQuery(document).on('click', '.frm-merge-fields-into-row', mergeFieldsIntoRowClick); + jQuery(document).on('click', '.frm-delete-field-groups', deleteFieldGroupsClick); + $newFields.on('click', '.frm-field-action-icons [data-toggle="dropdown"]', function () { + this.closest('li.form-field').classList.add('frm-field-settings-open'); + jQuery(document).on('click', '#frm_builder_page', handleClickOutsideOfFieldSettings); + }); + $newFields.on('mousemove', 'ul.frm_sorting', checkForMultiselectKeysOnMouseMove); + $newFields.on('show.bs.dropdown', '.frm-field-action-icons', onFieldActionDropdownShow); + jQuery(document).on('show.bs.dropdown', '#frm_field_group_controls', onFieldGroupActionDropdownShow); + $builderForm.on('click', '.frm_single_option a[data-removeid]', deleteFieldOption); + $builderForm.on('mousedown', '.frm_single_option input[type=radio]', maybeUncheckRadio); + $builderForm.on('focusin', '.frm_single_option input[type=text]', maybeClearOptText); + $builderForm.on('click', '.frm_add_opt', addFieldOption); + $builderForm.on('change', '.frm_single_option input', resetOptOnChange); + $builderForm.on('change', '.frm_image_id', resetOptOnChange); + $builderForm.on('change', '.frm_toggle_mult_sel', toggleMultSel); + $newFields.on('click', '.frm_primary_label', clickLabel); + $newFields.on('click', '.frm_description', clickDescription); + $newFields.on('click', 'li.ui-state-default:not(.frm_noallow)', clickVis); + $newFields.on('dblclick', 'li.ui-state-default', openAdvanced); + $builderForm.on('change', '.frm_tax_form_select', toggleFormTax); + $builderForm.on('change', 'select.conf_field', addConf); + $builderForm.on('change', '.frm_get_field_selection', getFieldSelection); + $builderForm.on('click', '.frm-show-inline-modal', maybeShowInlineModal); + $builderForm.on('keydown', '.frm-show-inline-modal', function (event) { + var key = event.key; + if (key === 'Enter' || key === ' ') { + event.preventDefault(); + maybeShowInlineModal.call(this, event); + } + }); + $builderForm.on('click', '.frm-inline-modal .dismiss', dismissInlineModal); + jQuery(document).on('change', '[data-frmchange]', changeInputtedValue); + document.addEventListener('click', closeModalOnOutsideClick); + $builderForm.on('change', '.frm_include_extras_field', rePopCalcFieldsForSummary); + $builderForm.on('change', 'select[name^="field_options[form_select_"]', maybeChangeEmbedFormMsg); + jQuery(document).on('submit', '#frm_js_build_form', buildSubmittedNoAjax); + jQuery(document).on('change', '#frm_builder_page input:not(.frm-search-input):not(.frm-custom-grid-size-input), #frm_builder_page select, #frm_builder_page textarea', fieldUpdated); + popAllProductFields(); + jQuery(document).on('change', '.frmjs_prod_data_type_opt', toggleProductType); + jQuery(document).on('focus', '.frm-single-settings ul input[type="text"][name^="field_options[options_"]', onOptionTextFocus); + jQuery(document).on('blur', '.frm-single-settings ul input[type="text"][name^="field_options[options_"]', onOptionTextBlur); + frmDom.util.documentOn('click', '.frm-show-field-settings', clickVis); + frmDom.util.documentOn('change', 'select.frm_format_dropdown, select.frm_phone_type_dropdown', maybeUpdateFormatInput); + + // Navigate to the next input field on pressing Enter in a single option field + $builderForm.on('keydown', '.frm_single_option input[name^="field_options["], .frm_single_option input[name^="rows_"]', function (event) { + if ('Enter' === event.key) { + focusNextSingleOptionInput(event.currentTarget); + } + }); + initBulkOptionsOverlay(); + hideEmptyEle(); + document.addEventListener('frm_added_field', hideEmptyEle); + maybeHideQuantityProductFieldOption(); + handleNameFieldOnFormBuilder(); + toggleSectionHolder(); + handleShowPasswordLiveUpdate(); + document.addEventListener('scroll', updateShortcodesPopupPosition, true); + document.addEventListener('change', handleBuilderChangeEvent); + document.querySelector('.frm_form_builder').addEventListener('mousedown', function (event) { + if (event.shiftKey) { + event.preventDefault(); + } + }); + wp.hooks.addAction('frmShowedFieldSettings', 'formidableAdmin', function (showBtn, fieldSettingsEl) { + fieldSettingsEl.querySelectorAll('.frm-collapse-me').forEach(addSlideAnimationCssVars); + }, 9999); + }, + settingsInit: function settingsInit() { + var $formActions = jQuery(document.getElementById('frm_notification_settings')); + + // BCC, CC, and Reply To button functionality + $formActions.on('click', '.frm_email_buttons', showEmailRow); + $formActions.on('click', '.frm_remove_field', hideEmailRow); + $formActions.on('change', '.frm_to_row, .frm_from_row', showEmailWarning); + $formActions.on('change', '.frm_tax_selector', changePosttaxRow); + $formActions.on('change', 'select.frm_single_post_field', checkDupPost); + $formActions.on('change', 'select.frm_toggle_post_content', togglePostContent); + $formActions.on('change', 'select.frm_dyncontent_opt', fillDyncontent); + $formActions.on('change', '.frm_post_type', switchPostType); + $formActions.on('click', '.frm_add_postmeta_row', addPostmetaRow); + $formActions.on('click', '.frm_add_posttax_row', addPosttaxRow); + $formActions.on('click', '.frm_toggle_cf_opts', toggleCfOpts); + $formActions.on('click', '.frm_duplicate_form_action', copyFormAction); + jQuery('.frm_actions_list').on('click', '.frm_active_action', addFormAction); + jQuery('#frm-show-groups, #frm-hide-groups').on('click', toggleActionGroups); + initiateMultiselect(); + + //set actions icons to inactive + jQuery('ul.frm_actions_list li').each(function () { + checkActiveAction(jQuery(this).children('a').data('actiontype')); + + // If the icon is a background image, don't add BG color. + var icon = jQuery(this).find('i'); + if (icon.css('background-image') !== 'none') { + icon.addClass('frm-inverse'); + } + }); + jQuery('.frm_submit_settings_btn').on('click', submitSettings); + addFormNameModalEvents(); + var formSettings = jQuery('.frm_form_settings'); + formSettings.on('click', '.frm_add_form_logic', addFormLogicRow); + formSettings.on('click', '.frm_already_used', actionLimitMessage); + document.addEventListener('click', function handleImageUploadClickEvents(event) { + var target = event.target; + if (!target.closest('.frm_image_preview_wrapper')) { + return; + } + if (target.closest('.frm_choose_image_box')) { + addImageToOption.bind(target)(event); + return; + } + if (target.closest('.frm_remove_image_option')) { + removeImageFromOption.bind(target)(event); + } + }); + + // Close shortcode modal on click. + formSettings.on('mouseup', '*:not(.frm-show-box)', maybeHideShortcodes); + + //Warning when user selects "Do not store entries ..." + jQuery(document.getElementById('no_save')).on('change', function () { + if (this.checked) { + if (confirm(frmAdminJs.no_save_warning) !== true) { + // Uncheck box if user hits "Cancel" + jQuery(this).attr('checked', false); + } + } + }); + jQuery('select[name="options[edit_action]"]').on('change', showSuccessOpt); + var $loggedIn = document.getElementById('logged_in'); + jQuery($loggedIn).on('change', function () { + if (this.checked) { + visible('.hide_logged_in'); + } else { + invisible('.hide_logged_in'); + } + }); + var $cookieExp = jQuery(document.getElementById('frm_cookie_expiration')); + jQuery(document.getElementById('frm_single_entry_type')).on('change', function () { + if (this.value === 'cookie') { + $cookieExp.fadeIn('slow'); + } else { + $cookieExp.fadeOut('slow'); + } + }); + var $singleEntry = document.getElementById('single_entry'); + jQuery($singleEntry).on('change', function () { + if (this.checked) { + visible('.hide_single_entry'); + } else { + invisible('.hide_single_entry'); + } + if (this.checked && jQuery(document.getElementById('frm_single_entry_type')).val() === 'cookie') { + $cookieExp.fadeIn('slow'); + } else { + $cookieExp.fadeOut('slow'); + } + }); + jQuery('.hide_save_draft').hide(); + var $saveDraft = jQuery(document.getElementById('save_draft')); + $saveDraft.on('change', function () { + if (this.checked) { + jQuery('.hide_save_draft').fadeIn('slow'); + } else { + jQuery('.hide_save_draft').fadeOut('slow'); + } + }); + triggerChange($saveDraft); + + //If Allow editing is checked/unchecked + var $editable = document.getElementById('editable'); + jQuery($editable).on('change', function () { + if (this.checked) { + jQuery('.hide_editable').fadeIn('slow'); + triggerChange(document.getElementById('edit_action')); + } else { + jQuery('.hide_editable').fadeOut('slow'); + jQuery('.edit_action_message_box').fadeOut('slow'); //Hide On Update message box + } + }); + + //If File Protection is checked/unchecked + jQuery(document).on('change', '#protect_files', function () { + if (this.checked) { + jQuery('.hide_protect_files').fadeIn('slow'); + } else { + jQuery('.hide_protect_files').fadeOut('slow'); + } + }); + jQuery(document).on('frm-multiselect-changed', '#protect_files_role', adjustVisibilityValuesForEveryoneValues); + jQuery(document).on('submit', '.frm_form_settings', settingsSubmitted); + jQuery(document).on('change', '#form_settings_page input:not(.frm-search-input), #form_settings_page select, #form_settings_page textarea', fieldUpdated); + + // Page Selection Autocomplete + initAutocomplete(); + jQuery(document).on('frm-action-loaded', onActionLoaded); + initOnSubmitAction(); + wp.hooks.addAction('frm_reset_fields_updated', 'formidableAdmin', resetFieldsUpdated); + }, + panelInit: function panelInit() { + jQuery('.frm_wrap, #postbox-container-1').on('click', '.frm_insert_code', insertCode); + jQuery(document).on('change', '.frm_insert_val', function () { + insertFieldCode(jQuery(this).data('target'), jQuery(this).val()); + jQuery(this).val(''); + }); + jQuery(document).on('click change', '[name="frm-id-key-condition"]', resetLogicBuilder); + jQuery(document).on('keyup change', '.frm-build-logic', setLogicExample); + showInputIcon(); + jQuery(document).on('frmElementAdded', function (event, parentEle) { + /* This is here for add-ons to trigger */ + showInputIcon(parentEle); + }); + jQuery(document).on('mousedown', '.frm-show-box', showShortcodes); + var settingsPage = document.getElementById('form_settings_page'); + var viewPage = document.body.classList.contains('post-type-frm_display'); + var insertFieldsTab = document.getElementById('frm_insert_fields_tab'); + if (settingsPage || viewPage || builderPage) { + jQuery(document).on('focusin', 'form input, form textarea', function (e) { + var htmlTab; + e.stopPropagation(); + maybeShowModal(this); + if (jQuery(this).is(':not(:submit, input[type=button], .frm-search-input, input[type=checkbox])')) { + if (jQuery(e.target).closest('#frm_adv_info').length) { + // Don't trigger for fields inside of the modal. + return; + } + if (settingsPage || builderPage) { + /* form settings page */ + htmlTab = jQuery('#frm_html_tab'); + if (jQuery(this).closest('#html_settings').length > 0) { + htmlTab.show(); + htmlTab.siblings().hide(); + jQuery('#frm_html_tab a').trigger('click'); + toggleAllowedHTML(this); + } else { + showElement(jQuery('.frm-category-tabs li')); + insertFieldsTab.click(); + htmlTab.hide(); + htmlTab.siblings().show(); + } + } else if (viewPage) { + var event = new CustomEvent('frm_legacy_views_handle_field_focus'); + event.frmData = { + idAttrValue: this.id + }; + document.dispatchEvent(event); + } + } + }); + } + jQuery('.frm_wrap, #postbox-container-1').on('mousedown', '#frm_adv_info a, .frm_field_list a', function (e) { + e.preventDefault(); + }); + var customPanel = jQuery('#frm_adv_info'); + customPanel.on('click', '.subsubsub a.frmids', function (e) { + toggleKeyID('frmids', e); + }); + customPanel.on('click', '.subsubsub a.frmkeys', function (e) { + toggleKeyID('frmkeys', e); + }); + }, + inboxInit: function inboxInit() { + var _document$getElementB6; + jQuery('.frm_inbox_dismiss').on('click', function (e) { + var message = this.parentNode.parentNode; + var key = message.getAttribute('data-message'); + var href = this.getAttribute('href'); + var dismissedMessage = message.cloneNode(true); + var dismissedMessagesWrapper = document.querySelector('.frm-dismissed-inbox-messages'); + if ('free_templates' === key && !this.classList.contains('frm_inbox_dismiss')) { + return; + } + e.preventDefault(); + var data = { + action: 'frm_inbox_dismiss', + key: key, + nonce: frmGlobal.nonce + }; + var isInboxSlideIn = 'frm_inbox_slide_in' === message.id; + if (isInboxSlideIn) { + message.classList.remove('s11-fadein'); + message.classList.add('s11-fadeout'); + message.addEventListener('animationend', function () { + return message.remove(); + }, { + once: true + }); + } + postAjax(data, function () { + if (isInboxSlideIn) { + return; + } + if (href !== '#') { + window.location = href; + return true; + } + fadeOut(message, function () { + if (dismissedMessagesWrapper) { + var _dismissedMessage$que; + dismissedMessage.classList.remove('frm-fade'); + (_dismissedMessage$que = dismissedMessage.querySelector('.frm-inbox-message-heading .frm_inbox_dismiss')) === null || _dismissedMessage$que === void 0 || _dismissedMessage$que.remove(); + dismissedMessagesWrapper.append(dismissedMessage); + } + if (1 === message.parentNode.querySelectorAll('.frm-inbox-message-container').length) { + document.getElementById('frm_empty_inbox').classList.remove('frm_hidden'); + message.parentNode.closest('.frm-active').classList.add('frm-empty-inbox'); + showActiveCampaignForm(); + } + message.remove(); + }); + }); + }); + if (false === ((_document$getElementB6 = document.getElementById('frm_empty_inbox')) === null || _document$getElementB6 === void 0 ? void 0 : _document$getElementB6.classList.contains('frm_hidden'))) { + showActiveCampaignForm(); + } + }, + solutionInit: function solutionInit() { + jQuery(document).on('submit', '#frm-new-template', installTemplate); + }, + styleInit: function styleInit() { + var $previewWrapper = jQuery('.frm_image_preview_wrapper'); + $previewWrapper.on('click', '.frm_choose_image_box', addImageToOption); + $previewWrapper.on('click', '.frm_remove_image_option', removeImageFromOption); + wp.hooks.doAction('frm_style_editor_init'); + }, + customCSSInit: function customCSSInit() { + console.warn('Calling frmAdminBuild.customCSSInit is deprecated.'); + }, + globalSettingsInit: function globalSettingsInit() { + jQuery(document).on('click', '[data-frmuninstall]', uninstallNow); + initiateMultiselect(); + + // activate addon licenses + var licenseTab = document.getElementById('licenses_settings'); + if (licenseTab) { + jQuery(licenseTab).on('click', '.edd_frm_save_license', saveAddonLicense); + } + + // Solution install page + jQuery(document).on('click', '#frm-new-template button', installTemplateFieldset); + jQuery('#frm-dismissable-cta .dismiss').on('click', function (event) { + event.preventDefault(); + jQuery.post(ajaxurl, { + action: 'frm_lite_settings_upgrade', + nonce: frmGlobal.nonce + }); + jQuery('.settings-lite-cta').remove(); + }); + var captchaType = document.getElementById('frm_re_type'); + if (captchaType) { + captchaType.addEventListener('change', handleCaptchaTypeChange); + } + document.querySelector('.frm_captchas').addEventListener('change', function (event) { + var _document$querySelect8; + var captchaValueOnLoad = (_document$querySelect8 = document.querySelector('.frm_captchas input[checked="checked"]')) === null || _document$querySelect8 === void 0 ? void 0 : _document$querySelect8.value; + var showNote = event.target.value !== captchaValueOnLoad; + document.querySelector('.captcha_settings .frm_note_style').classList.toggle('frm_hidden', !showNote); + }); + + // Set fieldsUpdated to 0 to avoid the unsaved changes pop up. + frmDom.util.documentOn('submit', '.frm_settings_form', function () { + fieldsUpdated = 0; + }); + var manageStyleSettings = document.getElementById('manage_styles_settings'); + if (manageStyleSettings) { + manageStyleSettings.addEventListener('change', function (event) { + var target = event.target; + if ('SELECT' !== target.nodeName || !target.dataset.name || target.getAttribute('name')) { + return; + } + target.setAttribute('name', target.dataset.name); + }); + } + var paymentsSettings = document.getElementById('payments_settings'); + var paymentSettingsTabs = paymentsSettings === null || paymentsSettings === void 0 ? void 0 : paymentsSettings.querySelectorAll('[name="frm_payment_section"]'); + if (paymentSettingsTabs) { + paymentSettingsTabs.forEach(function (element) { + element.addEventListener('change', function () { + if (!element.checked) { + return; + } + var label = paymentsSettings.querySelector("label[for=\"".concat(element.id, "\"]")); + if (label) { + label.setAttribute('aria-selected', 'true'); + } + paymentSettingsTabs.forEach(function (tab) { + if (tab === element) { + return; + } + var label = paymentsSettings.querySelector("label[for=\"".concat(tab.id, "\"]")); + if (label) { + label.setAttribute('aria-selected', 'false'); + } + }); + }); + }); + } + }, + exportInit: function exportInit() { + jQuery('.frm_form_importer').on('submit', startFormMigration); + jQuery(document.getElementById('frm_export_xml')).on('submit', validateExport); + jQuery('#frm_export_xml input, #frm_export_xml select').on('change', removeExportError); + jQuery('input[name="frm_import_file"]').on('change', checkCSVExtension); + document.querySelector('select[name="format"]').addEventListener('change', exportTypeChanged); + jQuery('input[name="frm_export_forms[]"]').on('click', preventMultipleExport); + initiateMultiselect(); + jQuery('.frm-feature-banner .dismiss').on('click', function (event) { + event.preventDefault(); + jQuery.post(ajaxurl, { + action: 'frm_dismiss_migrator', + plugin: this.id, + nonce: frmGlobal.nonce + }); + this.parentElement.remove(); + }); + showOrHideRepeaters(getExportOption()); + document.querySelector('#frm-export-select-all').addEventListener('change', function (event) { + document.querySelectorAll('[name="frm_export_forms[]"]').forEach(function (cb) { + cb.checked = event.target.checked; + }); + }); + }, + inboxBannerInit: function inboxBannerInit() { + var banner = document.getElementById('frm_banner'); + if (!banner) { + return; + } + var dismissButton = banner.querySelector('.frm-banner-dismiss'); + document.addEventListener('click', function (event) { + if (event.target !== dismissButton) { + return; + } + var data = { + action: 'frm_inbox_dismiss', + key: banner.dataset.key, + nonce: frmGlobal.nonce + }; + postAjax(data, function () { + jQuery(banner).fadeOut(400, function () { + banner.remove(); + }); + }); + }); + }, + updateOpts: function updateOpts(fieldId, opts, modal) { + var separate = usingSeparateValues(fieldId); + var action = isProductField(fieldId) ? 'frm_bulk_products' : 'frm_import_options'; + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: { + action: action, + field_id: fieldId, + opts: opts, + separate: separate, + nonce: frmGlobal.nonce + }, + success: function success(html) { + document.getElementById("frm_field_".concat(fieldId, "_opts")).innerHTML = html; + wp.hooks.doAction('frm_after_bulk_edit_opts', fieldId); + resetDisplayedOpts(fieldId); + if (modal !== undefined) { + modal.dialog('close'); + document.getElementById('frm-update-bulk-opts').classList.remove('frm_loading_button'); + } + } + }); + }, + /* remove conditional logic if the field doesn't exist */triggerRemoveLogic: function triggerRemoveLogic(fieldID, metaName) { + jQuery("#frm_logic_".concat(fieldID, "_").concat(metaName, " .frm_remove_tag")).trigger('click'); + }, + downloadXML: function downloadXML(controller, ids, isTemplate) { + var url = "".concat(ajaxurl, "?action=frm_").concat(controller, "_xml&ids=").concat(ids); + if (isTemplate !== null) { + url = "".concat(url, "&is_template=").concat(isTemplate); + } + location.href = url; + }, + /** + * @since 5.0.04 + */ + hooks: { + applyFilters: function applyFilters(hookName) { + var _wp$hooks; + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key2 = 1; _key2 < _len; _key2++) { + args[_key2 - 1] = arguments[_key2]; + } + return (_wp$hooks = wp.hooks).applyFilters.apply(_wp$hooks, [hookName].concat(args)); + }, + addFilter: function addFilter(hookName, callback, priority) { + return wp.hooks.addFilter(hookName, 'formidable', callback, priority); + }, + doAction: function doAction(hookName) { + var _wp$hooks2; + for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key3 = 1; _key3 < _len2; _key3++) { + args[_key3 - 1] = arguments[_key3]; + } + return (_wp$hooks2 = wp.hooks).doAction.apply(_wp$hooks2, [hookName].concat(args)); + }, + addAction: function addAction(hookName, callback, priority) { + return wp.hooks.addAction(hookName, 'formidable', callback, priority); + } + }, + applyZebraStriping: applyZebraStriping, + initModal: initModal, + infoModal: infoModal, + offsetModalY: offsetModalY, + adjustConditionalLogicOptionOrders: adjustConditionalLogicOptionOrders, + addRadioCheckboxOpt: addRadioCheckboxOpt, + installNewForm: installNewForm, + toggleAddonState: toggleAddonState, + purifyHtml: purifyHtml, + loadApiEmailForm: loadApiEmailForm, + addMyEmailAddress: addMyEmailAddress, + fillDropdownOpts: fillDropdownOpts, + showSaveAndReloadModal: showSaveAndReloadModal, + clearSettingsBox: clearSettingsBox, + deleteField: deleteField, + insertFormField: insertFormField, + confirmLinkClick: confirmLinkClick, + handleInsertFieldByDraggingResponse: handleInsertFieldByDraggingResponse, + handleAddFieldClickResponse: handleAddFieldClickResponse, + syncLayoutClasses: syncLayoutClasses, + moveFieldSettings: moveFieldSettings, + maybeCollapseSettings: maybeCollapseSettings + }; +}; +window.frmAdminBuild = frmAdminBuildJS(); +jQuery(document).ready(function () { + var _document$querySelect9; + frmAdminBuild.init(); + document.querySelectorAll('.frm-dropdown-menu').forEach(convertOldBootstrapDropdownsToBootstrap5); + (_document$querySelect9 = document.querySelector('.preview.dropdown .frm-dropdown-toggle')) === null || _document$querySelect9 === void 0 || _document$querySelect9.setAttribute('data-bs-toggle', 'dropdown'); + + // Bootstrap 5 uses data-bs-toggle instead of data-toggle. + document.querySelectorAll('[data-toggle]').forEach(function (toggle) { + return toggle.setAttribute('data-bs-toggle', toggle.getAttribute('data-toggle')); + }); + function convertOldBootstrapDropdownsToBootstrap5(frmDropdownMenu) { + frmDropdownMenu.classList.add('dropdown-menu'); + var toggle = frmDropdownMenu.querySelector('.frm-dropdown-toggle'); + if (toggle) { + if (!toggle.hasAttribute('role')) { + toggle.setAttribute('role', 'button'); + } + if (!toggle.hasAttribute('tabindex')) { + toggle.setAttribute('tabindex', 0); + } + } + + // Convert
      • and
          tags. + if ('UL' === frmDropdownMenu.tagName) { + convertBootstrapUl(frmDropdownMenu); + } + } + function convertBootstrapUl(ul) { + var html = ul.outerHTML; + html = html.replace('
            ', ''); + html = html.replaceAll('
          • ', '
          • ', ''); + ul.outerHTML = html; + } +}); +window.frm_show_div = function (div, value, showIf, classId) { + if (value == showIf) { + jQuery(classId + div).fadeIn('slow').css('visibility', 'visible'); + } else { + jQuery(classId + div).fadeOut('slow'); + } +}; +window.frmCheckAll = function (checked, n) { + jQuery("input[name^=\"".concat(n, "\"]")).prop('checked', Boolean(checked)); +}; +window.frmCheckAllLevel = function (checked, n, level) { + var $kids = jQuery(".frm_catlevel_".concat(level)).children('.frm_checkbox').children('label'); + $kids.children("input[name^=\"".concat(n, "\"]")).prop('checked', Boolean(checked)); +}; +window.frmGetFieldValues = function (fieldId, cur, rowNumber, fieldType, htmlName, callback) { + if (!fieldId) { + return; + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: "action=frm_get_field_values¤t_field=".concat(cur, "&field_id=").concat(fieldId, "&name=").concat(htmlName, "&t=").concat(fieldType, "&form_action=").concat(jQuery('input[name="frm_action"]').val(), "&nonce=").concat(frmGlobal.nonce), + success: function success(msg) { + document.getElementById("frm_show_selected_values_".concat(cur, "_").concat(rowNumber)).innerHTML = msg; + if ('function' === typeof callback) { + callback(); + } + } + }); +}; +window.frmImportCsv = function (formID) { + var urlVars = ''; + if (typeof __FRMURLVARS !== 'undefined') { + urlVars = __FRMURLVARS; + } + jQuery.ajax({ + type: 'POST', + url: ajaxurl, + data: "action=frm_import_csv&nonce=".concat(frmGlobal.nonce, "&frm_skip_cookie=1").concat(urlVars), + success: function success(count) { + var max = jQuery('.frm_admin_progress_bar').attr('aria-valuemax'); + var imported = max - count; + var percent = imported / max * 100; + jQuery('.frm_admin_progress_bar').css('width', "".concat(percent, "%")).attr('aria-valuenow', imported); + if (parseInt(count, 10) > 0) { + jQuery('.frm_csv_remaining').html(count); + frmImportCsv(formID); + } else { + jQuery(document.getElementById('frm_import_message')).html(frm_admin_js.import_complete); + setTimeout(function () { + location.href = "?page=formidable-entries&frm_action=list&form=".concat(formID, "&import-message=1"); + }, 2000); + } + } + }); +}; +})(); + +/******/ })() +; +//# sourceMappingURL=formidable_admin.js.map \ No newline at end of file diff --git a/js/formidable_blocks.js b/js/formidable_blocks.js index 726527dba6..8b0da523ad 100644 --- a/js/formidable_blocks.js +++ b/js/formidable_blocks.js @@ -1 +1,2715 @@ -(()=>{var e={2532:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(6314),o=r.n(n)()(function(e){return e[1]});o.push([e.id,'button.X_GKlxRFRHSOWckGcSPJ {\n\tcursor: progress;\n\topacity: 0.7;\n\tposition: relative;\n\ttext-indent: -999px;\n\tmin-width: 70px;\n\toverflow: hidden;\n}\n\nbutton.X_GKlxRFRHSOWckGcSPJ::before {\n\tcontent: "";\n\tdisplay: inline-block;\n\tposition: absolute;\n\tbackground: transparent;\n\tborder: 1px solid #fff;\n\tborder-top-color: transparent;\n\tborder-left-color: transparent;\n\tborder-radius: 50%;\n\n\tbox-sizing: border-box;\n\ttop: 50%;\n\tleft: 50%;\n\tmargin-top: -10px;\n\tmargin-left: -10px;\n\twidth: 20px;\n\theight: 20px;\n\n\tanimation: _3ywaXb1_tykjJGTtxpG 2s linear infinite;\n}\n',""]),o.locals={"frm-loading":"X_GKlxRFRHSOWckGcSPJ",spin:"_3ywaXb1_tykjJGTtxpG"};const i=o},6314:e=>{"use strict";e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var r=e(t);return t[2]?"@media ".concat(t[2]," {").concat(r,"}"):r}).join("")},t.i=function(e,r,n){"string"==typeof e&&(e=[[null,e,""]]);var o={};if(n)for(var i=0;i{"use strict";var n=r(6925);function o(){}function i(){}i.resetWarningCache=o,e.exports=function(){function e(e,t,r,o,i,l){if(l!==n){var a=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw a.name="Invariant Violation",a}}function t(){return e}e.isRequired=e;var r={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:i,resetWarningCache:o};return r.PropTypes=r,r}},5556:(e,t,r)=>{e.exports=r(2694)()},6925:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},5072:e=>{"use strict";var t=[];function r(e){for(var r=-1,n=0;n{"use strict";var t={};e.exports=function(e,r){var n=function(e){if(void 0===t[e]){var r=document.querySelector(e);if(window.HTMLIFrameElement&&r instanceof window.HTMLIFrameElement)try{r=r.contentDocument.head}catch(e){r=null}t[e]=r}return t[e]}(e);if(!n)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");n.appendChild(r)}},540:e=>{"use strict";e.exports=function(e){var t=document.createElement("style");return e.setAttributes(t,e.attributes),e.insert(t),t}},5056:(e,t,r)=>{"use strict";e.exports=function(e){var t=r.nc;t&&e.setAttribute("nonce",t)}},7825:e=>{"use strict";e.exports=function(e){var t=e.insertStyleElement(e);return{update:function(r){!function(e,t,r){var n=r.css,o=r.media,i=r.sourceMap;o?e.setAttribute("media",o):e.removeAttribute("media"),i&&"undefined"!=typeof btoa&&(n+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(i))))," */")),t.styleTagTransform(n,e)}(t,e,r)},remove:function(){!function(e){if(null===e.parentNode)return!1;e.parentNode.removeChild(e)}(t)}}}},1113:e=>{"use strict";e.exports=function(e,t){if(t.styleSheet)t.styleSheet.cssText=e;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(e))}}}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var i=t[n]={id:n,exports:{}};return e[n](i,i.exports,r),i.exports}r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.nc=void 0,(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(t,r,n){var o,i,l;n((o={},l=r,(i=function(t){var r=function(t){if("object"!=e(t)||!t)return t;var r=t[Symbol.toPrimitive];if(void 0!==r){var n=r.call(t,"string");if("object"!=e(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==e(r)?r:r+""}(i=t))in o?Object.defineProperty(o,i,{value:l,enumerable:!0,configurable:!0,writable:!0}):o[i]=l,o))}function n(e,t){return e?" ".concat(t,'="').concat(e,'"'):""}function o(e){return o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},o(e)}function i(e,t){for(var r=0;re.length)&&(t=e.length);for(var r=0,n=Array(t);r-1&&(n=e.substr(0,r)),n),"wp-admin/admin.php?page=formidable&frm_action=edit&id=").concat(c)},V("Go to form","formidable")))),wp.element.createElement(W,{title:V("Options","formidable"),initialOpen:!1},wp.element.createElement(J,{label:V("Show Form Title","formidable"),checked:s,onChange:function(e){t("title",e?"1":"",i)}}),wp.element.createElement(J,{label:V("Show Form Description","formidable"),checked:m,onChange:function(e){t("description",e?"1":"",i)}}),wp.element.createElement(J,{label:V("Minimize HTML","formidable"),checked:f,onChange:function(e){t("minimize",e?"1":"",i)}})),wp.element.createElement(W,{title:V("Shortcode","formidable"),initialOpen:!1},wp.element.createElement(U,null,wp.element.createElement(u,this.props.attributes))))}}])&&F(n.prototype,o),Object.defineProperty(n,"prototype",{writable:!1}),n;var n,o}(M);function K(e){return K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},K(e)}function $(e,t){for(var r=0;re.length)&&(t=e.length);for(var r=0,n=Array(t);r { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./js/src/api/class-addon-api.js": +/*!***************************************!*\ + !*** ./js/src/api/class-addon-api.js ***! + \***************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAddonAPI: () => (/* binding */ frmAddonAPI) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAddonAPI = /*#__PURE__*/function () { + function frmAddonAPI() { + _classCallCheck(this, frmAddonAPI); + } + return _createClass(frmAddonAPI, null, [{ + key: "toggleAddonState", + value: + /** + * A function designed to toggle different addon states. + * + * @param {'frm_install_addon'|'frm_activate_addon'|'frm_multiple_addons'} action The addon state action type. + * @param {string} addon The addon path. Ex: formidable-views/formidable-views.php + * + * @return {Promise} The response from the server. + */ + function toggleAddonState(action, addon) { + return fetch(ajaxurl, { + method: 'POST', + headers: { + 'Content-Type': 'application/x-www-form-urlencoded' + }, + body: new URLSearchParams({ + action: action, + nonce: frmGlobal.nonce, + plugin: addon + }) + }).then(function (response) { + return response.json(); + }); + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/api/index.js": +/*!*****************************!*\ + !*** ./js/src/api/index.js ***! + \*****************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAddonAPI: () => (/* reexport safe */ _class_addon_api__WEBPACK_IMPORTED_MODULE_0__.frmAddonAPI) +/* harmony export */ }); +/* harmony import */ var _class_addon_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./class-addon-api */ "./js/src/api/class-addon-api.js"); + + +/***/ }), + +/***/ "./js/src/common/components/icon.js": +/*!******************************************!*\ + !*** ./js/src/common/components/icon.js ***! + \******************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ FormidableIcon) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +/** + * Formidable Forms icon + */ +var Component = wp.element.Component; +var Dashicon = wp.components.Dashicon; +var FormidableIcon = /*#__PURE__*/function (_Component) { + function FormidableIcon() { + _classCallCheck(this, FormidableIcon); + return _callSuper(this, FormidableIcon, arguments); + } + _inherits(FormidableIcon, _Component); + return _createClass(FormidableIcon, [{ + key: "loadCustomSvgIcon", + value: function loadCustomSvgIcon() { + var _formidable_form_sele = formidable_form_selector, + icon = _formidable_form_sele.icon; + if (icon.match(/frm_white_label_icon/)) { + return wp.element.createElement("svg", { + xmlns: "http://www.w3.org/2000/svg", + viewBox: "0 0 20 20", + width: "120", + height: "120" + }, wp.element.createElement("path", { + d: "M18.1 1.3H2C.9 1.3 0 2 0 3V17c0 1 .8 1.9 1.9 1.9H18c1 0 1.9-.9 1.9-2V3.2c0-1-.8-1.9-1.9-1.9zM18 16.9H2a.2.2 0 0 1-.2-.3V3.4c0-.2 0-.3.2-.3H18c.1 0 .2.1.2.3v13.2c0 .2 0 .3-.2.3zm-1.6-3.6v1c0 .2-.3.4-.5.4H8a.5.5 0 0 1-.5-.5v-1c0-.2.2-.4.5-.4h7.8c.2 0 .4.2.4.5zm0-3.8v1c0 .2-.3.4-.5.4H8a.5.5 0 0 1-.5-.4v-1c0-.2.2-.4.5-.4h7.8c.2 0 .4.2.4.4zm0-3.7v1c0 .2-.3.4-.5.4H8a.5.5 0 0 1-.5-.5v-1c0-.2.2-.4.5-.4h7.8c.2 0 .4.2.4.5zm-9.9.5a1.4 1.4 0 1 1-2.8 0 1.4 1.4 0 0 1 2.8 0zm0 3.7a1.4 1.4 0 1 1-2.8 0 1.4 1.4 0 0 1 2.8 0zm0 3.8a1.4 1.4 0 1 1-2.8 0 1.4 1.4 0 0 1 2.8 0z" + })); + } + return false; + } + }, { + key: "render", + value: function render() { + if (false !== this.loadCustomSvgIcon()) { + return this.loadCustomSvgIcon(); + } + if (formidable_form_selector.icon !== 'svg') { + return wp.element.createElement(Dashicon, { + icon: formidable_form_selector.icon + }); + } + return wp.element.createElement("svg", { + xmlns: "http://www.w3.org/2000/svg", + viewBox: "0 0 599.68 601.37", + width: "120", + height: "120" + }, wp.element.createElement("path", { + className: "cls-1 orange", + d: "M289.6 384h140v76h-140z" + }), wp.element.createElement("path", { + className: "cls-1", + d: "M400.2 147h-200c-17 0-30.6 12.2-30.6 29.3V218h260v-71zM397.9 264H169.6v196h75V340H398a32.2 32.2 0 0 0 30.1-21.4 24.3 24.3 0 0 0 1.7-8.7V264z" + }), wp.element.createElement("path", { + className: "cls-1", + d: "M299.8 601.4A300.3 300.3 0 0 1 0 300.7a299.8 299.8 0 1 1 511.9 212.6 297.4 297.4 0 0 1-212 88zm0-563A262 262 0 0 0 38.3 300.7a261.6 261.6 0 1 0 446.5-185.5 259.5 259.5 0 0 0-185-76.8z" + })); + } + }]); +}(Component); + + +/***/ }), + +/***/ "./js/src/common/components/itemselect.js": +/*!************************************************!*\ + !*** ./js/src/common/components/itemselect.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ ItemSelect) +/* harmony export */ }); +/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! prop-types */ "./node_modules/prop-types/index.js"); +/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_0__); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } +function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +var _wp$i18n = wp.i18n, + __ = _wp$i18n.__, + sprintf = _wp$i18n.sprintf; + +var Component = wp.element.Component; +var SelectControl = wp.components.SelectControl; + +/** + * Displays a Select control with the specified items as options + * + */ +var ItemSelect = /*#__PURE__*/function (_Component) { + function ItemSelect() { + _classCallCheck(this, ItemSelect); + return _callSuper(this, ItemSelect, arguments); + } + _inherits(ItemSelect, _Component); + return _createClass(ItemSelect, [{ + key: "createOptions", + value: function createOptions(items, itemName) { + var options = items.map(function (item) { + return { + label: item.label, + value: item.value + }; + }); + return [{ + // translators: %s is the name of the item + label: sprintf(__('Select a %s', 'formidable'), itemName), + value: '' + }].concat(_toConsumableArray(options)); + } + }, { + key: "render", + value: function render() { + var _this$props = this.props, + selected = _this$props.selected, + items = _this$props.items, + onChange = _this$props.onChange, + itemName = _this$props.itemName, + itemNamePlural = _this$props.itemNamePlural, + label = _this$props.label, + help = _this$props.help; + if (!items || items.length === 0) { + return wp.element.createElement("p", { + className: "frm-block-select-no-items" + }, sprintf( + // translators: %s is the name of the item + __('Currently, there are no %s', 'formidable'), itemNamePlural)); + } + return wp.element.createElement(SelectControl, { + value: selected, + options: this.createOptions(items, itemName), + label: label, + help: help, + onChange: onChange, + __next40pxDefaultSize: true, + __nextHasNoMarginBottom: true + }); + } + }]); +}(Component); + +ItemSelect.defaultProps = { + itemName: 'item', + itemNamePlural: 'items' +}; +ItemSelect.propTypes = { + selected: prop_types__WEBPACK_IMPORTED_MODULE_0___default().oneOfType([(prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), (prop_types__WEBPACK_IMPORTED_MODULE_0___default().number)]), + //selected item + items: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().array), + //list of possible items + onChange: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().func), + itemName: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), + //name for item in select label + itemNamePlural: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), + //plural of items, used in some labels + label: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), + help: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string) +}; + +/***/ }), + +/***/ "./js/src/common/utilities/values.js": +/*!*******************************************!*\ + !*** ./js/src/common/utilities/values.js ***! + \*******************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ cssHideAdvancedSettings: () => (/* binding */ cssHideAdvancedSettings), +/* harmony export */ getSubDir: () => (/* binding */ getSubDir), +/* harmony export */ setTextAttribute: () => (/* binding */ setTextAttribute), +/* harmony export */ updateAttribute: () => (/* binding */ updateAttribute) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Updates an attribute with the specified new value + * + * @param {string} attributeName Name of block attribute to be updated + * @param {*} attributeValue Value of block attribute to be updated + * @param {Function} setAttributes Function to set the block attribute to be updated + */ +function updateAttribute(attributeName, attributeValue, setAttributes) { + setAttributes(_defineProperty({}, attributeName, attributeValue)); +} + +/** + * Sets text attribute for a shortcode from a key value pair + * + * @param {*} value Value of text attribute to be set + * @param {string} attributeName Name of text attribute to be set + * @return {string} String of the text attribute in the format " id=10" + */ +function setTextAttribute(value, attributeName) { + if (value) { + return " ".concat(attributeName, "=\"").concat(value, "\""); + } + return ''; +} + +/** + * Gets subdirectory of current site, if the site isn't on the top level of the domain + * + * @return {string} The subdirectory of the current site + */ +function getSubDir() { + var page = window.location.pathname; + var index = page.indexOf('wp-admin'); + var subDir = '/'; + if (index > -1) { + subDir = page.substr(0, index); + } + return subDir; +} +var cssHideAdvancedSettings = "\n .components-panel__body.editor-block-inspector__advanced {\n display:none;\n }\n"; + +/***/ }), + +/***/ "./js/src/form/block.js": +/*!******************************!*\ + !*** ./js/src/form/block.js ***! + \******************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _formshortcode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./formshortcode */ "./js/src/form/formshortcode.js"); +/* harmony import */ var _inspector__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./inspector */ "./js/src/form/inspector.js"); +/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); +/* harmony import */ var _formselect__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./formselect */ "./js/src/form/formselect.js"); +/* harmony import */ var _common_utilities_values__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common/utilities/values */ "./js/src/common/utilities/values.js"); +/** + * BLOCK: formidable/simple-form + * + * Block to display selected Formidable form with limited setting options + */ + + + + + +var useBlockProps = wp.blockEditor.useBlockProps; +var Fragment = wp.element.Fragment; +var __ = wp.i18n.__; +var registerBlockType = wp.blocks.registerBlockType; +var Notice = wp.components.Notice; +var _wp = wp, + ServerSideRender = _wp.serverSideRender; +function Edit(_ref) { + var setAttributes = _ref.setAttributes, + attributes = _ref.attributes, + isSelected = _ref.isSelected; + var formId = attributes.formId; + var _formidable_form_sele = formidable_form_selector, + forms = _formidable_form_sele.forms; + var blockProps = useBlockProps(); + if (forms.length === 0) { + return wp.element.createElement("div", blockProps, wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, __('This site does not have any forms.', 'formidable'))); + } + if (!formId) { + return wp.element.createElement("div", blockProps, wp.element.createElement("div", { + className: "frm-block-intro-screen" + }, wp.element.createElement("div", { + className: "frm-block-intro-content" + }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_2__["default"], null), wp.element.createElement("div", { + className: "frm-block-title" + }, formidable_form_selector.name), wp.element.createElement("div", { + className: "frm-block-selector-screen" + }, wp.element.createElement(_formselect__WEBPACK_IMPORTED_MODULE_3__["default"], { + formId: formId, + setAttributes: setAttributes, + forms: forms + }))))); + } + return wp.element.createElement("div", blockProps, wp.element.createElement(_inspector__WEBPACK_IMPORTED_MODULE_1__["default"], { + attributes: attributes, + setAttributes: setAttributes, + forms: forms + }), isSelected && wp.element.createElement("style", null, _common_utilities_values__WEBPACK_IMPORTED_MODULE_4__.cssHideAdvancedSettings), wp.element.createElement(ServerSideRender, { + block: "formidable/simple-form", + attributes: attributes + })); +} +registerBlockType('formidable/simple-form', { + apiVersion: 3, + title: formidable_form_selector.name, + description: __('Display a Form', 'formidable'), + icon: _common_components_icon__WEBPACK_IMPORTED_MODULE_2__["default"], + category: 'widgets', + keywords: [__('contact forms', 'formidable'), 'formidable'], + edit: Edit, + save: function save(props) { + var attributes = props.attributes; + var formId = attributes.formId; + return formId === undefined ? '' : wp.element.createElement(Fragment, null, wp.element.createElement(_formshortcode__WEBPACK_IMPORTED_MODULE_0__["default"], attributes)); + } +}); + +/***/ }), + +/***/ "./js/src/form/calculator.js": +/*!***********************************!*\ + !*** ./js/src/form/calculator.js ***! + \***********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); +/** + * BLOCK: formidable/calculator + * + * Block to display selected Formidable calculator form + */ + +var __ = wp.i18n.__; +var registerBlockType = wp.blocks.registerBlockType; +var Notice = wp.components.Notice; +var useBlockProps = wp.blockEditor.useBlockProps; +function Edit(_ref) { + var setAttributes = _ref.setAttributes, + attributes = _ref.attributes; + var _formidable_form_sele = formidable_form_selector, + forms = _formidable_form_sele.forms; + var blockProps = useBlockProps(); + if (forms.length === 0) { + return wp.element.createElement("div", blockProps, wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, __('This site does not have any forms.', 'formidable'))); + } + return wp.element.createElement("div", blockProps, wp.element.createElement("div", { + className: "frm-block-intro-screen" + }, wp.element.createElement("div", { + className: "frm-block-intro-content" + }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { + className: "frm-block-title" + }, __('Calculator Form', 'formidable')), wp.element.createElement("div", { + className: "frm-block-selector-screen frm_pro_tip" + }, wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, __('This site does not have any calculator forms.', 'formidable'), wp.element.createElement("br", null), wp.element.createElement("a", { + href: formidable_form_selector.link, + target: "_blank" + }, __('Upgrade Formidable Forms.', 'formidable'))), wp.element.createElement("img", { + src: "".concat(formidable_form_selector.url, "/images/conversion-calc.jpg"), + alt: __('Calculator Form', 'formidable') + }))))); +} +var FrmCalcIcon = wp.element.createElement('svg', { + width: 20, + height: 20 +}, wp.element.createElement('path', { + d: 'M16.9 0H3a2 2 0 0 0-1.9 1.9V18a2 2 0 0 0 2 1.9h13.7a2 2 0 0 0 1.9-1.9V2a2 2 0 0 0-2-1.9zm0 18.1H3v-10H17v10zm0-11.9H3V2H17v4.3zM5.5 12.6H7c.3 0 .5-.3.5-.5v-1.5c0-.3-.3-.5-.5-.5H5.5c-.3 0-.5.3-.5.5V12c0 .3.3.5.5.5zm7.5 3.8h1.5c.3 0 .5-.3.5-.6v-5.2c0-.3-.3-.5-.5-.5H13c-.3 0-.5.3-.5.5v5.3c0 .2.3.4.5.4zm-7.5 0H7c.3 0 .5-.3.5-.6v-1.4c0-.3-.3-.6-.5-.6H5.5c-.3 0-.5.3-.5.6v1.4c0 .3.3.6.5.6zm3.8-3.8h1.4c.3 0 .6-.3.6-.5v-1.5c0-.3-.3-.5-.6-.5H9.3c-.3 0-.6.3-.6.5V12c0 .3.3.5.6.5zm0 3.8h1.4c.3 0 .6-.3.6-.6v-1.4c0-.3-.3-.6-.6-.6H9.3c-.3 0-.6.3-.6.6v1.4c0 .3.3.6.6.6z' +})); +registerBlockType('formidable/calculator', { + apiVersion: 3, + title: __('Calculator Form', 'formidable'), + description: __('Display a Calculator Form', 'formidable'), + icon: FrmCalcIcon, + category: 'widgets', + keywords: ['calculation', 'formidable'], + edit: Edit +}); + +/***/ }), + +/***/ "./js/src/form/formselect.js": +/*!***********************************!*\ + !*** ./js/src/form/formselect.js ***! + \***********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ FormSelect) +/* harmony export */ }); +/* harmony import */ var _common_components_itemselect__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/itemselect */ "./js/src/common/components/itemselect.js"); +/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! prop-types */ "./node_modules/prop-types/index.js"); +/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +/** + * Form selector + */ + + +var __ = wp.i18n.__; +var Component = wp.element.Component; +var FormSelect = /*#__PURE__*/function (_Component) { + function FormSelect() { + _classCallCheck(this, FormSelect); + return _callSuper(this, FormSelect, arguments); + } + _inherits(FormSelect, _Component); + return _createClass(FormSelect, [{ + key: "render", + value: function render() { + var _this$props = this.props, + formId = _this$props.formId, + setAttributes = _this$props.setAttributes, + forms = _this$props.forms; + return wp.element.createElement(_common_components_itemselect__WEBPACK_IMPORTED_MODULE_0__["default"], { + selected: formId, + itemName: __('form', 'formidable'), + itemNamePlural: __('forms', 'formidable'), + items: forms, + onChange: function onChange(newFormId) { + setAttributes({ + formId: newFormId + }); + } + }); + } + }]); +}(Component); + +FormSelect.propTypes = { + formId: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string), + //current formId + setAttributes: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().func).isRequired //setAttributes of block +}; + +/***/ }), + +/***/ "./js/src/form/formshortcode.js": +/*!**************************************!*\ + !*** ./js/src/form/formshortcode.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ FormShortcode) +/* harmony export */ }); +/* harmony import */ var _common_utilities_values__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/utilities/values */ "./js/src/common/utilities/values.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +/** + * Form shortcode of current form + */ +var Component = wp.element.Component; + +function createParamsText(atts) { + var formId = atts.formId, + title = atts.title, + description = atts.description, + minimize = atts.minimize; + var paramsText = ''; + paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(formId, 'id'); + paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(title, 'title'); + paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(description, 'description'); + paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(minimize, 'minimize'); + return paramsText; +} +var FormShortcode = /*#__PURE__*/function (_Component) { + function FormShortcode() { + _classCallCheck(this, FormShortcode); + return _callSuper(this, FormShortcode, arguments); + } + _inherits(FormShortcode, _Component); + return _createClass(FormShortcode, [{ + key: "render", + value: function render() { + return wp.element.createElement("div", null, "[formidable", createParamsText(this.props), "]"); + } + }]); +}(Component); + + +/***/ }), + +/***/ "./js/src/form/graph.js": +/*!******************************!*\ + !*** ./js/src/form/graph.js ***! + \******************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); + +(function () { + 'use strict'; + + if (formidable_form_selector.chartsAddon.installed) { + return; + } + var __ = wp.i18n.__; + var registerBlockType = wp.blocks.registerBlockType; + var Notice = wp.components.Notice; + var useBlockProps = wp.blockEditor.useBlockProps; + var UpgradeNotice = function UpgradeNotice(_ref) { + var text = _ref.text, + buttonText = _ref.buttonText, + link = _ref.link; + return wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, text, wp.element.createElement("br", null), wp.element.createElement("a", { + href: link, + target: "_blank" + }, buttonText)); + }; + var blockName = __('Formidable Chart', 'formidable'); + function Edit() { + var imageWrapperStyles = { + padding: '38px', + margin: '0 auto', + maxWidth: '600px' + }; + var blockProps = useBlockProps(); + return wp.element.createElement("div", blockProps, wp.element.createElement("div", { + className: "frm-block-intro-screen" + }, wp.element.createElement("div", { + className: "frm-block-intro-content" + }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { + className: "frm-block-title" + }, blockName), wp.element.createElement("div", { + className: "frm-block-selector-screen frm_pro_tip", + style: { + alignSelf: 'stretch' + } + }, formidable_form_selector.chartsAddon.hasAccess ? wp.element.createElement(UpgradeNotice, { + text: __('This site does not have Formidable Charts active.', 'formidable'), + buttonText: __('Install Formidable Charts', 'formidable'), + link: formidable_form_selector.chartsAddon.link + }) : wp.element.createElement(UpgradeNotice, { + text: __('This site does not have Formidable Charts installed.', 'formidable'), + buttonText: __('Upgrade Formidable Forms', 'formidable'), + link: formidable_form_selector.link + }), wp.element.createElement("div", { + style: imageWrapperStyles + }, wp.element.createElement("img", { + src: "".concat(formidable_form_selector.url, "/images/demo-graph.svg"), + alt: blockName + })))))); + } + registerBlockType('frm-charts/graph', { + apiVersion: 3, + title: blockName, + description: __('Display a chart or graph', 'formidable'), + icon: wp.element.createElement("svg", { + xmlns: "http://www.w3.org/2000/svg", + fill: "none", + viewBox: "0 0 25 23" + }, wp.element.createElement("path", { + stroke: "currentColor", + strokeLinecap: "round", + strokeWidth: "2.5", + d: "M23 2v19m-7-7.5V21M9 10.8V21m-7-2.9V21" + })), + category: 'design', + edit: Edit + }); +})(); + +/***/ }), + +/***/ "./js/src/form/inspector.js": +/*!**********************************!*\ + !*** ./js/src/form/inspector.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Inspector) +/* harmony export */ }); +/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! prop-types */ "./node_modules/prop-types/index.js"); +/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_3__); +/* harmony import */ var _formselect__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./formselect */ "./js/src/form/formselect.js"); +/* harmony import */ var _formshortcode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./formshortcode */ "./js/src/form/formshortcode.js"); +/* harmony import */ var _common_utilities_values__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../common/utilities/values */ "./js/src/common/utilities/values.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } +function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } +function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } +function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } +function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } +function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } +function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } +/** + * Inspector controls for Formidable Simple Form block + */ + +var __ = wp.i18n.__; +var Component = wp.element.Component; +var InspectorControls = wp.blockEditor.InspectorControls; +var _wp$components = wp.components, + PanelBody = _wp$components.PanelBody, + PanelRow = _wp$components.PanelRow, + ToggleControl = _wp$components.ToggleControl, + ExternalLink = _wp$components.ExternalLink; + + + + +var Inspector = /*#__PURE__*/function (_Component) { + function Inspector() { + _classCallCheck(this, Inspector); + return _callSuper(this, Inspector, arguments); + } + _inherits(Inspector, _Component); + return _createClass(Inspector, [{ + key: "render", + value: function render() { + var _this$props = this.props, + setAttributes = _this$props.setAttributes, + attributes = _this$props.attributes, + forms = _this$props.forms; + var formId = attributes.formId, + title = attributes.title, + description = attributes.description, + minimize = attributes.minimize; + return wp.element.createElement(InspectorControls, null, wp.element.createElement(PanelBody, { + title: __('Select Form', 'formidable'), + initialOpen: true + }, wp.element.createElement(PanelRow, null, wp.element.createElement(_formselect__WEBPACK_IMPORTED_MODULE_0__["default"], { + formId: formId, + setAttributes: setAttributes, + forms: forms + })), formId && wp.element.createElement(PanelRow, null, wp.element.createElement(ExternalLink, { + href: "".concat((0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.getSubDir)(), "wp-admin/admin.php?page=formidable&frm_action=edit&id=").concat(formId) + }, __('Go to form', 'formidable')))), wp.element.createElement(PanelBody, { + title: __('Options', 'formidable'), + initialOpen: false + }, wp.element.createElement(ToggleControl, { + label: __('Show Form Title', 'formidable'), + checked: title, + onChange: function onChange(response) { + (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.updateAttribute)('title', response ? '1' : '', setAttributes); + } + }), wp.element.createElement(ToggleControl, { + label: __('Show Form Description', 'formidable'), + checked: description, + onChange: function onChange(response) { + (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.updateAttribute)('description', response ? '1' : '', setAttributes); + } + }), wp.element.createElement(ToggleControl, { + label: __('Minimize HTML', 'formidable'), + checked: minimize, + onChange: function onChange(response) { + (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.updateAttribute)('minimize', response ? '1' : '', setAttributes); + } + })), wp.element.createElement(PanelBody, { + title: __('Shortcode', 'formidable'), + initialOpen: false + }, wp.element.createElement(PanelRow, null, wp.element.createElement(_formshortcode__WEBPACK_IMPORTED_MODULE_1__["default"], this.props.attributes)))); + } + }]); +}(Component); + +Inspector.propTypes = { + attributes: (prop_types__WEBPACK_IMPORTED_MODULE_3___default().object), + //block attributes + setAttributes: (prop_types__WEBPACK_IMPORTED_MODULE_3___default().func) //setAttributes of block +}; + +/***/ }), + +/***/ "./js/src/form/modal.js": +/*!******************************!*\ + !*** ./js/src/form/modal.js ***! + \******************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); + +var __ = wp.i18n.__; +var registerBlockType = wp.blocks.registerBlockType; +var Notice = wp.components.Notice; +var useBlockProps = wp.blockEditor.useBlockProps; +var UpgradeNotice = function UpgradeNotice(_ref) { + var text = _ref.text, + buttonText = _ref.buttonText, + link = _ref.link; + return wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, text, wp.element.createElement("br", null), wp.element.createElement("a", { + href: link, + target: "_blank" + }, buttonText)); +}; +function Edit(_ref2) { + var setAttributes = _ref2.setAttributes, + attributes = _ref2.attributes; + var blockName = __('Bootstrap modal popup', 'formidable'); + var imageStyles = { + maxWidth: '504px', + height: 'auto', + borderRadius: '12px' + }; + var imageWrapperStyles = { + padding: '38px', + textAlign: 'center', + backgroundColor: '#f2f4f7', + marginTop: '24px' + }; + var blockProps = useBlockProps(); + return wp.element.createElement("div", blockProps, wp.element.createElement("div", { + className: "frm-block-intro-screen" + }, wp.element.createElement("div", { + className: "frm-block-intro-content" + }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { + className: "frm-block-title" + }, blockName), wp.element.createElement("div", { + className: "frm-block-selector-screen frm_pro_tip", + style: { + alignSelf: 'stretch' + } + }, formidable_form_selector.modalAddon.hasAccess ? wp.element.createElement(UpgradeNotice, { + text: __('This site does not have popup modals active.', 'formidable'), + buttonText: __('Install Formidable Modals', 'formidable'), + link: formidable_form_selector.modalAddon.link + }) : wp.element.createElement(UpgradeNotice, { + text: __('This site does not have popup modals.', 'formidable'), + buttonText: __('Upgrade Formidable Forms', 'formidable'), + link: formidable_form_selector.link + }), wp.element.createElement("div", { + style: imageWrapperStyles + }, wp.element.createElement("img", { + src: "".concat(formidable_form_selector.url, "/images/modal.png"), + alt: blockName, + style: imageStyles + })))))); +} +registerBlockType('frm-modal/modal', { + apiVersion: 3, + title: "".concat(formidable_form_selector.name, " ").concat(__('Modal', 'formidable')), + description: __('Display a modal', 'formidable'), + icon: _common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], + category: 'widgets', + keywords: ['modal', 'formidable'], + edit: Edit +}); + +/***/ }), + +/***/ "./js/src/form/views.js": +/*!******************************!*\ + !*** ./js/src/form/views.js ***! + \******************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); +/* harmony import */ var _api_index__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../api/index */ "./js/src/api/index.js"); +/* harmony import */ var _css_button_module_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./css/button.module.css */ "./js/src/form/css/button.module.css"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } + + + +var __ = wp.i18n.__; +var registerBlockType = wp.blocks.registerBlockType; +var Notice = wp.components.Notice; +var useState = wp.element.useState; +var useBlockProps = wp.blockEditor.useBlockProps; +var blockData = formidable_form_selector; +var upgradeLink = blockData.viewsAddon.hasAccess ? blockData.viewsAddon.link : blockData.link; +function Edit() { + var _useState = useState({ + defaultClassname: 'frm-activate-addon frm-button-primary button button-primary', + loadingClassname: 'frm-loading', + classnames: 'frm-activate-addon frm-button-primary button button-primary', + label: !blockData.viewsAddon.installed && blockData.viewsAddon.hasAccess ? __('Install', 'formidable') : __('Activate', 'formidable'), + isLoading: false + }), + _useState2 = _slicedToArray(_useState, 2), + addonActivateButton = _useState2[0], + updateAddonActivateButton = _useState2[1]; + var activateViewsAddon = function activateViewsAddon() { + if (true === addonActivateButton.isLoading) { + return; + } + updateAddonActivateButton(_objectSpread(_objectSpread({}, addonActivateButton), {}, { + isLoading: true, + classnames: "".concat(addonActivateButton.defaultClassname, " ").concat(addonActivateButton.loadingClassname) + })); + if (!blockData.viewsAddon.installed && blockData.viewsAddon.hasAccess) { + _api_index__WEBPACK_IMPORTED_MODULE_1__.frmAddonAPI.toggleAddonState('frm_install_addon', blockData.viewsAddon.url).then(function () { + window.location.reload(); + }); + return; + } + _api_index__WEBPACK_IMPORTED_MODULE_1__.frmAddonAPI.toggleAddonState('frm_activate_addon', 'formidable-views/formidable-views.php').then(function () { + window.location.reload(); + }); + }; + var blockName = __('Formidable Views', 'formidable'); + var imageStyles = { + maxWidth: '504px', + height: 'auto', + borderRadius: '12px' + }; + var imageWrapperStyles = { + padding: '38px', + textAlign: 'center', + backgroundColor: '#f2f4f7', + marginTop: '24px' + }; + var blockProps = useBlockProps(); + return wp.element.createElement("div", blockProps, wp.element.createElement("div", { + className: "frm-block-intro-screen" + }, wp.element.createElement("div", { + className: "frm-block-intro-content" + }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { + className: "frm-block-title" + }, blockName), wp.element.createElement("div", { + className: "frm-block-selector-screen frm_pro_tip", + style: { + alignSelf: 'stretch' + } + }, !blockData.viewsAddon.hasAccess && wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, wp.element.createElement("div", { + style: { + maxWidth: '500px', + margin: 'auto' + } + }, __('Effortlessly transform form data into webpages with Views, the only integrated form & application builder.', 'formidable')), wp.element.createElement("br", null), wp.element.createElement("a", { + href: upgradeLink, + rel: "noreferrer", + target: "_blank" + }, __('Upgrade Formidable Forms', 'formidable'))), blockData.viewsAddon.hasAccess && wp.element.createElement(Notice, { + status: "warning", + isDismissible: false + }, wp.element.createElement("div", { + style: { + maxWidth: '500px', + margin: 'auto' + } + }, __('Effortlessly transform form data into webpages with Views, the only integrated form & application builder.', 'formidable')), wp.element.createElement("br", null), wp.element.createElement("button", { + className: addonActivateButton.classnames, + onClick: activateViewsAddon, + type: "button" + }, " ", addonActivateButton.label, " ")), wp.element.createElement("div", { + style: imageWrapperStyles + }, wp.element.createElement("img", { + src: "".concat(blockData.url, "/images/blocks/views-block-placeholder.jpg"), + alt: blockName, + style: imageStyles + })))))); +} +registerBlockType('formidable/simple-view', { + apiVersion: 3, + title: __('Formidable Views', 'formidable'), + description: __('Display a Visual View', 'formidable'), + icon: _common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], + category: 'widgets', + keywords: ['views', 'formidable'], + edit: Edit +}); + +/***/ }), + +/***/ "./node_modules/css-loader/dist/cjs.js!./js/src/form/css/button.module.css": +/*!*********************************************************************************!*\ + !*** ./node_modules/css-loader/dist/cjs.js!./js/src/form/css/button.module.css ***! + \*********************************************************************************/ +/***/ ((module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/cssWithMappingToString.js */ "./node_modules/css-loader/dist/runtime/cssWithMappingToString.js"); +/* harmony import */ var _node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js"); +/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__); +// Imports + + +var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0___default())); +// Module +___CSS_LOADER_EXPORT___.push([module.id, "button.X_GKlxRFRHSOWckGcSPJ {\n\tcursor: progress;\n\topacity: 0.7;\n\tposition: relative;\n\ttext-indent: -999px;\n\tmin-width: 70px;\n\toverflow: hidden;\n}\n\nbutton.X_GKlxRFRHSOWckGcSPJ::before {\n\tcontent: \"\";\n\tdisplay: inline-block;\n\tposition: absolute;\n\tbackground: transparent;\n\tborder: 1px solid #fff;\n\tborder-top-color: transparent;\n\tborder-left-color: transparent;\n\tborder-radius: 50%;\n\n\tbox-sizing: border-box;\n\ttop: 50%;\n\tleft: 50%;\n\tmargin-top: -10px;\n\tmargin-left: -10px;\n\twidth: 20px;\n\theight: 20px;\n\n\tanimation: _3ywaXb1_tykjJGTtxpG 2s linear infinite;\n}\n", "",{"version":3,"sources":["webpack://./js/src/form/css/button.module.css"],"names":[],"mappings":"AAAA;CACC,gBAAgB;CAChB,YAAY;CACZ,kBAAkB;CAClB,mBAAmB;CACnB,eAAe;CACf,gBAAgB;AACjB;;AAEA;CACC,WAAW;CACX,qBAAqB;CACrB,kBAAkB;CAClB,uBAAuB;CACvB,sBAAsB;CACtB,6BAA6B;CAC7B,8BAA8B;CAC9B,kBAAkB;;CAElB,sBAAsB;CACtB,QAAQ;CACR,SAAS;CACT,iBAAiB;CACjB,kBAAkB;CAClB,WAAW;CACX,YAAY;;CAEZ,kDAAkC;AACnC","sourcesContent":["button.frm-loading {\n\tcursor: progress;\n\topacity: 0.7;\n\tposition: relative;\n\ttext-indent: -999px;\n\tmin-width: 70px;\n\toverflow: hidden;\n}\n\nbutton.frm-loading::before {\n\tcontent: \"\";\n\tdisplay: inline-block;\n\tposition: absolute;\n\tbackground: transparent;\n\tborder: 1px solid #fff;\n\tborder-top-color: transparent;\n\tborder-left-color: transparent;\n\tborder-radius: 50%;\n\n\tbox-sizing: border-box;\n\ttop: 50%;\n\tleft: 50%;\n\tmargin-top: -10px;\n\tmargin-left: -10px;\n\twidth: 20px;\n\theight: 20px;\n\n\tanimation: spin 2s linear infinite;\n}\n"],"sourceRoot":""}]); +// Exports +___CSS_LOADER_EXPORT___.locals = { + "frm-loading": "X_GKlxRFRHSOWckGcSPJ", + "spin": "_3ywaXb1_tykjJGTtxpG" +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___); + + +/***/ }), + +/***/ "./node_modules/css-loader/dist/runtime/api.js": +/*!*****************************************************!*\ + !*** ./node_modules/css-loader/dist/runtime/api.js ***! + \*****************************************************/ +/***/ ((module) => { + +"use strict"; + + +/* + MIT License http://www.opensource.org/licenses/mit-license.php + Author Tobias Koppers @sokra +*/ +// css base code, injected by the css-loader +// eslint-disable-next-line func-names +module.exports = function (cssWithMappingToString) { + var list = []; // return the list of modules as css string + + list.toString = function toString() { + return this.map(function (item) { + var content = cssWithMappingToString(item); + + if (item[2]) { + return "@media ".concat(item[2], " {").concat(content, "}"); + } + + return content; + }).join(""); + }; // import a list of modules into the list + // eslint-disable-next-line func-names + + + list.i = function (modules, mediaQuery, dedupe) { + if (typeof modules === "string") { + // eslint-disable-next-line no-param-reassign + modules = [[null, modules, ""]]; + } + + var alreadyImportedModules = {}; + + if (dedupe) { + for (var i = 0; i < this.length; i++) { + // eslint-disable-next-line prefer-destructuring + var id = this[i][0]; + + if (id != null) { + alreadyImportedModules[id] = true; + } + } + } + + for (var _i = 0; _i < modules.length; _i++) { + var item = [].concat(modules[_i]); + + if (dedupe && alreadyImportedModules[item[0]]) { + // eslint-disable-next-line no-continue + continue; + } + + if (mediaQuery) { + if (!item[2]) { + item[2] = mediaQuery; + } else { + item[2] = "".concat(mediaQuery, " and ").concat(item[2]); + } + } + + list.push(item); + } + }; + + return list; +}; + +/***/ }), + +/***/ "./node_modules/css-loader/dist/runtime/cssWithMappingToString.js": +/*!************************************************************************!*\ + !*** ./node_modules/css-loader/dist/runtime/cssWithMappingToString.js ***! + \************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } + +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } + +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } + +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } + +function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } + +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + +module.exports = function cssWithMappingToString(item) { + var _item = _slicedToArray(item, 4), + content = _item[1], + cssMapping = _item[3]; + + if (!cssMapping) { + return content; + } + + if (typeof btoa === "function") { + // eslint-disable-next-line no-undef + var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping)))); + var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64); + var sourceMapping = "/*# ".concat(data, " */"); + var sourceURLs = cssMapping.sources.map(function (source) { + return "/*# sourceURL=".concat(cssMapping.sourceRoot || "").concat(source, " */"); + }); + return [content].concat(sourceURLs).concat([sourceMapping]).join("\n"); + } + + return [content].join("\n"); +}; + +/***/ }), + +/***/ "./node_modules/object-assign/index.js": +/*!*********************************************!*\ + !*** ./node_modules/object-assign/index.js ***! + \*********************************************/ +/***/ ((module) => { + +"use strict"; +/* +object-assign +(c) Sindre Sorhus +@license MIT +*/ + + +/* eslint-disable no-unused-vars */ +var getOwnPropertySymbols = Object.getOwnPropertySymbols; +var hasOwnProperty = Object.prototype.hasOwnProperty; +var propIsEnumerable = Object.prototype.propertyIsEnumerable; + +function toObject(val) { + if (val === null || val === undefined) { + throw new TypeError('Object.assign cannot be called with null or undefined'); + } + + return Object(val); +} + +function shouldUseNative() { + try { + if (!Object.assign) { + return false; + } + + // Detect buggy property enumeration order in older V8 versions. + + // https://bugs.chromium.org/p/v8/issues/detail?id=4118 + var test1 = new String('abc'); // eslint-disable-line no-new-wrappers + test1[5] = 'de'; + if (Object.getOwnPropertyNames(test1)[0] === '5') { + return false; + } + + // https://bugs.chromium.org/p/v8/issues/detail?id=3056 + var test2 = {}; + for (var i = 0; i < 10; i++) { + test2['_' + String.fromCharCode(i)] = i; + } + var order2 = Object.getOwnPropertyNames(test2).map(function (n) { + return test2[n]; + }); + if (order2.join('') !== '0123456789') { + return false; + } + + // https://bugs.chromium.org/p/v8/issues/detail?id=3056 + var test3 = {}; + 'abcdefghijklmnopqrst'.split('').forEach(function (letter) { + test3[letter] = letter; + }); + if (Object.keys(Object.assign({}, test3)).join('') !== + 'abcdefghijklmnopqrst') { + return false; + } + + return true; + } catch (err) { + // We don't expect any of the above to throw, but better to be safe. + return false; + } +} + +module.exports = shouldUseNative() ? Object.assign : function (target, source) { + var from; + var to = toObject(target); + var symbols; + + for (var s = 1; s < arguments.length; s++) { + from = Object(arguments[s]); + + for (var key in from) { + if (hasOwnProperty.call(from, key)) { + to[key] = from[key]; + } + } + + if (getOwnPropertySymbols) { + symbols = getOwnPropertySymbols(from); + for (var i = 0; i < symbols.length; i++) { + if (propIsEnumerable.call(from, symbols[i])) { + to[symbols[i]] = from[symbols[i]]; + } + } + } + } + + return to; +}; + + +/***/ }), + +/***/ "./node_modules/prop-types/checkPropTypes.js": +/*!***************************************************!*\ + !*** ./node_modules/prop-types/checkPropTypes.js ***! + \***************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; +/** + * Copyright (c) 2013-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + + + +var printWarning = function() {}; + +if (true) { + var ReactPropTypesSecret = __webpack_require__(/*! ./lib/ReactPropTypesSecret */ "./node_modules/prop-types/lib/ReactPropTypesSecret.js"); + var loggedTypeFailures = {}; + var has = __webpack_require__(/*! ./lib/has */ "./node_modules/prop-types/lib/has.js"); + + printWarning = function(text) { + var message = 'Warning: ' + text; + if (typeof console !== 'undefined') { + console.error(message); + } + try { + // --- Welcome to debugging React --- + // This error was thrown as a convenience so that you can use this stack + // to find the callsite that caused this warning to fire. + throw new Error(message); + } catch (x) { /**/ } + }; +} + +/** + * Assert that the values match with the type specs. + * Error messages are memorized and will only be shown once. + * + * @param {object} typeSpecs Map of name to a ReactPropType + * @param {object} values Runtime values that need to be type-checked + * @param {string} location e.g. "prop", "context", "child context" + * @param {string} componentName Name of the component for error messages. + * @param {?Function} getStack Returns the component stack. + * @private + */ +function checkPropTypes(typeSpecs, values, location, componentName, getStack) { + if (true) { + for (var typeSpecName in typeSpecs) { + if (has(typeSpecs, typeSpecName)) { + var error; + // Prop type validation may throw. In case they do, we don't want to + // fail the render phase where it didn't fail before. So we log it. + // After these have been cleaned up, we'll let them throw. + try { + // This is intentionally an invariant that gets caught. It's the same + // behavior as without this statement except with a better message. + if (typeof typeSpecs[typeSpecName] !== 'function') { + var err = Error( + (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.' + ); + err.name = 'Invariant Violation'; + throw err; + } + error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret); + } catch (ex) { + error = ex; + } + if (error && !(error instanceof Error)) { + printWarning( + (componentName || 'React class') + ': type specification of ' + + location + ' `' + typeSpecName + '` is invalid; the type checker ' + + 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' + + 'You may have forgotten to pass an argument to the type checker ' + + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + + 'shape all require an argument).' + ); + } + if (error instanceof Error && !(error.message in loggedTypeFailures)) { + // Only monitor this failure once because there tends to be a lot of the + // same error. + loggedTypeFailures[error.message] = true; + + var stack = getStack ? getStack() : ''; + + printWarning( + 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '') + ); + } + } + } + } +} + +/** + * Resets warning cache when testing. + * + * @private + */ +checkPropTypes.resetWarningCache = function() { + if (true) { + loggedTypeFailures = {}; + } +} + +module.exports = checkPropTypes; + + +/***/ }), + +/***/ "./node_modules/prop-types/factoryWithTypeCheckers.js": +/*!************************************************************!*\ + !*** ./node_modules/prop-types/factoryWithTypeCheckers.js ***! + \************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; +/** + * Copyright (c) 2013-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + + + +var ReactIs = __webpack_require__(/*! react-is */ "./node_modules/prop-types/node_modules/react-is/index.js"); +var assign = __webpack_require__(/*! object-assign */ "./node_modules/object-assign/index.js"); + +var ReactPropTypesSecret = __webpack_require__(/*! ./lib/ReactPropTypesSecret */ "./node_modules/prop-types/lib/ReactPropTypesSecret.js"); +var has = __webpack_require__(/*! ./lib/has */ "./node_modules/prop-types/lib/has.js"); +var checkPropTypes = __webpack_require__(/*! ./checkPropTypes */ "./node_modules/prop-types/checkPropTypes.js"); + +var printWarning = function() {}; + +if (true) { + printWarning = function(text) { + var message = 'Warning: ' + text; + if (typeof console !== 'undefined') { + console.error(message); + } + try { + // --- Welcome to debugging React --- + // This error was thrown as a convenience so that you can use this stack + // to find the callsite that caused this warning to fire. + throw new Error(message); + } catch (x) {} + }; +} + +function emptyFunctionThatReturnsNull() { + return null; +} + +module.exports = function(isValidElement, throwOnDirectAccess) { + /* global Symbol */ + var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator; + var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec. + + /** + * Returns the iterator method function contained on the iterable object. + * + * Be sure to invoke the function with the iterable as context: + * + * var iteratorFn = getIteratorFn(myIterable); + * if (iteratorFn) { + * var iterator = iteratorFn.call(myIterable); + * ... + * } + * + * @param {?object} maybeIterable + * @return {?function} + */ + function getIteratorFn(maybeIterable) { + var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]); + if (typeof iteratorFn === 'function') { + return iteratorFn; + } + } + + /** + * Collection of methods that allow declaration and validation of props that are + * supplied to React components. Example usage: + * + * var Props = require('ReactPropTypes'); + * var MyArticle = React.createClass({ + * propTypes: { + * // An optional string prop named "description". + * description: Props.string, + * + * // A required enum prop named "category". + * category: Props.oneOf(['News','Photos']).isRequired, + * + * // A prop named "dialog" that requires an instance of Dialog. + * dialog: Props.instanceOf(Dialog).isRequired + * }, + * render: function() { ... } + * }); + * + * A more formal specification of how these methods are used: + * + * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...) + * decl := ReactPropTypes.{type}(.isRequired)? + * + * Each and every declaration produces a function with the same signature. This + * allows the creation of custom validation functions. For example: + * + * var MyLink = React.createClass({ + * propTypes: { + * // An optional string or URI prop named "href". + * href: function(props, propName, componentName) { + * var propValue = props[propName]; + * if (propValue != null && typeof propValue !== 'string' && + * !(propValue instanceof URI)) { + * return new Error( + * 'Expected a string or an URI for ' + propName + ' in ' + + * componentName + * ); + * } + * } + * }, + * render: function() {...} + * }); + * + * @internal + */ + + var ANONYMOUS = '<>'; + + // Important! + // Keep this list in sync with production version in `./factoryWithThrowingShims.js`. + var ReactPropTypes = { + array: createPrimitiveTypeChecker('array'), + bigint: createPrimitiveTypeChecker('bigint'), + bool: createPrimitiveTypeChecker('boolean'), + func: createPrimitiveTypeChecker('function'), + number: createPrimitiveTypeChecker('number'), + object: createPrimitiveTypeChecker('object'), + string: createPrimitiveTypeChecker('string'), + symbol: createPrimitiveTypeChecker('symbol'), + + any: createAnyTypeChecker(), + arrayOf: createArrayOfTypeChecker, + element: createElementTypeChecker(), + elementType: createElementTypeTypeChecker(), + instanceOf: createInstanceTypeChecker, + node: createNodeChecker(), + objectOf: createObjectOfTypeChecker, + oneOf: createEnumTypeChecker, + oneOfType: createUnionTypeChecker, + shape: createShapeTypeChecker, + exact: createStrictShapeTypeChecker, + }; + + /** + * inlined Object.is polyfill to avoid requiring consumers ship their own + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is + */ + /*eslint-disable no-self-compare*/ + function is(x, y) { + // SameValue algorithm + if (x === y) { + // Steps 1-5, 7-10 + // Steps 6.b-6.e: +0 != -0 + return x !== 0 || 1 / x === 1 / y; + } else { + // Step 6.a: NaN == NaN + return x !== x && y !== y; + } + } + /*eslint-enable no-self-compare*/ + + /** + * We use an Error-like object for backward compatibility as people may call + * PropTypes directly and inspect their output. However, we don't use real + * Errors anymore. We don't inspect their stack anyway, and creating them + * is prohibitively expensive if they are created too often, such as what + * happens in oneOfType() for any type before the one that matched. + */ + function PropTypeError(message, data) { + this.message = message; + this.data = data && typeof data === 'object' ? data: {}; + this.stack = ''; + } + // Make `instanceof Error` still work for returned errors. + PropTypeError.prototype = Error.prototype; + + function createChainableTypeChecker(validate) { + if (true) { + var manualPropTypeCallCache = {}; + var manualPropTypeWarningCount = 0; + } + function checkType(isRequired, props, propName, componentName, location, propFullName, secret) { + componentName = componentName || ANONYMOUS; + propFullName = propFullName || propName; + + if (secret !== ReactPropTypesSecret) { + if (throwOnDirectAccess) { + // New behavior only for users of `prop-types` package + var err = new Error( + 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' + + 'Use `PropTypes.checkPropTypes()` to call them. ' + + 'Read more at http://fb.me/use-check-prop-types' + ); + err.name = 'Invariant Violation'; + throw err; + } else if ( true && typeof console !== 'undefined') { + // Old behavior for people using React.PropTypes + var cacheKey = componentName + ':' + propName; + if ( + !manualPropTypeCallCache[cacheKey] && + // Avoid spamming the console because they are often not actionable except for lib authors + manualPropTypeWarningCount < 3 + ) { + printWarning( + 'You are manually calling a React.PropTypes validation ' + + 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' + + 'and will throw in the standalone `prop-types` package. ' + + 'You may be seeing this warning due to a third-party PropTypes ' + + 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.' + ); + manualPropTypeCallCache[cacheKey] = true; + manualPropTypeWarningCount++; + } + } + } + if (props[propName] == null) { + if (isRequired) { + if (props[propName] === null) { + return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.')); + } + return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.')); + } + return null; + } else { + return validate(props, propName, componentName, location, propFullName); + } + } + + var chainedCheckType = checkType.bind(null, false); + chainedCheckType.isRequired = checkType.bind(null, true); + + return chainedCheckType; + } + + function createPrimitiveTypeChecker(expectedType) { + function validate(props, propName, componentName, location, propFullName, secret) { + var propValue = props[propName]; + var propType = getPropType(propValue); + if (propType !== expectedType) { + // `propValue` being instance of, say, date/regexp, pass the 'object' + // check, but we can offer a more precise error message here rather than + // 'of type `object`'. + var preciseType = getPreciseType(propValue); + + return new PropTypeError( + 'Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'), + {expectedType: expectedType} + ); + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createAnyTypeChecker() { + return createChainableTypeChecker(emptyFunctionThatReturnsNull); + } + + function createArrayOfTypeChecker(typeChecker) { + function validate(props, propName, componentName, location, propFullName) { + if (typeof typeChecker !== 'function') { + return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.'); + } + var propValue = props[propName]; + if (!Array.isArray(propValue)) { + var propType = getPropType(propValue); + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.')); + } + for (var i = 0; i < propValue.length; i++) { + var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret); + if (error instanceof Error) { + return error; + } + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createElementTypeChecker() { + function validate(props, propName, componentName, location, propFullName) { + var propValue = props[propName]; + if (!isValidElement(propValue)) { + var propType = getPropType(propValue); + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.')); + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createElementTypeTypeChecker() { + function validate(props, propName, componentName, location, propFullName) { + var propValue = props[propName]; + if (!ReactIs.isValidElementType(propValue)) { + var propType = getPropType(propValue); + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.')); + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createInstanceTypeChecker(expectedClass) { + function validate(props, propName, componentName, location, propFullName) { + if (!(props[propName] instanceof expectedClass)) { + var expectedClassName = expectedClass.name || ANONYMOUS; + var actualClassName = getClassName(props[propName]); + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.')); + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createEnumTypeChecker(expectedValues) { + if (!Array.isArray(expectedValues)) { + if (true) { + if (arguments.length > 1) { + printWarning( + 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' + + 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).' + ); + } else { + printWarning('Invalid argument supplied to oneOf, expected an array.'); + } + } + return emptyFunctionThatReturnsNull; + } + + function validate(props, propName, componentName, location, propFullName) { + var propValue = props[propName]; + for (var i = 0; i < expectedValues.length; i++) { + if (is(propValue, expectedValues[i])) { + return null; + } + } + + var valuesString = JSON.stringify(expectedValues, function replacer(key, value) { + var type = getPreciseType(value); + if (type === 'symbol') { + return String(value); + } + return value; + }); + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.')); + } + return createChainableTypeChecker(validate); + } + + function createObjectOfTypeChecker(typeChecker) { + function validate(props, propName, componentName, location, propFullName) { + if (typeof typeChecker !== 'function') { + return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.'); + } + var propValue = props[propName]; + var propType = getPropType(propValue); + if (propType !== 'object') { + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.')); + } + for (var key in propValue) { + if (has(propValue, key)) { + var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); + if (error instanceof Error) { + return error; + } + } + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createUnionTypeChecker(arrayOfTypeCheckers) { + if (!Array.isArray(arrayOfTypeCheckers)) { + true ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : 0; + return emptyFunctionThatReturnsNull; + } + + for (var i = 0; i < arrayOfTypeCheckers.length; i++) { + var checker = arrayOfTypeCheckers[i]; + if (typeof checker !== 'function') { + printWarning( + 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' + + 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.' + ); + return emptyFunctionThatReturnsNull; + } + } + + function validate(props, propName, componentName, location, propFullName) { + var expectedTypes = []; + for (var i = 0; i < arrayOfTypeCheckers.length; i++) { + var checker = arrayOfTypeCheckers[i]; + var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret); + if (checkerResult == null) { + return null; + } + if (checkerResult.data && has(checkerResult.data, 'expectedType')) { + expectedTypes.push(checkerResult.data.expectedType); + } + } + var expectedTypesMessage = (expectedTypes.length > 0) ? ', expected one of type [' + expectedTypes.join(', ') + ']': ''; + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.')); + } + return createChainableTypeChecker(validate); + } + + function createNodeChecker() { + function validate(props, propName, componentName, location, propFullName) { + if (!isNode(props[propName])) { + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.')); + } + return null; + } + return createChainableTypeChecker(validate); + } + + function invalidValidatorError(componentName, location, propFullName, key, type) { + return new PropTypeError( + (componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' + + 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.' + ); + } + + function createShapeTypeChecker(shapeTypes) { + function validate(props, propName, componentName, location, propFullName) { + var propValue = props[propName]; + var propType = getPropType(propValue); + if (propType !== 'object') { + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); + } + for (var key in shapeTypes) { + var checker = shapeTypes[key]; + if (typeof checker !== 'function') { + return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker)); + } + var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); + if (error) { + return error; + } + } + return null; + } + return createChainableTypeChecker(validate); + } + + function createStrictShapeTypeChecker(shapeTypes) { + function validate(props, propName, componentName, location, propFullName) { + var propValue = props[propName]; + var propType = getPropType(propValue); + if (propType !== 'object') { + return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); + } + // We need to check all keys in case some are required but missing from props. + var allKeys = assign({}, props[propName], shapeTypes); + for (var key in allKeys) { + var checker = shapeTypes[key]; + if (has(shapeTypes, key) && typeof checker !== 'function') { + return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker)); + } + if (!checker) { + return new PropTypeError( + 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' + + '\nBad object: ' + JSON.stringify(props[propName], null, ' ') + + '\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ') + ); + } + var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); + if (error) { + return error; + } + } + return null; + } + + return createChainableTypeChecker(validate); + } + + function isNode(propValue) { + switch (typeof propValue) { + case 'number': + case 'string': + case 'undefined': + return true; + case 'boolean': + return !propValue; + case 'object': + if (Array.isArray(propValue)) { + return propValue.every(isNode); + } + if (propValue === null || isValidElement(propValue)) { + return true; + } + + var iteratorFn = getIteratorFn(propValue); + if (iteratorFn) { + var iterator = iteratorFn.call(propValue); + var step; + if (iteratorFn !== propValue.entries) { + while (!(step = iterator.next()).done) { + if (!isNode(step.value)) { + return false; + } + } + } else { + // Iterator will provide entry [k,v] tuples rather than values. + while (!(step = iterator.next()).done) { + var entry = step.value; + if (entry) { + if (!isNode(entry[1])) { + return false; + } + } + } + } + } else { + return false; + } + + return true; + default: + return false; + } + } + + function isSymbol(propType, propValue) { + // Native Symbol. + if (propType === 'symbol') { + return true; + } + + // falsy value can't be a Symbol + if (!propValue) { + return false; + } + + // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol' + if (propValue['@@toStringTag'] === 'Symbol') { + return true; + } + + // Fallback for non-spec compliant Symbols which are polyfilled. + if (typeof Symbol === 'function' && propValue instanceof Symbol) { + return true; + } + + return false; + } + + // Equivalent of `typeof` but with special handling for array and regexp. + function getPropType(propValue) { + var propType = typeof propValue; + if (Array.isArray(propValue)) { + return 'array'; + } + if (propValue instanceof RegExp) { + // Old webkits (at least until Android 4.0) return 'function' rather than + // 'object' for typeof a RegExp. We'll normalize this here so that /bla/ + // passes PropTypes.object. + return 'object'; + } + if (isSymbol(propType, propValue)) { + return 'symbol'; + } + return propType; + } + + // This handles more types than `getPropType`. Only used for error messages. + // See `createPrimitiveTypeChecker`. + function getPreciseType(propValue) { + if (typeof propValue === 'undefined' || propValue === null) { + return '' + propValue; + } + var propType = getPropType(propValue); + if (propType === 'object') { + if (propValue instanceof Date) { + return 'date'; + } else if (propValue instanceof RegExp) { + return 'regexp'; + } + } + return propType; + } + + // Returns a string that is postfixed to a warning about an invalid type. + // For example, "undefined" or "of type array" + function getPostfixForTypeWarning(value) { + var type = getPreciseType(value); + switch (type) { + case 'array': + case 'object': + return 'an ' + type; + case 'boolean': + case 'date': + case 'regexp': + return 'a ' + type; + default: + return type; + } + } + + // Returns class name of the object, if any. + function getClassName(propValue) { + if (!propValue.constructor || !propValue.constructor.name) { + return ANONYMOUS; + } + return propValue.constructor.name; + } + + ReactPropTypes.checkPropTypes = checkPropTypes; + ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache; + ReactPropTypes.PropTypes = ReactPropTypes; + + return ReactPropTypes; +}; + + +/***/ }), + +/***/ "./node_modules/prop-types/index.js": +/*!******************************************!*\ + !*** ./node_modules/prop-types/index.js ***! + \******************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +/** + * Copyright (c) 2013-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +if (true) { + var ReactIs = __webpack_require__(/*! react-is */ "./node_modules/prop-types/node_modules/react-is/index.js"); + + // By explicitly using `prop-types` you are opting into new development behavior. + // http://fb.me/prop-types-in-prod + var throwOnDirectAccess = true; + module.exports = __webpack_require__(/*! ./factoryWithTypeCheckers */ "./node_modules/prop-types/factoryWithTypeCheckers.js")(ReactIs.isElement, throwOnDirectAccess); +} else {} + + +/***/ }), + +/***/ "./node_modules/prop-types/lib/ReactPropTypesSecret.js": +/*!*************************************************************!*\ + !*** ./node_modules/prop-types/lib/ReactPropTypesSecret.js ***! + \*************************************************************/ +/***/ ((module) => { + +"use strict"; +/** + * Copyright (c) 2013-present, Facebook, Inc. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + + + +var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED'; + +module.exports = ReactPropTypesSecret; + + +/***/ }), + +/***/ "./node_modules/prop-types/lib/has.js": +/*!********************************************!*\ + !*** ./node_modules/prop-types/lib/has.js ***! + \********************************************/ +/***/ ((module) => { + +module.exports = Function.call.bind(Object.prototype.hasOwnProperty); + + +/***/ }), + +/***/ "./node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack_module, exports) => { + +"use strict"; +/** @license React v16.13.1 + * react-is.development.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + + + + + +if (true) { + (function() { +'use strict'; + +// The Symbol used to tag the ReactElement-like types. If there is no native Symbol +// nor polyfill, then a plain number is used for performance. +var hasSymbol = typeof Symbol === 'function' && Symbol.for; +var REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7; +var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca; +var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb; +var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc; +var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2; +var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd; +var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary +// (unstable) APIs that have been removed. Can we remove the symbols? + +var REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf; +var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf; +var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0; +var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1; +var REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8; +var REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3; +var REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4; +var REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9; +var REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5; +var REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6; +var REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7; + +function isValidElementType(type) { + return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill. + type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE); +} + +function typeOf(object) { + if (typeof object === 'object' && object !== null) { + var $$typeof = object.$$typeof; + + switch ($$typeof) { + case REACT_ELEMENT_TYPE: + var type = object.type; + + switch (type) { + case REACT_ASYNC_MODE_TYPE: + case REACT_CONCURRENT_MODE_TYPE: + case REACT_FRAGMENT_TYPE: + case REACT_PROFILER_TYPE: + case REACT_STRICT_MODE_TYPE: + case REACT_SUSPENSE_TYPE: + return type; + + default: + var $$typeofType = type && type.$$typeof; + + switch ($$typeofType) { + case REACT_CONTEXT_TYPE: + case REACT_FORWARD_REF_TYPE: + case REACT_LAZY_TYPE: + case REACT_MEMO_TYPE: + case REACT_PROVIDER_TYPE: + return $$typeofType; + + default: + return $$typeof; + } + + } + + case REACT_PORTAL_TYPE: + return $$typeof; + } + } + + return undefined; +} // AsyncMode is deprecated along with isAsyncMode + +var AsyncMode = REACT_ASYNC_MODE_TYPE; +var ConcurrentMode = REACT_CONCURRENT_MODE_TYPE; +var ContextConsumer = REACT_CONTEXT_TYPE; +var ContextProvider = REACT_PROVIDER_TYPE; +var Element = REACT_ELEMENT_TYPE; +var ForwardRef = REACT_FORWARD_REF_TYPE; +var Fragment = REACT_FRAGMENT_TYPE; +var Lazy = REACT_LAZY_TYPE; +var Memo = REACT_MEMO_TYPE; +var Portal = REACT_PORTAL_TYPE; +var Profiler = REACT_PROFILER_TYPE; +var StrictMode = REACT_STRICT_MODE_TYPE; +var Suspense = REACT_SUSPENSE_TYPE; +var hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated + +function isAsyncMode(object) { + { + if (!hasWarnedAboutDeprecatedIsAsyncMode) { + hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint + + console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.'); + } + } + + return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE; +} +function isConcurrentMode(object) { + return typeOf(object) === REACT_CONCURRENT_MODE_TYPE; +} +function isContextConsumer(object) { + return typeOf(object) === REACT_CONTEXT_TYPE; +} +function isContextProvider(object) { + return typeOf(object) === REACT_PROVIDER_TYPE; +} +function isElement(object) { + return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE; +} +function isForwardRef(object) { + return typeOf(object) === REACT_FORWARD_REF_TYPE; +} +function isFragment(object) { + return typeOf(object) === REACT_FRAGMENT_TYPE; +} +function isLazy(object) { + return typeOf(object) === REACT_LAZY_TYPE; +} +function isMemo(object) { + return typeOf(object) === REACT_MEMO_TYPE; +} +function isPortal(object) { + return typeOf(object) === REACT_PORTAL_TYPE; +} +function isProfiler(object) { + return typeOf(object) === REACT_PROFILER_TYPE; +} +function isStrictMode(object) { + return typeOf(object) === REACT_STRICT_MODE_TYPE; +} +function isSuspense(object) { + return typeOf(object) === REACT_SUSPENSE_TYPE; +} + +exports.AsyncMode = AsyncMode; +exports.ConcurrentMode = ConcurrentMode; +exports.ContextConsumer = ContextConsumer; +exports.ContextProvider = ContextProvider; +exports.Element = Element; +exports.ForwardRef = ForwardRef; +exports.Fragment = Fragment; +exports.Lazy = Lazy; +exports.Memo = Memo; +exports.Portal = Portal; +exports.Profiler = Profiler; +exports.StrictMode = StrictMode; +exports.Suspense = Suspense; +exports.isAsyncMode = isAsyncMode; +exports.isConcurrentMode = isConcurrentMode; +exports.isContextConsumer = isContextConsumer; +exports.isContextProvider = isContextProvider; +exports.isElement = isElement; +exports.isForwardRef = isForwardRef; +exports.isFragment = isFragment; +exports.isLazy = isLazy; +exports.isMemo = isMemo; +exports.isPortal = isPortal; +exports.isProfiler = isProfiler; +exports.isStrictMode = isStrictMode; +exports.isSuspense = isSuspense; +exports.isValidElementType = isValidElementType; +exports.typeOf = typeOf; + })(); +} + + +/***/ }), + +/***/ "./node_modules/prop-types/node_modules/react-is/index.js": +/*!****************************************************************!*\ + !*** ./node_modules/prop-types/node_modules/react-is/index.js ***! + \****************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +if (false) {} else { + module.exports = __webpack_require__(/*! ./cjs/react-is.development.js */ "./node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js"); +} + + +/***/ }), + +/***/ "./js/src/form/css/button.module.css": +/*!*******************************************!*\ + !*** ./js/src/form/css/button.module.css ***! + \*******************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js"); +/* harmony import */ var _node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js */ "./node_modules/style-loader/dist/runtime/styleDomAPI.js"); +/* harmony import */ var _node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/insertBySelector.js */ "./node_modules/style-loader/dist/runtime/insertBySelector.js"); +/* harmony import */ var _node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var _node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js */ "./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js"); +/* harmony import */ var _node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3__); +/* harmony import */ var _node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js */ "./node_modules/style-loader/dist/runtime/insertStyleElement.js"); +/* harmony import */ var _node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4__); +/* harmony import */ var _node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js */ "./node_modules/style-loader/dist/runtime/styleTagTransform.js"); +/* harmony import */ var _node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5__); +/* harmony import */ var _node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! !!../../../../node_modules/css-loader/dist/cjs.js!./button.module.css */ "./node_modules/css-loader/dist/cjs.js!./js/src/form/css/button.module.css"); + + + + + + + + + + + +var options = {}; + +options.styleTagTransform = (_node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5___default()); +options.setAttributes = (_node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3___default()); + + options.insert = _node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2___default().bind(null, "head"); + +options.domAPI = (_node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1___default()); +options.insertStyleElement = (_node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4___default()); + +var update = _node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0___default()(_node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"], options); + + + + + /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"] && _node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"].locals ? _node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"].locals : undefined); + + +/***/ }), + +/***/ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js": +/*!****************************************************************************!*\ + !*** ./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js ***! + \****************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +var stylesInDom = []; + +function getIndexByIdentifier(identifier) { + var result = -1; + + for (var i = 0; i < stylesInDom.length; i++) { + if (stylesInDom[i].identifier === identifier) { + result = i; + break; + } + } + + return result; +} + +function modulesToDom(list, options) { + var idCountMap = {}; + var identifiers = []; + + for (var i = 0; i < list.length; i++) { + var item = list[i]; + var id = options.base ? item[0] + options.base : item[0]; + var count = idCountMap[id] || 0; + var identifier = "".concat(id, " ").concat(count); + idCountMap[id] = count + 1; + var index = getIndexByIdentifier(identifier); + var obj = { + css: item[1], + media: item[2], + sourceMap: item[3] + }; + + if (index !== -1) { + stylesInDom[index].references++; + stylesInDom[index].updater(obj); + } else { + stylesInDom.push({ + identifier: identifier, + updater: addStyle(obj, options), + references: 1 + }); + } + + identifiers.push(identifier); + } + + return identifiers; +} + +function addStyle(obj, options) { + var api = options.domAPI(options); + api.update(obj); + return function updateStyle(newObj) { + if (newObj) { + if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) { + return; + } + + api.update(obj = newObj); + } else { + api.remove(); + } + }; +} + +module.exports = function (list, options) { + options = options || {}; + list = list || []; + var lastIdentifiers = modulesToDom(list, options); + return function update(newList) { + newList = newList || []; + + for (var i = 0; i < lastIdentifiers.length; i++) { + var identifier = lastIdentifiers[i]; + var index = getIndexByIdentifier(identifier); + stylesInDom[index].references--; + } + + var newLastIdentifiers = modulesToDom(newList, options); + + for (var _i = 0; _i < lastIdentifiers.length; _i++) { + var _identifier = lastIdentifiers[_i]; + + var _index = getIndexByIdentifier(_identifier); + + if (stylesInDom[_index].references === 0) { + stylesInDom[_index].updater(); + + stylesInDom.splice(_index, 1); + } + } + + lastIdentifiers = newLastIdentifiers; + }; +}; + +/***/ }), + +/***/ "./node_modules/style-loader/dist/runtime/insertBySelector.js": +/*!********************************************************************!*\ + !*** ./node_modules/style-loader/dist/runtime/insertBySelector.js ***! + \********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +var memo = {}; +/* istanbul ignore next */ + +function getTarget(target) { + if (typeof memo[target] === "undefined") { + var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself + + if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) { + try { + // This will throw an exception if access to iframe is blocked + // due to cross-origin restrictions + styleTarget = styleTarget.contentDocument.head; + } catch (e) { + // istanbul ignore next + styleTarget = null; + } + } + + memo[target] = styleTarget; + } + + return memo[target]; +} +/* istanbul ignore next */ + + +function insertBySelector(insert, style) { + var target = getTarget(insert); + + if (!target) { + throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid."); + } + + target.appendChild(style); +} + +module.exports = insertBySelector; + +/***/ }), + +/***/ "./node_modules/style-loader/dist/runtime/insertStyleElement.js": +/*!**********************************************************************!*\ + !*** ./node_modules/style-loader/dist/runtime/insertStyleElement.js ***! + \**********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +/* istanbul ignore next */ +function insertStyleElement(options) { + var style = document.createElement("style"); + options.setAttributes(style, options.attributes); + options.insert(style); + return style; +} + +module.exports = insertStyleElement; + +/***/ }), + +/***/ "./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js": +/*!**********************************************************************************!*\ + !*** ./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js ***! + \**********************************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +/* istanbul ignore next */ +function setAttributesWithoutAttributes(style) { + var nonce = true ? __webpack_require__.nc : 0; + + if (nonce) { + style.setAttribute("nonce", nonce); + } +} + +module.exports = setAttributesWithoutAttributes; + +/***/ }), + +/***/ "./node_modules/style-loader/dist/runtime/styleDomAPI.js": +/*!***************************************************************!*\ + !*** ./node_modules/style-loader/dist/runtime/styleDomAPI.js ***! + \***************************************************************/ +/***/ ((module) => { + +"use strict"; + + +/* istanbul ignore next */ +function apply(style, options, obj) { + var css = obj.css; + var media = obj.media; + var sourceMap = obj.sourceMap; + + if (media) { + style.setAttribute("media", media); + } else { + style.removeAttribute("media"); + } + + if (sourceMap && typeof btoa !== "undefined") { + css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */"); + } // For old IE + + /* istanbul ignore if */ + + + options.styleTagTransform(css, style); +} + +function removeStyleElement(style) { + // istanbul ignore if + if (style.parentNode === null) { + return false; + } + + style.parentNode.removeChild(style); +} +/* istanbul ignore next */ + + +function domAPI(options) { + var style = options.insertStyleElement(options); + return { + update: function update(obj) { + apply(style, options, obj); + }, + remove: function remove() { + removeStyleElement(style); + } + }; +} + +module.exports = domAPI; + +/***/ }), + +/***/ "./node_modules/style-loader/dist/runtime/styleTagTransform.js": +/*!*********************************************************************!*\ + !*** ./node_modules/style-loader/dist/runtime/styleTagTransform.js ***! + \*********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +/* istanbul ignore next */ +function styleTagTransform(css, style) { + if (style.styleSheet) { + style.styleSheet.cssText = css; + } else { + while (style.firstChild) { + style.removeChild(style.firstChild); + } + + style.appendChild(document.createTextNode(css)); + } +} + +module.exports = styleTagTransform; + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ id: moduleId, +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/nonce */ +/******/ (() => { +/******/ __webpack_require__.nc = undefined; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. +(() => { +"use strict"; +/*!**************************!*\ + !*** ./js/src/blocks.js ***! + \**************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _form_block__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./form/block */ "./js/src/form/block.js"); +/* harmony import */ var _form_calculator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./form/calculator */ "./js/src/form/calculator.js"); +/* harmony import */ var _form_modal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./form/modal */ "./js/src/form/modal.js"); +/* harmony import */ var _form_graph__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./form/graph */ "./js/src/form/graph.js"); +/* harmony import */ var _form_views__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./form/views */ "./js/src/form/views.js"); +/** + * Formidable Simple Blocks + * + */ + + + + + + +})(); + +/******/ })() +; +//# sourceMappingURL=formidable_blocks.js.map \ No newline at end of file diff --git a/js/formidable_dashboard.js b/js/formidable_dashboard.js index bfb4fbb57d..8cff43e425 100644 --- a/js/formidable_dashboard.js +++ b/js/formidable_dashboard.js @@ -1 +1,959 @@ -(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(e,t){for(var i=0;i1&&void 0!==arguments[1]?arguments[1]:"default";!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.elements=t,this.type=n,this.prepareElements()},n=[{key:"fadeIn",value:function(){var e=this;this.applyStyleToElements(function(t){t.classList.add("frm-fadein-up"),t.addEventListener("animationend",function(){e.resetOpacity(),t.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){e.applyStyleToElements(function(e,n){e.classList.remove("frm-animate"),e.style.transitionDelay="".concat((n+1)*t,"s")})},200)}},{key:"prepareElements",value:function(){var e=this;this.applyStyleToElements(function(t){"default"===e.type&&(t.style.opacity="0.0"),"cascade"===e.type&&t.classList.add("frm-init-cascade-animation"),"cascade-3d"===e.type&&t.classList.add("frm-init-fadein-3d"),t.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(e){return e.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(e){this.elements instanceof Element?e(this.elements,0):0 li"),this.slideTrackLine=this.wrapper.querySelector(".frm-tabs-active-underline"),this.slideTrack=this.wrapper.querySelector(".frm-tabs-slide-track"),this.slides=this.wrapper.querySelectorAll(".frm-tabs-slide-track > div"),this.isRTL="rtl"===document.documentElement.dir||"rtl"===document.body.dir,this.resizeObserver=null,this.init()))},(t=[{key:"init",value:function(){var e=this;null!==this.wrapper&&this.navs.length&&null!==this.slideTrackLine&&null!==this.slideTrack&&this.slides.length&&(this.navs.forEach(function(t,n){t.addEventListener("click",function(t){return e.onNavClick(t,n)}),t.classList.contains("frm-active")&&e.initSlideTrackUnderline(t)}),this.slideTrackLine.style.display="block",this.setupScrollbarObserver(),window.addEventListener("beforeunload",this.cleanupObservers))}},{key:"onNavClick",value:function(e,t){var n=e.currentTarget;e.preventDefault(),this.removeActiveClassnameFromNavs(),n.classList.add("frm-active"),this.initSlideTrackUnderline(n),this.changeSlide(t);var i,r,o=n.querySelector("a");o&&"frm_insert_fields_tab"===o.id&&!o.closest("#frm_adv_info")&&(null===(i=window.frmAdminBuild)||void 0===i||null===(r=i.clearSettingsBox)||void 0===r||r.call(i))}},{key:"initSlideTrackUnderline",value:function(e){var t=void 0!==e?e:this.navs.filter(function(e){return e.classList.contains("frm-active")});this.positionUnderlineIndicator(t)}},{key:"setupScrollbarObserver",value:function(){var e=this,t=document.querySelector(".frm-scrollbar-wrapper, .styling_settings")||document.body;t&&"ResizeObserver"in window&&(this.resizeObserver=new ResizeObserver(function(){var t=e.wrapper.querySelector(".frm-tabs-navs ul > li.frm-active");t&&e.positionUnderlineIndicator(t)}),this.resizeObserver.observe(t))}},{key:"cleanupObservers",value:function(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null)}},{key:"positionUnderlineIndicator",value:function(e){var t=this;requestAnimationFrame(function(){var n=t.isRTL?-(e.parentElement.offsetWidth-e.offsetLeft-e.offsetWidth):e.offsetLeft;t.slideTrackLine.style.transform="translateX(".concat(n,"px)"),t.slideTrackLine.style.width="".concat(e.clientWidth,"px")})}},{key:"changeSlide",value:function(e){this.removeActiveClassnameFromSlides();var t=0==e?"0px":"calc( ( ".concat(100*e,"% + ").concat(parseInt(this.flexboxSlidesGap,10)*e,"px ) * ").concat(this.isRTL?1:-1," )");"0px"!==t?this.slideTrack.style.transform="translateX(".concat(t,")"):this.slideTrack.style.removeProperty("transform"),e in this.slides&&this.slides[e].classList.add("frm-active")}},{key:"removeActiveClassnameFromSlides",value:function(){this.slides.forEach(function(e){return e.classList.remove("frm-active")})}},{key:"removeActiveClassnameFromNavs",value:function(){this.navs.forEach(function(e){return e.classList.remove("frm-active")})}}])&&c(e.prototype,t),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,t}();function m(e){return m="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},m(e)}function d(e,t){for(var n=0;n { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ "./js/src/components/class-counter.js": +/*!********************************************!*\ + !*** ./js/src/components/class-counter.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmCounter: () => (/* binding */ frmCounter) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmCounter = /*#__PURE__*/function () { + /** + * Init frmCounter + * + * @param {Element} element + * @param {Object} options + * @param {number} options.timetoFinish Max time in mileseconds for counter to complete the animation. + */ + function frmCounter(element, options) { + _classCallCheck(this, frmCounter); + if (!(element instanceof Element) || !element.dataset.counter) { + return; + } + this.template = element.dataset.type || 'default'; + this.element = element; + this.value = parseInt(element.dataset.counter, 10); + this.activeCounter = 0; + this.locale = element.dataset.locale ? element.dataset.locale.replace('_', '-') : 'en-US'; + this.timeoutInterval = 50; + this.timeToFinish = options !== undefined && options.timetoFinish !== undefined ? options.timetoFinish : 1400; + this.valueStep = this.value / Math.ceil(this.timeToFinish / this.timeoutInterval); + if (0 === this.value) { + return; + } + this.animate(); + } + return _createClass(frmCounter, [{ + key: "formatNumber", + value: function formatNumber(number) { + if ('currency' === this.template) { + return number.toLocaleString(this.locale, { + minimumFractionDigits: 2 + }); + } + return number; + } + }, { + key: "animate", + value: function animate() { + if (Math.round(this.activeCounter) < this.value) { + this.activeCounter += this.valueStep; + this.element.innerText = this.formatNumber(Math.round(this.activeCounter)); + setTimeout(this.animate.bind(this), this.timeoutInterval); + } else { + this.element.innerText = this.formatNumber(this.value); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/components/class-tabs-navigator.js": +/*!***************************************************!*\ + !*** ./js/src/components/class-tabs-navigator.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmTabsNavigator: () => (/* binding */ frmTabsNavigator) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmTabsNavigator = /*#__PURE__*/function () { + function frmTabsNavigator(wrapper) { + _classCallCheck(this, frmTabsNavigator); + if (wrapper === undefined) { + return; + } + this.wrapper = wrapper instanceof Element ? wrapper : document.querySelector(wrapper); + if (null === this.wrapper) { + return; + } + this.flexboxSlidesGap = '16px'; + this.navs = this.wrapper.querySelectorAll('.frm-tabs-navs ul > li'); + this.slideTrackLine = this.wrapper.querySelector('.frm-tabs-active-underline'); + this.slideTrack = this.wrapper.querySelector('.frm-tabs-slide-track'); + this.slides = this.wrapper.querySelectorAll('.frm-tabs-slide-track > div'); + this.isRTL = document.documentElement.dir === 'rtl' || document.body.dir === 'rtl'; + this.resizeObserver = null; + this.init(); + } + return _createClass(frmTabsNavigator, [{ + key: "init", + value: function init() { + var _this = this; + if (null === this.wrapper || !this.navs.length || null === this.slideTrackLine || null === this.slideTrack || !this.slides.length) { + return; + } + this.navs.forEach(function (nav, index) { + nav.addEventListener('click', function (event) { + return _this.onNavClick(event, index); + }); + if (nav.classList.contains('frm-active')) { + _this.initSlideTrackUnderline(nav); + } + }); + this.slideTrackLine.style.display = 'block'; + this.setupScrollbarObserver(); + // Cleanup observers when page unloads to prevent memory leaks + window.addEventListener('beforeunload', this.cleanupObservers); + } + }, { + key: "onNavClick", + value: function onNavClick(event, index) { + var navItem = event.currentTarget; + event.preventDefault(); + this.removeActiveClassnameFromNavs(); + navItem.classList.add('frm-active'); + this.initSlideTrackUnderline(navItem); + this.changeSlide(index); + + // Handle special case for frm_insert_fields_tab + var navLink = navItem.querySelector('a'); + if (navLink && navLink.id === 'frm_insert_fields_tab' && !navLink.closest('#frm_adv_info')) { + var _window$frmAdminBuild, _window$frmAdminBuild2; + (_window$frmAdminBuild = window.frmAdminBuild) === null || _window$frmAdminBuild === void 0 || (_window$frmAdminBuild2 = _window$frmAdminBuild.clearSettingsBox) === null || _window$frmAdminBuild2 === void 0 || _window$frmAdminBuild2.call(_window$frmAdminBuild); + } + } + }, { + key: "initSlideTrackUnderline", + value: function initSlideTrackUnderline(nav) { + var activeNav = nav !== undefined ? nav : this.navs.filter(function (nav) { + return nav.classList.contains('frm-active'); + }); + this.positionUnderlineIndicator(activeNav); + } + + /** + * Sets up a ResizeObserver to watch for scrollbar changes in the parent container. + * Automatically repositions the underline indicator when layout changes occur. + */ + }, { + key: "setupScrollbarObserver", + value: function setupScrollbarObserver() { + var _this2 = this; + var resizeObserverTarget = document.querySelector('.frm-scrollbar-wrapper, .styling_settings') || document.body; + if (!resizeObserverTarget || !('ResizeObserver' in window)) { + return; + } + this.resizeObserver = new ResizeObserver(function () { + var activeNav = _this2.wrapper.querySelector('.frm-tabs-navs ul > li.frm-active'); + if (activeNav) { + _this2.positionUnderlineIndicator(activeNav); + } + }); + this.resizeObserver.observe(resizeObserverTarget); + } + + /** + * Cleans up observers to prevent memory leaks. + */ + }, { + key: "cleanupObservers", + value: function cleanupObservers() { + if (this.resizeObserver) { + this.resizeObserver.disconnect(); + this.resizeObserver = null; + } + } + + /** + * Positions the underline indicator based on the active navigation element. + * + * @param {HTMLElement} activeNav The active navigation element to position the underline under + */ + }, { + key: "positionUnderlineIndicator", + value: function positionUnderlineIndicator(activeNav) { + var _this3 = this; + requestAnimationFrame(function () { + var position = _this3.isRTL ? -(activeNav.parentElement.offsetWidth - activeNav.offsetLeft - activeNav.offsetWidth) : activeNav.offsetLeft; + _this3.slideTrackLine.style.transform = "translateX(".concat(position, "px)"); + _this3.slideTrackLine.style.width = "".concat(activeNav.clientWidth, "px"); + }); + } + }, { + key: "changeSlide", + value: function changeSlide(index) { + this.removeActiveClassnameFromSlides(); + var translate = index == 0 ? '0px' : "calc( ( ".concat(index * 100, "% + ").concat(parseInt(this.flexboxSlidesGap, 10) * index, "px ) * ").concat(this.isRTL ? 1 : -1, " )"); + if ('0px' !== translate) { + this.slideTrack.style.transform = "translateX(".concat(translate, ")"); + } else { + this.slideTrack.style.removeProperty('transform'); + } + if (index in this.slides) { + this.slides[index].classList.add('frm-active'); + } + } + }, { + key: "removeActiveClassnameFromSlides", + value: function removeActiveClassnameFromSlides() { + this.slides.forEach(function (slide) { + return slide.classList.remove('frm-active'); + }); + } + }, { + key: "removeActiveClassnameFromNavs", + value: function removeActiveClassnameFromNavs() { + this.navs.forEach(function (nav) { + return nav.classList.remove('frm-active'); + }); + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. +(() => { +/*!*****************************!*\ + !*** ./js/src/dashboard.js ***! + \*****************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/class-tabs-navigator */ "./js/src/components/class-tabs-navigator.js"); +/* harmony import */ var _components_class_counter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/class-counter */ "./js/src/components/class-counter.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * External dependencies + */ + + + +var frmDashboard = /*#__PURE__*/function () { + function frmDashboard() { + _classCallCheck(this, frmDashboard); + this.options = { + ajax: { + action: 'dashboard_ajax_action', + dashboardActions: { + welcomeBanner: 'welcome-banner-has-closed', + checkEmailIfSubscribed: 'email-has-subscribed', + saveSubscribedEmail: 'save-subscribed-email' + } + } + }; + this.widgetsAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(document.querySelectorAll('.frm-dashboard-widget'), 'cascade'); + } + return _createClass(frmDashboard, [{ + key: "init", + value: function init() { + this.initInbox(); + this.initCounters(); + this.initCloseWelcomeBanner(); + this.widgetsAnimate.cascadeFadeIn(); + } + }, { + key: "initInbox", + value: function initInbox() { + var _this = this; + new _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_1__.frmTabsNavigator('.frm-inbox-wrapper'); + var userEmailInput = document.querySelector('#frm_leave_email'); + var subscribeButton = document.querySelector('#frm-add-my-email-address'); + subscribeButton.addEventListener('click', function () { + _this.saveSubscribedEmail(userEmailInput.value).then(); + }); + } + }, { + key: "initCounters", + value: function initCounters() { + var counters = document.querySelectorAll('.frm-counter'); + counters.forEach(function (counter) { + return new _components_class_counter__WEBPACK_IMPORTED_MODULE_2__.frmCounter(counter); + }); + } + }, { + key: "initCloseWelcomeBanner", + value: function initCloseWelcomeBanner() { + var _this2 = this; + var closeButton = document.querySelector('.frm-dashboard-banner-close'); + var dashboardBanner = document.querySelector('.frm-dashboard-banner'); + if (!closeButton || !dashboardBanner) { + return; + } + closeButton.addEventListener('click', function () { + _this2.closeWelcomeBannerSaveCookieRequest().then(function (data) { + if (true === data.success) { + dashboardBanner.remove(); + } + }); + }); + } + }, { + key: "saveSubscribedEmail", + value: function saveSubscribedEmail(email) { + return fetch(window.ajaxurl, { + method: 'POST', + headers: { + 'Content-Type': 'application/x-www-form-urlencoded' + }, + body: new URLSearchParams({ + action: this.options.ajax.action, + dashboard_action: this.options.ajax.dashboardActions.saveSubscribedEmail, + email: email + }) + }).then(function (result) { + return result.json(); + }); + } + }, { + key: "closeWelcomeBannerSaveCookieRequest", + value: function closeWelcomeBannerSaveCookieRequest() { + return fetch(window.ajaxurl, { + method: 'POST', + headers: { + 'Content-Type': 'application/x-www-form-urlencoded' + }, + body: new URLSearchParams({ + action: this.options.ajax.action, + dashboard_action: this.options.ajax.dashboardActions.welcomeBanner, + banner_has_closed: 1 + }) + }).then(function (result) { + return result.json(); + }); + } + }]); +}(); +var frmDashboardClass = new frmDashboard(); +document.addEventListener('DOMContentLoaded', function () { + frmDashboardClass.init(); +}); +})(); + +/******/ })() +; +//# sourceMappingURL=formidable_dashboard.js.map \ No newline at end of file diff --git a/js/formidable_overlay.js b/js/formidable_overlay.js index 06a1b3196b..11e4eb15d5 100644 --- a/js/formidable_overlay.js +++ b/js/formidable_overlay.js @@ -1 +1,793 @@ -(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(e,t){for(var n=0;n1&&void 0!==arguments[1]?arguments[1]:"default";!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.elements=t,this.type=r,this.prepareElements()},r=[{key:"fadeIn",value:function(){var e=this;this.applyStyleToElements(function(t){t.classList.add("frm-fadein-up"),t.addEventListener("animationend",function(){e.resetOpacity(),t.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){e.applyStyleToElements(function(e,r){e.classList.remove("frm-animate"),e.style.transitionDelay="".concat((r+1)*t,"s")})},200)}},{key:"prepareElements",value:function(){var e=this;this.applyStyleToElements(function(t){"default"===e.type&&(t.style.opacity="0.0"),"cascade"===e.type&&t.classList.add("frm-init-cascade-animation"),"cascade-3d"===e.type&&t.classList.add("frm-init-fadein-3d"),t.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(e){return e.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(e){this.elements instanceof Element?e(this.elements,0):0 { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ "./js/src/components/class-overlay.js": +/*!********************************************!*\ + !*** ./js/src/components/class-overlay.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmOverlay: () => (/* binding */ frmOverlay) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * External dependencies + */ + +var frmOverlay = /*#__PURE__*/function () { + function frmOverlay() { + _classCallCheck(this, frmOverlay); + this.body = document.body; + } + + /** + * Open overlay + * + * @param {Object} overlayData An object containing data for the overlay. + * @param {string} overlayData.hero_image URL of the hero image. + * @param {string} overlayData.heading Heading of the overlay. + * @param {string} overlayData.copy Copy/content of the overlay. + * @param {Array} overlayData.buttons Array of button objects. + * @param {string} overlayData.buttons[].url URL for the button. + * @param {string} overlayData.buttons[].target Target attribute for the button link. + * @param {string} overlayData.buttons[].label Label/text of the button. + */ + return _createClass(frmOverlay, [{ + key: "open", + value: function open(overlayData) { + this.overlayData = { + hero_image: null, + heading: null, + copy: null, + buttons: [] + }; + this.overlayData = _objectSpread(_objectSpread({}, this.overlayData), overlayData); + this.bodyAddOverflowHidden(); + this.body.insertBefore(this.buildOverlay(), this.body.firstChild); + this.initCloseButton(); + this.initOverlayIntroAnimation(200); + } + }, { + key: "bodyAddOverflowHidden", + value: function bodyAddOverflowHidden() { + this.body.classList.add('frm-hidden-overflow'); + setTimeout(function () { + document.body.scrollTop = 0; + document.documentElement.scrollTop = 0; + }, 80); + } + }, { + key: "close", + value: function close() { + var overlayWrapper = document.querySelector('.frm-overlay--wrapper'); + if (overlayWrapper) { + document.body.classList.remove('frm-hidden-overflow'); + overlayWrapper.remove(); + } + } + }, { + key: "initCloseButton", + value: function initCloseButton() { + var overlayWrapper = document.querySelector('.frm-overlay--wrapper'); + if (overlayWrapper) { + var closeButton = document.createElement('span'); + closeButton.classList.add('frm-overlay--close'); + closeButton.addEventListener('click', this.close); + overlayWrapper.prepend(closeButton); + } + } + }, { + key: "getHeroImage", + value: function getHeroImage() { + if (this.overlayData.hero_image) { + return frmDom.img({ + src: this.overlayData.hero_image + }); + } + return ''; + } + }, { + key: "getButtons", + value: function getButtons() { + var buttons = this.overlayData.buttons.map(function (button, index) { + if (!button.url) { + return ''; + } + var buttonTypeClassname = 1 === index ? 'frm-button-primary' : 'frm-button-secondary'; + var options = { + href: button.url, + text: button.label, + className: "button frm_animate_bg ".concat(buttonTypeClassname) + }; + if (button.target) { + options.target = button.target; + } + return frmDom.a(options); + }); + if (buttons) { + var buttonsWrapperElementOptions = { + className: 'frm-overlay--cta frm-flex-box', + children: buttons + }; + return frmDom.div(buttonsWrapperElementOptions); + } + return ''; + } + }, { + key: "getHeading", + value: function getHeading() { + if (this.overlayData.heading) { + return frmDom.tag('h2', { + className: 'frm-overlay--heading frm-text-xl', + text: this.overlayData.heading + }); + } + return ''; + } + }, { + key: "getCopy", + value: function getCopy() { + if (this.overlayData.copy) { + var copy = frmDom.tag('div'); + copy.innerHTML = this.overlayData.copy; + return frmDom.div({ + className: 'frm-overlay--copy', + child: copy + }); + } + return ''; + } + }, { + key: "initOverlayIntroAnimation", + value: function initOverlayIntroAnimation(delay) { + setTimeout(function () { + var elements = document.querySelectorAll('.frm-overlay--hero-image, .frm-overlay--heading, .frm-overlay--copy, .frm-overlay--cta a'); + new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(elements, 'cascade-3d').cascadeFadeIn(0.07); + }, delay); + } + }, { + key: "buildOverlay", + value: function buildOverlay() { + var container = frmDom.div({ + className: 'frm-overlay--container', + children: [frmDom.div({ + className: 'frm-overlay--hero-image frm-mb-md', + children: [this.getHeroImage()] + }), this.getHeading(), this.getCopy(), this.getButtons()] + }); + return frmDom.div({ + className: 'frm-overlay--wrapper frm_wrap', + children: [container] + }); + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. +(() => { +/*!***************************!*\ + !*** ./js/src/overlay.js ***! + \***************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _components_class_overlay__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./components/class-overlay */ "./js/src/components/class-overlay.js"); + +window.frmOverlay = new _components_class_overlay__WEBPACK_IMPORTED_MODULE_0__.frmOverlay(); +})(); + +/******/ })() +; +//# sourceMappingURL=formidable_overlay.js.map \ No newline at end of file diff --git a/js/formidable_styles.js b/js/formidable_styles.js index db2e203cc7..61b240efc5 100644 --- a/js/formidable_styles.js +++ b/js/formidable_styles.js @@ -1 +1,3160 @@ -(()=>{var t={8616:t=>{t.exports=function(t,e){var n,r,i=0;function o(){var o,s,a=n,c=arguments.length;t:for(;a;){if(a.args.length===arguments.length){for(s=0;s{var r;!function(){"use strict";var i={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function o(t){return function(t,e){var n,r,s,a,c,l,u,f,p,d=1,h=t.length,y="";for(r=0;r=0),a.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,a.width?parseInt(a.width):0);break;case"e":n=a.precision?parseFloat(n).toExponential(a.precision):parseFloat(n).toExponential();break;case"f":n=a.precision?parseFloat(n).toFixed(a.precision):parseFloat(n);break;case"g":n=a.precision?String(Number(n.toPrecision(a.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=a.precision?n.substring(0,a.precision):n;break;case"t":n=String(!!n),n=a.precision?n.substring(0,a.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=a.precision?n.substring(0,a.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=a.precision?n.substring(0,a.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}i.json.test(a.type)?y+=n:(!i.number.test(a.type)||f&&!a.sign?p="":(p=f?"+":"-",n=n.toString().replace(i.sign,"")),l=a.pad_char?"0"===a.pad_char?"0":a.pad_char.charAt(1):" ",u=a.width-(p+n).length,c=a.width&&u>0?l.repeat(u):"",y+=a.align?p+n+c:"0"===l?p+c+n:c+p+n)}return y}(function(t){if(a[t])return a[t];for(var e,n=t,r=[],o=0;n;){if(null!==(e=i.text.exec(n)))r.push(e[0]);else if(null!==(e=i.modulo.exec(n)))r.push("%");else{if(null===(e=i.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){o|=1;var s=[],c=e[2],l=[];if(null===(l=i.key.exec(c)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(s.push(l[1]);""!==(c=c.substring(l[0].length));)if(null!==(l=i.key_access.exec(c)))s.push(l[1]);else{if(null===(l=i.index_access.exec(c)))throw new SyntaxError("[sprintf] failed to parse named argument key");s.push(l[1])}e[2]=s}else o|=2;if(3===o)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}n=n.substring(e[0].length)}return a[t]=r}(t),arguments)}function s(t,e){return o.apply(null,[t].concat(e||[]))}var a=Object.create(null);"undefined"!=typeof window&&(window.sprintf=o,window.vsprintf=s,void 0===(r=function(){return{sprintf:o,vsprintf:s}}.call(e,n,e,t))||(t.exports=r))}()}},e={};function n(r){var i=e[r];if(void 0!==i)return i.exports;var o=e[r]={exports:{}};return t[r](o,o.exports,n),o.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t,e,r,i,o=n(8616),s=n.n(o);function a(t){return a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},a(t)}function c(t){var e=function(t){if("object"!=a(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=a(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==a(e)?e:e+""}n(7604),s()(console.error),t={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},e=["(","?"],r={")":["("],":":["?","?:"]},i=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var l={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,n){if(t)throw e;return n}};var u={contextDelimiter:"",onMissingKey:null};function f(t,e){var n;for(n in this.data=t,this.pluralForms={},this.options={},u)this.options[n]=void 0!==e&&n in e?e[n]:u[n]}function p(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function d(t){for(var e=1;e=0||t[c]3&&void 0!==arguments[3]?arguments[3]:10,s=t[e];if(v(n)&&m(r))if("function"==typeof i)if("number"==typeof o){var a={callback:i,priority:o,namespace:r};if(s[n]){var c,l=s[n].handlers;for(c=l.length;c>0&&!(o>=l[c-1].priority);c--);c===l.length?l[c]=a:l.splice(c,0,a),s.__current.forEach(function(t){t.name===n&&t.currentIndex>=c&&t.currentIndex++})}else s[n]={handlers:[a],runs:0};"hookAdded"!==n&&t.doAction("hookAdded",n,r,i,o)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},b=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,i){var o=t[e];if(v(r)&&(n||m(i))){if(!o[r])return 0;var s=0;if(n)s=o[r].handlers.length,o[r]={runs:o[r].runs,handlers:[]};else for(var a=o[r].handlers,c=function(t){a[t].namespace===i&&(a.splice(t,1),s++,o.__current.forEach(function(e){e.name===r&&e.currentIndex>=t&&e.currentIndex--}))},l=a.length-1;l>=0;l--)c(l);return"hookRemoved"!==r&&t.doAction("hookRemoved",r,i),s}}},_=function(t,e){return function(n,r){var i=t[e];return void 0!==r?n in i&&i[n].handlers.some(function(t){return t.namespace===r}):n in i}},x=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var i=t[e];i[r]||(i[r]={handlers:[],runs:0}),i[r].runs++;for(var o=i[r].handlers,s=arguments.length,a=new Array(s>1?s-1:0),c=1;c1&&void 0!==arguments[1]?arguments[1]:"default";r.data[e]=d(d(d({},h),r.data[e]),t),r.data[e][""]=d(d({},h[""]),r.data[e][""])},a=function(t,e){s(t,e),o()},c=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,i=arguments.length>3?arguments[3]:void 0,o=arguments.length>4?arguments[4]:void 0;return r.data[t]||s(void 0,t),r.dcnpgettext(t,e,n,i,o)},l=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},u=function(t,e,r){var i=c(r,e,t);return n?(i=n.applyFilters("i18n.gettext_with_context",i,t,e,r),n.applyFilters("i18n.gettext_with_context_"+l(r),i,t,e,r)):i};if(n){var p=function(t){y.test(t)&&o()};n.addAction("hookAdded","core/i18n",p),n.addAction("hookRemoved","core/i18n",p)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[t]},setLocaleData:a,resetLocaleData:function(t,e){r.data={},r.pluralForms={},a(t,e)},subscribe:function(t){return i.add(t),function(){return i.delete(t)}},__:function(t,e){var r=c(e,void 0,t);return n?(r=n.applyFilters("i18n.gettext",r,t,e),n.applyFilters("i18n.gettext_"+l(e),r,t,e)):r},_x:u,_n:function(t,e,r,i){var o=c(i,void 0,t,e,r);return n?(o=n.applyFilters("i18n.ngettext",o,t,e,r,i),n.applyFilters("i18n.ngettext_"+l(i),o,t,e,r,i)):o},_nx:function(t,e,r,i,o){var s=c(o,i,t,e,r);return n?(s=n.applyFilters("i18n.ngettext_with_context",s,t,e,r,i,o),n.applyFilters("i18n.ngettext_with_context_"+l(o),s,t,e,r,i,o)):s},isRTL:function(){return"rtl"===u("ltr","text direction")},hasTranslation:function(t,e,i){var o,s,a=e?e+""+t:t,c=!(null===(o=r.data)||void 0===o||null===(s=o[null!=i?i:"default"])||void 0===s||!s[a]);return n&&(c=n.applyFilters("i18n.has_translation",c,t,e,i),c=n.applyFilters("i18n.has_translation_"+l(i),c,t,e,i)),c}}}(0,0,E));A.getLocaleData.bind(A),A.setLocaleData.bind(A),A.resetLocaleData.bind(A),A.subscribe.bind(A);var C=A.__.bind(A);function O(t){return O="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},O(t)}function F(t,e){for(var n=0;n=this.cssEditorOptions.retryLimit||(void 0!==window.frm_single_style_custom_css_wp_editor&&void 0!==window.frm_single_style_custom_css_wp_editor.codemirror?(this.cssEditorInstance=window.frm_single_style_custom_css_wp_editor.codemirror,this.onCssEditorReady()):setTimeout(function(){t.cssEditorOptions.retryCount++,t.initCustomCSSEditorInstance()},500))}},{key:"getInlineStyleElement",value:function(){return null!==this.cssInlineStyleElement||(this.cssInlineStyleElement=document.createElement("style"),document.head.append(this.cssInlineStyleElement)),this.cssInlineStyleElement}},{key:"onCssEditorReady",value:function(){var t,e=this,n=null===(t=document.getElementById("frm_style_class_custom_css"))||void 0===t||null===(t=t.dataset)||void 0===t?void 0:t.cssScope;if(null!==n){var r=CSS.escape(n);this.cssEditorInstance.on("change",function(t){var n=t.getValue().replace(/<[^>]*>/g,"").trim();e.getInlineStyleElement().textContent=".".concat(r," { ").concat(n," }")})}}},{key:"initColorPickerDependentUpdaterComponents",value:function(){var t=document.querySelectorAll(".frm-style-dependent-updater-component.frm-colorpicker"),e=[];t.forEach(function(t){var n=t.querySelector("input.hex"),r=void 0!==n?n.getAttribute("id"):null;null!==r&&e.push({id:r,dependentUpdaterClass:new j(t,"colorpicker")})}),wp.hooks.addAction("frm_style_options_color_change","formidable",function(t){var n=t.event,r=t.value,i=n.target.closest(".wp-picker-container"),o=n.target.getAttribute("id");i.querySelector(".wp-color-result-text").innerText=r,e.forEach(function(t){t.id===o&&t.dependentUpdaterClass.updateAllDependentElements(r)})})}},{key:"initHover",value:function(){var t=document.querySelector(".frm-right-panel .styling_settings .accordion-container");if(t){var e=document.createElement("div");e.classList.add("frm_hidden"),e.classList.add("frm-style-settings-hover"),t.append(e),t.querySelector(":scope > ul").querySelectorAll(":scope > li").forEach(function(t){t.querySelector("h3").addEventListener("mouseover",function(t){e.style.transform="translateY(".concat(t.target.closest("li").offsetTop,"px)"),e.classList.add("frm-animating"),e.classList.remove("frm_hidden"),setTimeout(function(){e.classList.remove("frm-animating")},250)})}),document.querySelectorAll("#frm_style_sidebar .accordion-section h3").forEach(function(t){t.addEventListener("click",function(){e.classList.add("frm_hidden")})})}}},{key:"initStyleClassCopyToClipboard",value:function(t){var e=this;document.querySelectorAll(".frm-copy-text").forEach(function(n){n.addEventListener("click",function(n){var r=n.currentTarget.innerText;navigator.clipboard&&navigator.clipboard.writeText?navigator.clipboard.writeText(r).then(function(){e.success(t)}):!0===e.fallbackCopyToClipboard(r,n.currentTarget)&&e.success(t)})})}},{key:"toggleVisibilityOfCustomCSSEditor",value:function(){var t=document.getElementById("frm_enable_single_style_custom_css"),e=document.getElementById("frm_single_style_custom_css_editor");t&&e&&t.addEventListener("change",function(t){e.classList.toggle("frm_hidden",!t.target.checked)})}},{key:"fallbackCopyToClipboard",value:function(t,e){if("function"!=typeof document.execCommand)return!1;var n,r=document.createElement("input");r.setAttribute("type","text"),r.value=t,e.parentElement.append(r),r.focus(),r.select(),r.setSelectionRange(0,99999),r.style.position="absolute",r.style.left="-9999px",r.style.top="-9999px";try{n=document.execCommand("copy")}catch(t){n=!1}return r.remove(),n}}])&&P(t.prototype,e),Object.defineProperty(t,"prototype",{writable:!1}),t;var t,e}())})()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/admin/components/dependent-updater-component.js": +/*!****************************************************************!*\ + !*** ./js/src/admin/components/dependent-updater-component.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ frmStyleDependentUpdaterComponent) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * This component updates the dependent style element's values and triggers a custom change event for each style element, initiating the style preview. + * The names of the elements that will be updated are specified using the "will-change" attribute. + * It is primarily used in components from Style/Quick Settings. + * For instance, when the "FrmPrimaryColorStyleComponent" is changed, it simultaneously updates various style elements like border color, text color, and button backgrounds. + */ +var frmStyleDependentUpdaterComponent = /*#__PURE__*/function () { + /** + * Creates an instance of frmStyleDependentUpdaterComponent. + * + * @param {HTMLElement} component - The component element. + */ + function frmStyleDependentUpdaterComponent(component) { + _classCallCheck(this, frmStyleDependentUpdaterComponent); + this.component = component; + try { + var willChangeData = JSON.parse(this.component.dataset.willChange); + this.data = { + propagateInputs: this.initPropagationList(willChangeData), + changeEvent: new Event('change', { + bubbles: true + }) + }; + } catch (error) { + console.error('Error parsing JSON data from "will-change" attribute.', error); + } + } + + /** + * Initializes the list of inputs to propagate changes to. + * The selection is made by provided input's names list in "will-change" attribute. + * + * @param {string[]} inputNames - The names of the inputs to propagate changes to. + * @return {HTMLElement[]} - The list of inputs to propagate changes to. + */ + return _createClass(frmStyleDependentUpdaterComponent, [{ + key: "initPropagationList", + value: function initPropagationList(inputNames) { + var list = []; + inputNames.forEach(function (name) { + var input = document.querySelector("input[name=\"".concat(name, "\"]")); + if (input) { + list.push(input); + } + }); + return list; + } + + /** + * Updates all dependent elements with the given value. + * + * @param {string} value - The value to update the dependent elements with. + */ + }, { + key: "updateAllDependentElements", + value: function updateAllDependentElements(value) { + this.data.propagateInputs.forEach(function (input) { + input.value = value; + }); + this.data.propagateInputs[0].dispatchEvent(this.data.changeEvent); + } + }]); +}(); + + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. +(() => { +"use strict"; +/*!********************************!*\ + !*** ./js/src/admin/styles.js ***! + \********************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var _components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/dependent-updater-component */ "./js/src/admin/components/dependent-updater-component.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } + + + +/** + * Represents the frmStyleOptions class. + * + * @class + */ +var frmStyleOptions = /*#__PURE__*/function () { + function frmStyleOptions() { + _classCallCheck(this, frmStyleOptions); + this.success = frmDom.success; + this.cssEditorInstance = null; + this.cssInlineStyleElement = null; + this.cssEditorOptions = { + retryLimit: 5, + // Stop after 5 retries. + retryInterval: 500, + // Retry every 500ms. + retryCount: 0 // Count the number of retries. + }; + this.init(); + this.initHover(); + this.initCustomCSSEditorInstance(); + } + + /** + * Init the dependent + */ + return _createClass(frmStyleOptions, [{ + key: "init", + value: function init() { + this.initColorPickerDependentUpdaterComponents(); + this.initStyleClassCopyToClipboard((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('The class name has been copied.', 'formidable')); + this.toggleVisibilityOfCustomCSSEditor(); + } + + /** + * Initialize the custom CSS editor instance. + * + * @return {void} + */ + }, { + key: "initCustomCSSEditorInstance", + value: function initCustomCSSEditorInstance() { + var _this = this; + if (null !== this.cssEditorInstance || this.cssEditorOptions.retryCount >= this.cssEditorOptions.retryLimit) { + return; + } + if (window.frm_single_style_custom_css_wp_editor === undefined || window.frm_single_style_custom_css_wp_editor.codemirror === undefined) { + setTimeout(function () { + _this.cssEditorOptions.retryCount++; + _this.initCustomCSSEditorInstance(); + }, 500); + return; + } + this.cssEditorInstance = window.frm_single_style_custom_css_wp_editor.codemirror; + this.onCssEditorReady(); + } + + /** + * Get the inline style element. + * + * @return {HTMLElement} The inline style element. + */ + }, { + key: "getInlineStyleElement", + value: function getInlineStyleElement() { + if (null !== this.cssInlineStyleElement) { + return this.cssInlineStyleElement; + } + this.cssInlineStyleElement = document.createElement('style'); + document.head.append(this.cssInlineStyleElement); + return this.cssInlineStyleElement; + } + + /** + * On the CSS editor ready, add an event listener to the editor to update the inline style element. + * + * @return {void} + */ + }, { + key: "onCssEditorReady", + value: function onCssEditorReady() { + var _document$getElementB, + _this2 = this; + var cssScope = (_document$getElementB = document.getElementById('frm_style_class_custom_css')) === null || _document$getElementB === void 0 || (_document$getElementB = _document$getElementB.dataset) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.cssScope; + if (null === cssScope) { + return; + } + var sanitizedCssScope = CSS.escape(cssScope); + this.cssEditorInstance.on('change', function (editor) { + var value = editor.getValue().replace(/<[^>]*>/g, '').trim(); + _this2.getInlineStyleElement().textContent = ".".concat(sanitizedCssScope, " { ").concat(value, " }"); + }); + } + + /** + * Initializes the color picker dependent updater components. + * Retrieves the components and elements, and adds them to the elements array. + * Adds an action hook for the frm_style_options_color_change event. + */ + }, { + key: "initColorPickerDependentUpdaterComponents", + value: function initColorPickerDependentUpdaterComponents() { + var components = document.querySelectorAll('.frm-style-dependent-updater-component.frm-colorpicker'); + var elements = []; + components.forEach(function (component) { + var element = component.querySelector('input.hex'); + var id = element !== undefined ? element.getAttribute('id') : null; + if (null !== id) { + elements.push({ + id: id, + dependentUpdaterClass: new _components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__["default"](component, 'colorpicker') + }); + } + }); + wp.hooks.addAction('frm_style_options_color_change', 'formidable', function (_ref) { + var event = _ref.event, + value = _ref.value; + var container = event.target.closest('.wp-picker-container'); + var id = event.target.getAttribute('id'); + container.querySelector('.wp-color-result-text').innerText = value; + elements.forEach(function (element) { + if (element.id === id) { + element.dependentUpdaterClass.updateAllDependentElements(value); + } + }); + }); + } + + /** + * Initializes the hover functionality for the style options. + * Creates a hover element and appends it to the settingsWrapper. + * Adds event listeners for mouseover and click events. + */ + }, { + key: "initHover", + value: function initHover() { + var settingsWrapper = document.querySelector('.frm-right-panel .styling_settings .accordion-container'); + if (!settingsWrapper) { + return; + } + var hoverElement = document.createElement('div'); + hoverElement.classList.add('frm_hidden'); + hoverElement.classList.add('frm-style-settings-hover'); + settingsWrapper.append(hoverElement); + var styleOptionsMenu = settingsWrapper.querySelector(':scope > ul'); + styleOptionsMenu.querySelectorAll(':scope > li').forEach(function (item) { + item.querySelector('h3').addEventListener('mouseover', function (event) { + hoverElement.style.transform = "translateY(".concat(event.target.closest('li').offsetTop, "px)"); + hoverElement.classList.add('frm-animating'); + hoverElement.classList.remove('frm_hidden'); + setTimeout(function () { + hoverElement.classList.remove('frm-animating'); + }, 250); + }); + }); + var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); + accordionitems.forEach(function (item) { + item.addEventListener('click', function () { + hoverElement.classList.add('frm_hidden'); + }); + }); + } + + /** + * Initializes the copy to clipboard functionality for style classes. + * Adds a click event listener to the copyLabel element. + * Copies the class name to the clipboard and displays a success message. + * + * @param {string} successMessage The success message to display. + * @return {void} Initializes the copy to clipboard functionality for style classes. + */ + }, { + key: "initStyleClassCopyToClipboard", + value: function initStyleClassCopyToClipboard(successMessage) { + var _this3 = this; + var labels = document.querySelectorAll('.frm-copy-text'); + labels.forEach(function (label) { + label.addEventListener('click', function (event) { + var className = event.currentTarget.innerText; + if (!navigator.clipboard || !navigator.clipboard.writeText) { + if (true === _this3.fallbackCopyToClipboard(className, event.currentTarget)) { + _this3.success(successMessage); + } + return; + } + navigator.clipboard.writeText(className).then(function () { + _this3.success(successMessage); + }); + }); + }); + } + + /** + * Toggle the visibility of the custom CSS editor. + * + * @return {void} + */ + }, { + key: "toggleVisibilityOfCustomCSSEditor", + value: function toggleVisibilityOfCustomCSSEditor() { + var toggle = document.getElementById('frm_enable_single_style_custom_css'); + var editor = document.getElementById('frm_single_style_custom_css_editor'); + if (!toggle || !editor) { + return; + } + toggle.addEventListener('change', function (event) { + editor.classList.toggle('frm_hidden', !event.target.checked); + }); + } + + /** + * Copy to clipboard if the Clipboard API is not available. + * + * @param {string} couponCode The string being copied to the clipboard. + * @param {HTMLElement} copyButton Used to position the temporary input element. + * @return {boolean} True if the copy was successful, false otherwise. + */ + }, { + key: "fallbackCopyToClipboard", + value: function fallbackCopyToClipboard(couponCode, copyButton) { + if ('function' !== typeof document.execCommand) { + return false; + } + var copySuccess; + var temp = document.createElement('input'); + temp.setAttribute('type', 'text'); + temp.value = couponCode; + copyButton.parentElement.append(temp); + temp.focus(); + temp.select(); + temp.setSelectionRange(0, 99999); + + // Hide the input so it doesn't show up in the UI. + temp.style.position = 'absolute'; + temp.style.left = '-9999px'; + temp.style.top = '-9999px'; + try { + copySuccess = document.execCommand('copy'); + } catch (error) { + copySuccess = false; + } + temp.remove(); + return copySuccess; + } + }]); +}(); +new frmStyleOptions(); +})(); + +/******/ })() +; +//# sourceMappingURL=formidable_styles.js.map \ No newline at end of file diff --git a/js/frm_testing_mode.js b/js/frm_testing_mode.js index 33b94e6693..485b5f52a7 100644 --- a/js/frm_testing_mode.js +++ b/js/frm_testing_mode.js @@ -1,2 +1,3485 @@ -/*! For license information please see frm_testing_mode.js.LICENSE.txt */ -(()=>{var e={65:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(8793),o=r(1323);function a(e){var t=(0,n.A)(e);return function(e){return(0,o.A)(t,e)}}},1323:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n={"!":function(e){return!e},"*":function(e,t){return e*t},"/":function(e,t){return e/t},"%":function(e,t){return e%t},"+":function(e,t){return e+t},"-":function(e,t){return e-t},"<":function(e,t){return e":function(e,t){return e>t},">=":function(e,t){return e>=t},"==":function(e,t){return e===t},"!=":function(e,t){return e!==t},"&&":function(e,t){return e&&t},"||":function(e,t){return e||t},"?:":function(e,t,r){if(e)throw t;return r}};function o(e,t){var r,o,a,i,s,l,c=[];for(r=0;r{"use strict";r.d(t,{A:()=>o});var n=r(65);function o(e){var t=(0,n.A)(e);return function(e){return+t({n:e})}}},8793:(e,t,r)=>{"use strict";var n,o,a,i;function s(e){for(var t,r,s,l,c=[],u=[];t=e.match(i);){for(r=t[0],(s=e.substr(0,t.index).trim())&&c.push(s);l=u.pop();){if(a[r]){if(a[r][0]===l){r=a[r][1]||r;break}}else if(o.indexOf(l)>=0||n[l]s}),n={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},o=["(","?"],a={")":["("],":":["?","?:"]},i=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/},7521:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(6956),o=r(7395);const a=function(e,t){return function(r,a,i){var s=arguments.length>3&&void 0!==arguments[3]?arguments[3]:10,l=e[t];if((0,o.A)(r)&&(0,n.A)(a))if("function"==typeof i)if("number"==typeof s){var c={callback:i,priority:s,namespace:a};if(l[r]){var u,d=l[r].handlers;for(u=d.length;u>0&&!(s>=d[u-1].priority);u--);u===d.length?d[u]=c:d.splice(u,0,c),l.__current.forEach(function(e){e.name===r&&e.currentIndex>=u&&e.currentIndex++})}else l[r]={handlers:[c],runs:0};"hookAdded"!==r&&e.doAction("hookAdded",r,a,i,s)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}}},11:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(){var r,n,o=e[t];return null!==(r=null===(n=o.__current[o.__current.length-1])||void 0===n?void 0:n.name)&&void 0!==r?r:null}}},5375:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(7395);const o=function(e,t){return function(r){var o=e[t];if((0,n.A)(r))return o[r]&&o[r].runs?o[r].runs:0}}},3561:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r){var n=e[t];return void 0===r?void 0!==n.__current[0]:!!n.__current[0]&&r===n.__current[0].name}}},8830:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r,n){var o=e[t];return void 0!==n?r in o&&o[r].handlers.some(function(e){return e.namespace===n}):r in o}}},7765:(e,t,r)=>{"use strict";r.d(t,{A:()=>f});var n=r(3029),o=r(7521),a=r(4194),i=r(8830),s=r(6763),l=r(11),c=r(3561),u=r(5375),d=function e(){(0,n.A)(this,e),this.actions=Object.create(null),this.actions.__current=[],this.filters=Object.create(null),this.filters.__current=[],this.addAction=(0,o.A)(this,"actions"),this.addFilter=(0,o.A)(this,"filters"),this.removeAction=(0,a.A)(this,"actions"),this.removeFilter=(0,a.A)(this,"filters"),this.hasAction=(0,i.A)(this,"actions"),this.hasFilter=(0,i.A)(this,"filters"),this.removeAllActions=(0,a.A)(this,"actions",!0),this.removeAllFilters=(0,a.A)(this,"filters",!0),this.doAction=(0,s.A)(this,"actions"),this.applyFilters=(0,s.A)(this,"filters",!0),this.currentAction=(0,l.A)(this,"actions"),this.currentFilter=(0,l.A)(this,"filters"),this.doingAction=(0,c.A)(this,"actions"),this.doingFilter=(0,c.A)(this,"filters"),this.didAction=(0,u.A)(this,"actions"),this.didFilter=(0,u.A)(this,"filters")};const f=function(){return new d}},4194:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(6956),o=r(7395);const a=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(a,i){var s=e[t];if((0,o.A)(a)&&(r||(0,n.A)(i))){if(!s[a])return 0;var l=0;if(r)l=s[a].handlers.length,s[a]={runs:s[a].runs,handlers:[]};else for(var c=s[a].handlers,u=function(e){c[e].namespace===i&&(c.splice(e,1),l++,s.__current.forEach(function(t){t.name===a&&t.currentIndex>=e&&t.currentIndex--}))},d=c.length-1;d>=0;d--)u(d);return"hookRemoved"!==a&&e.doAction("hookRemoved",a,i),l}}}},6763:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var o=e[t];o[n]||(o[n]={handlers:[],runs:0}),o[n].runs++;for(var a=o[n].handlers,i=arguments.length,s=new Array(i>1?i-1:0),l=1;l{"use strict";r.d(t,{se:()=>n});var n=(0,r(7765).A)();n.addAction,n.addFilter,n.removeAction,n.removeFilter,n.hasAction,n.hasFilter,n.removeAllActions,n.removeAllFilters,n.doAction,n.applyFilters,n.currentAction,n.currentFilter,n.doingAction,n.doingFilter,n.didAction,n.didFilter,n.actions,n.filters},7395:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The hook name must be a non-empty string."),!1):/^__/.test(e)?(console.error("The hook name cannot begin with `__`."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(e)||(console.error("The hook name can only contain numbers, letters, dashes, periods and underscores."),!1)}},6956:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The namespace must be a non-empty string."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(e)||(console.error("The namespace can only contain numbers, letters, dashes, periods, underscores and slashes."),!1)}},772:(e,t,r)=>{"use strict";r.d(t,{h:()=>c});var n=r(4467),o=r(5397);function a(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,n)}return r}function i(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:"default";n.data[t]=i(i(i({},s),n.data[t]),e),n.data[t][""]=i(i({},s[""]),n.data[t][""])},d=function(e,t){u(e,t),c()},f=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",t=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,a=arguments.length>4?arguments[4]:void 0;return n.data[e]||u(void 0,e),n.dcnpgettext(e,t,r,o,a)},p=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},m=function(e,t,n){var o=f(n,t,e);return r?(o=r.applyFilters("i18n.gettext_with_context",o,e,t,n),r.applyFilters("i18n.gettext_with_context_"+p(n),o,e,t,n)):o};if(e&&d(e,t),r){var v=function(e){l.test(e)&&c()};r.addAction("hookAdded","core/i18n",v),r.addAction("hookRemoved","core/i18n",v)}return{getLocaleData:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[e]},setLocaleData:d,resetLocaleData:function(e,t){n.data={},n.pluralForms={},d(e,t)},subscribe:function(e){return a.add(e),function(){return a.delete(e)}},__:function(e,t){var n=f(t,void 0,e);return r?(n=r.applyFilters("i18n.gettext",n,e,t),r.applyFilters("i18n.gettext_"+p(t),n,e,t)):n},_x:m,_n:function(e,t,n,o){var a=f(o,void 0,e,t,n);return r?(a=r.applyFilters("i18n.ngettext",a,e,t,n,o),r.applyFilters("i18n.ngettext_"+p(o),a,e,t,n,o)):a},_nx:function(e,t,n,o,a){var i=f(a,o,e,t,n);return r?(i=r.applyFilters("i18n.ngettext_with_context",i,e,t,n,o,a),r.applyFilters("i18n.ngettext_with_context_"+p(a),i,e,t,n,o,a)):i},isRTL:function(){return"rtl"===m("ltr","text direction")},hasTranslation:function(e,t,o){var a,i,s=t?t+""+e:e,l=!(null===(a=n.data)||void 0===a||null===(i=a[null!=o?o:"default"])||void 0===i||!i[s]);return r&&(l=r.applyFilters("i18n.has_translation",l,e,t,o),l=r.applyFilters("i18n.has_translation_"+p(o),l,e,t,o)),l}}}},5839:(e,t,r)=>{"use strict";r.d(t,{__:()=>i});var n=r(772),o=r(2133),a=(0,n.h)(void 0,void 0,o.se),i=(a.getLocaleData.bind(a),a.setLocaleData.bind(a),a.resetLocaleData.bind(a),a.subscribe.bind(a),a.__.bind(a));a._x.bind(a),a._n.bind(a),a._nx.bind(a),a.isRTL.bind(a),a.hasTranslation.bind(a)},9575:(e,t,r)=>{"use strict";r.d(t,{__:()=>n.__}),r(181),r(772);var n=r(5839)},181:(e,t,r)=>{"use strict";var n=r(8616),o=r.n(n);r(7604),o()(console.error)},1105:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addonError:()=>f,afterAddonInstall:()=>d,extractErrorFromAddOnResponse:()=>u,toggleAddonState:()=>c});var n=r(9575);function o(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,a,i,s=[],l=!0,c=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;l=!1}else for(;!(l=(n=a.call(r)).done)&&(s.push(n.value),s.length!==t);l=!0);}catch(e){c=!0,o=e}finally{try{if(!l&&null!=r.return&&(i=r.return(),Object(i)!==i))return}finally{if(c)throw o}}return s}}(e,t)||function(e,t){if(e){if("string"==typeof e)return a(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?a(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function a(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r5&&void 0!==arguments[5]?arguments[5]:"frm_activate_addon",u=frm_admin_js,d=document.querySelectorAll(".frm-addon-status");d.forEach(function(t){t.textContent=e,t.style.display="block"}),t.css({opacity:"0"}),document.querySelectorAll(".frm-oneclick").forEach(function(e){e.style.display="none"}),function(){var e=document.getElementById("frm_upgrade_modal");if(e){e.classList.add("frm-success");var t=e.querySelector(".frm-upgrade-message");if(t){var r=t.querySelector("img");t.replaceChildren((0,n.__)("Great! Everything's ready to go!","formidable"),document.createElement("br"),(0,n.__)("You just need to refresh the builder so the new field becomes available.","formidable")),r&&t.append(r)}var o=document.querySelector(".frm-addon-status");o&&(o.textContent="");var a,i=e.querySelector(".frm-circled-icon");if(i)i.classList.add("frm-circled-icon-green"),null===(a=i.querySelector("svg"))||void 0===a||a.replaceWith(l({href:"#frm_checkmark_icon"}))}}();var f={frm_activate_addon:{class:"frm-addon-active",message:u.active},frm_deactivate_addon:{class:"frm-addon-installed",message:u.installed},frm_uninstall_addon:{class:"frm-addon-not-installed",message:u.not_installed}};f.frm_install_addon=f.frm_activate_addon;var m=o(r,1)[0];m&&(m.textContent=f[c].message);var v=o(a,1)[0].parentElement;v.classList.remove("frm-addon-not-installed","frm-addon-installed","frm-addon-active"),v.classList.add(f[c].class),o(t,1)[0].classList.remove("frm_loading_button"),document.querySelectorAll(".frm-admin-page-import, #frm-admin-smtp, #frm-welcome").length>0?window.location.reload():["settings","form_builder"].includes(i)&&d.forEach(function(e){var t=null!==e.closest("#frm_upgrade_modal");e.append(function(e,t){var r,o=[p(e)];return t&&o.push(((r=document.createElement("a")).setAttribute("href","#"),r.classList.add("button","button-secondary","frm-button-secondary","dismiss"),r.textContent=(0,n.__)("Not Now","formidable"),r)),s({className:"frm-save-and-reload-options",children:o})}(i,t))})}function f(e,t,r){e.form?(jQuery(".frm-inline-error").remove(),r.closest(".frm-card").html(e.form).css({padding:5}).find("#upgrade").attr("rel",r.attr("rel")).on("click",m)):(t.append('

            '.concat(e.message,"

            ")),r.removeClass("frm_loading_button"),jQuery(".frm-addon-error").delay(4e3).fadeOut())}function p(e){var t=document.createElement("button");return t.classList.add("frm-save-and-reload","button","button-primary","frm-button-primary"),t.textContent=(0,n.__)("Save and Reload","formidable"),t.addEventListener("click",function(){var t;"form_builder"===e?((t=document.getElementById("frm_submit_side_top")).classList.contains("frm_submit_ajax")&&t.setAttribute("data-new-addon-installed",!0),t.click()):"settings"===e&&function(){var e=document.getElementById("form_settings_page");if(e){var t=e.querySelector("form.frm_form_settings");null!==t&&(wp.hooks.doAction("frm_reset_fields_updated"),t.submit())}}()}),t}function m(e){e.preventDefault();var t=jQuery(this),r=t.parent().parent(),n=t.attr("rel");t.addClass("frm_loading_button"),jQuery.ajax({url:ajaxurl,type:"POST",async:!0,cache:!1,dataType:"json",data:{action:"frm_install_addon",nonce:frmAdminJs.nonce,plugin:n,hostname:r.find("#hostname").val(),username:r.find("#username").val(),password:r.find("#password").val()},success:function(e){var n,o,a=u(e=null!==(n=null===(o=e)||void 0===o?void 0:o.data)&&void 0!==n?n:e);a?f(a,r,t):d(e,t,message,r)},error:function(){t.removeClass("frm_loading_button")}})}},4260:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addOneClick:()=>a,initModal:()=>i,initUpgradeModal:()=>s});var n=r(9575),o=frmDom.svg;function a(e,t,r){var a;if("modal"===t)a=document.getElementById("frm_upgrade_modal");else{if("tab"!==t)return;a=document.getElementById(e.getAttribute("href").substr(1))}var i,s=a.querySelector(".frm-oneclick"),l=a.querySelector(".frm-upgrade-message"),c=a.querySelector(".frm-upgrade-link"),u=a.querySelector(".frm-oneclick-button"),d=a.querySelector(".frm-addon-status"),f=e.getAttribute("data-oneclick"),p=e.getAttribute("data-message"),m="block",v="block",y="none",h=a.querySelector(".frm-circled-icon");h&&(h.classList.remove("frm-circled-icon-green"),null===(i=h.querySelector("svg"))||void 0===i||i.replaceWith(o({href:"#frm_filled_lock_icon"})));var g=a.querySelector(".frm-learn-more");if(g&&(g.href=e.dataset.learnMore),null!==s&&null!==u&&void 0!==f&&f){null===p&&(v="none"),m="none",y="block",f=JSON.parse(f),u.className=u.className.replace(" frm-install-addon","").replace(" frm-activate-addon",""),u.className="".concat(u.className," ").concat(f.class),u.rel=f.url,s.textContent=(0,n.__)("This plugin is not activated. Would you like to activate it now?","formidable"),u.textContent=(0,n.__)("Activate","formidable");var _=e.querySelector("use");_&&(null==h||h.querySelector("svg").replaceWith(o({href:_.getAttribute("href")||_.getAttribute("xlink:href"),classList:["frm_svg32"]})))}p||(p=l.getAttribute("data-default")),void 0!==r&&(p=p.replace('',r)),l.innerHTML=p,e.dataset.upsellImage&&l.append(frmDom.img({src:e.dataset.upsellImage,alt:e.dataset.upgrade})),c.href=function(e,t){var r=e.getAttribute("data-link");return null!=r&&""!==r||(r=t.getAttribute("data-default")),r}(e,c),d.style.display="none",s&&(s.style.display=y),u&&(u.style.display="block"===y?"inline-block":y),l.style.display=v,c.style.display="block"===m?"inline-block":m;var b=c.closest(".frm-upgrade-modal-actions");b&&(b.style.display="block"===m?"flex":m)}function i(e,t){var r=jQuery(e);if(!r.length)return!1;void 0===t&&(t="552px");var n={dialogClass:"frm-dialog",modal:!0,autoOpen:!1,closeOnEscape:!0,width:t,resizable:!1,draggable:!1,open:function(){var e,t;jQuery(".ui-dialog-titlebar").addClass("frm_hidden").removeClass("ui-helper-clearfix"),jQuery("#wpwrap").addClass("frm_overlay"),jQuery(".frm-dialog").removeClass("ui-widget ui-widget-content ui-corner-all"),r.removeClass("ui-dialog-content ui-widget-content"),e=r,t=function(){e.dialog("close")},jQuery(".ui-widget-overlay").on("click",t),e.on("click","a.dismiss",t)},close:function(){jQuery("#wpwrap").removeClass("frm_overlay"),jQuery(".spinner").css("visibility","hidden"),this.removeAttribute("data-option-type");var e=document.getElementById("bulk-option-type");e&&(e.value="")}};return r.dialog(n),r}function s(){var e=i("#frm_upgrade_modal");function t(t){var r,o,i;if((r=t.target).classList){var s=r.classList.contains("frm_show_expired_modal")||null!==r.querySelector(".frm_show_expired_modal")||r.closest(".frm_show_expired_modal");if("change"===t.type&&r.classList.contains("frm_select_with_upgrade")){var l=r.options[r.selectedIndex];l&&l.dataset.upgrade&&(r=l)}if(!r.dataset.upgrade){var c=r.closest("[data-upgrade]");if(!c){if(!(c=r.closest(".frm_field_box")))return;r.dataset.upgrade=""}r=c}if(s)wp.hooks.doAction("frm_show_expired_modal",r);else{var u=r.dataset.upgrade;if(u&&!r.classList.contains("frm_show_upgrade_tab")){t.preventDefault();var d=e.get(0);d.classList.remove("frm-success");var f=d.querySelector(".frm_lock_icon");f&&(f.style.display="block",f.classList.remove("frm_lock_open_icon"),f.querySelector("use").setAttribute("href","#frm_lock_icon"));var p="frm_upgrade_modal_image",m=document.getElementById(p);m&&m.remove(),r.dataset.image&&f&&(f.style.display="none",f.parentNode.insertBefore(frmDom.img({id:p,src:"".concat(frmGlobal.url,"/images/").concat(r.dataset.image)}),f));var v=d.querySelector(".license-level");v&&(v.textContent=function(e){return e.dataset.requires?e.dataset.requires:"Pro"}(r)),a(r,"modal",u);var y=d.querySelector(".frm_are_not_installed");y.style.display=r.dataset.image||r.dataset.oneclick?"none":"inline-block",y.textContent=y.dataset.default,d.querySelector(".frm-upgrade-modal-title-prefix").style.display=r.dataset.oneclick?"inline":"none",d.querySelector(".frm_feature_label").textContent=u,d.querySelector(".frm-upgrade-modal-title-suffix").style.display="none",d.querySelector("h2").style.display="block",e.dialog("open");var h=d.querySelector(".button-primary:not(.frm-oneclick-button)");o=h.getAttribute("href").replace(/(medium=)[a-z_-]+/gi,"$1".concat(r.getAttribute("data-medium"))),null===(i=r.getAttribute("data-content"))&&(i=""),o=o.replace(/(content=)[a-z_-]+/gi,"$1".concat(i)),h.setAttribute("href",o),r.classList.contains("frm_show_update")&&function(e){var t=e.querySelector(".frm-upgrade-modal-title-prefix");t&&(t.style.display="none");var r=e.querySelector(".frm_are_not_installed");r&&(r.textContent=(0,n.__)("require an update","formidable"),r.style.display="");var o=e.querySelector(".frm-oneclick");o&&(o.style.display="none");var a=e.querySelector(".frm-oneclick-button");a&&(a.textContent=(0,n.__)("Update Now","formidable"))}(d)}}}}!1!==e&&(document.addEventListener("click",t),frmDom.util.documentOn("change","select.frm_select_with_upgrade",t))}},8616:e=>{e.exports=function(e,t){var r,n,o=0;function a(){var a,i,s=r,l=arguments.length;e:for(;s;){if(s.args.length===arguments.length){for(i=0;i{var n;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function a(e){return function(e,t){var r,n,i,s,l,c,u,d,f,p=1,m=e.length,v="";for(n=0;n=0),s.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,s.width?parseInt(s.width):0);break;case"e":r=s.precision?parseFloat(r).toExponential(s.precision):parseFloat(r).toExponential();break;case"f":r=s.precision?parseFloat(r).toFixed(s.precision):parseFloat(r);break;case"g":r=s.precision?String(Number(r.toPrecision(s.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=s.precision?r.substring(0,s.precision):r;break;case"t":r=String(!!r),r=s.precision?r.substring(0,s.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=s.precision?r.substring(0,s.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=s.precision?r.substring(0,s.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}o.json.test(s.type)?v+=r:(!o.number.test(s.type)||d&&!s.sign?f="":(f=d?"+":"-",r=r.toString().replace(o.sign,"")),c=s.pad_char?"0"===s.pad_char?"0":s.pad_char.charAt(1):" ",u=s.width-(f+r).length,l=s.width&&u>0?c.repeat(u):"",v+=s.align?f+r+l:"0"===c?f+l+r:l+f+r)}return v}(function(e){if(s[e])return s[e];for(var t,r=e,n=[],a=0;r;){if(null!==(t=o.text.exec(r)))n.push(t[0]);else if(null!==(t=o.modulo.exec(r)))n.push("%");else{if(null===(t=o.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){a|=1;var i=[],l=t[2],c=[];if(null===(c=o.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(i.push(c[1]);""!==(l=l.substring(c[0].length));)if(null!==(c=o.key_access.exec(l)))i.push(c[1]);else{if(null===(c=o.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");i.push(c[1])}t[2]=i}else a|=2;if(3===a)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return s[e]=n}(e),arguments)}function i(e,t){return a.apply(null,[e].concat(t||[]))}var s=Object.create(null);"undefined"!=typeof window&&(window.sprintf=a,window.vsprintf=i,void 0===(n=function(){return{sprintf:a,vsprintf:i}}.call(t,r,t,e))||(e.exports=n))}()},5397:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(1364),o={contextDelimiter:"",onMissingKey:null};function a(e,t){var r;for(r in this.data=e,this.pluralForms={},this.options={},o)this.options[r]=void 0!==t&&r in t?t[r]:o[r]}a.prototype.getPluralForm=function(e,t){var r,o,a,i=this.pluralForms[e];return i||("function"!=typeof(a=(r=this.data[e][""])["Plural-Forms"]||r["plural-forms"]||r.plural_forms)&&(o=function(e){var t,r,n;for(t=e.split(";"),r=0;r{"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}r.d(t,{A:()=>n})},4467:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(9922);function o(e,t,r){return(t=(0,n.A)(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}},2327:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(2284);function o(e,t){if("object"!=(0,n.A)(e)||!e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var o=r.call(e,t||"default");if("object"!=(0,n.A)(o))return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}},9922:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(2284),o=r(2327);function a(e){var t=(0,o.A)(e,"string");return"symbol"==(0,n.A)(t)?t:t+""}},2284:(e,t,r)=>{"use strict";function n(e){return n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(e)}r.d(t,{A:()=>n})}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var a=t[n]={exports:{}};return e[n](a,a.exports,r),a.exports}function n(){var e,t,r="function"==typeof Symbol?Symbol:{},a=r.iterator||"@@iterator",i=r.toStringTag||"@@toStringTag";function s(r,n,a,i){var s=n&&n.prototype instanceof c?n:c,u=Object.create(s.prototype);return o(u,"_invoke",function(r,n,o){var a,i,s,c=0,u=o||[],d=!1,f={p:0,n:0,v:e,a:p,f:p.bind(e,4),d:function(t,r){return a=t,i=0,s=e,f.n=r,l}};function p(r,n){for(i=r,s=n,t=0;!d&&c&&!o&&t3?(o=m===n)&&(s=a[(i=a[4])?5:(i=3,3)],a[4]=a[5]=e):a[0]<=p&&((o=r<2&&pn||n>m)&&(a[4]=r,a[5]=n,f.n=m,i=0))}if(o||r>1)return l;throw d=!0,n}return function(o,u,m){if(c>1)throw TypeError("Generator is already running");for(d&&1===u&&p(u,m),i=u,s=m;(t=i<2?e:s)||!d;){a||(i?i<3?(i>1&&(f.n=-1),p(i,s)):f.n=s:f.v=s);try{if(c=2,a){if(i||(o="next"),t=a[o]){if(!(t=t.call(a,s)))throw TypeError("iterator result is not an object");if(!t.done)return t;s=t.value,i<2&&(i=0)}else 1===i&&(t=a.return)&&t.call(a),i<2&&(s=TypeError("The iterator does not provide a '"+o+"' method"),i=1);a=e}else if((t=(d=f.n<0)?s:r.call(n,f))!==l)break}catch(t){a=e,i=1,s=t}finally{c=1}}return{value:t,done:d}}}(r,a,i),!0),u}var l={};function c(){}function u(){}function d(){}t=Object.getPrototypeOf;var f=[][a]?t(t([][a]())):(o(t={},a,function(){return this}),t),p=d.prototype=c.prototype=Object.create(f);function m(e){return Object.setPrototypeOf?Object.setPrototypeOf(e,d):(e.__proto__=d,o(e,i,"GeneratorFunction")),e.prototype=Object.create(p),e}return u.prototype=d,o(p,"constructor",d),o(d,"constructor",u),u.displayName="GeneratorFunction",o(d,i,"GeneratorFunction"),o(p),o(p,i,"Generator"),o(p,a,function(){return this}),o(p,"toString",function(){return"[object Generator]"}),(n=function(){return{w:s,m}})()}function o(e,t,r,n){var a=Object.defineProperty;try{a({},"",{})}catch(e){a=0}o=function(e,t,r,n){function i(t,r){o(e,t,function(e){return this._invoke(t,r,e)})}t?a?a(e,t,{value:r,enumerable:!n,configurable:!n,writable:!n}):e[t]=r:(i("next",0),i("throw",1),i("return",2))},o(e,t,r,n)}function a(e,t,r,n,o,a,i){try{var s=e[a](i),l=s.value}catch(e){return void r(e)}s.done?t(l):Promise.resolve(l).then(n,o)}r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},function(){var e=r(1105).toggleAddonState;function t(){jQuery(document).on("click","#frm_upgrade_modal .frm-install-addon",function(t){t.preventDefault(),e(this,"frm_install_addon")}),jQuery(document).on("click","#frm_upgrade_modal .frm-activate-addon",function(t){t.preventDefault(),e(this,"frm_activate_addon")}),function(){o.apply(this,arguments)}(),i(),jQuery(document).on("mouseenter.frm",".frm_help",function(){jQuery(this).off("mouseenter.frm"),jQuery(this).tooltip("show")})}function o(){var e;return e=n().m(function e(){return n().w(function(e){for(;;)switch(e.n){case 0:return e.n=1,Promise.resolve().then(r.bind(r,4260));case 1:e.v.initUpgradeModal();case 2:return e.a(2)}},e)}),o=function(){var t=this,r=arguments;return new Promise(function(n,o){var i=e.apply(t,r);function s(e){a(i,n,o,s,l,"next",e)}function l(e){a(i,n,o,s,l,"throw",e)}s(void 0)})},o.apply(this,arguments)}function i(){var e=window.frmDom;e.bootstrap.setupBootstrapDropdowns(function(){var e=document.querySelector("#frm_testmode_enabled_form_actions .dropdown-toggle");e&&(e.classList.add("frm-dropdown-toggle"),e.hasAttribute("role")||e.setAttribute("role","button"),e.hasAttribute("tabindex")||e.setAttribute("tabindex",0))});var t=document.getElementById("frm_testmode_enabled_form_actions");t&&(t.style.display="none",e.bootstrap.multiselect.init.bind(t)(),t.disabled&&t.parentElement.querySelector(".dropdown-toggle").classList.add("frm_noallow"))}"complete"===document.readyState?t():document.addEventListener("DOMContentLoaded",t),document.addEventListener("frm_after_start_over",function(){i()}),jQuery(document).on("frmPageChanged frmFormComplete",function(){i()})}()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/admin/addon-state.js": +/*!*************************************!*\ + !*** ./js/src/admin/addon-state.js ***! + \*************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addonError: () => (/* binding */ addonError), +/* harmony export */ afterAddonInstall: () => (/* binding */ afterAddonInstall), +/* harmony export */ extractErrorFromAddOnResponse: () => (/* binding */ extractErrorFromAddOnResponse), +/* harmony export */ toggleAddonState: () => (/* binding */ toggleAddonState) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } +function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } + +var _frmDom = frmDom, + div = _frmDom.div, + svg = _frmDom.svg; + +/** + * Toggles the state of an add-on (ie. enable or disable an add-on). + * + * @param {Element} clicked + * @param {string} action + */ +function toggleAddonState(clicked, action) { + var _window$ajaxurl; + var ajaxurl = (_window$ajaxurl = window.ajaxurl) !== null && _window$ajaxurl !== void 0 ? _window$ajaxurl : frm_js.ajax_url; + + // Remove any leftover error messages, output an icon and get the plugin basename that needs to be activated. + jQuery('.frm-addon-error').remove(); + var button = jQuery(clicked); + var plugin = button.attr('rel'); + var el = button.parent(); + var message = el.parent().find('.addon-status-label'); + button.addClass('frm_loading_button'); + + // Process the Ajax to perform the activation. + jQuery.ajax({ + url: ajaxurl, + type: 'POST', + async: true, + cache: false, + dataType: 'json', + data: { + action: action, + nonce: frmGlobal.nonce, + plugin: plugin + }, + success: function success(response) { + var _response$data, _response; + response = (_response$data = (_response = response) === null || _response === void 0 ? void 0 : _response.data) !== null && _response$data !== void 0 ? _response$data : response; + var saveAndReload; + if ('string' !== typeof response && 'string' === typeof response.message) { + if (response.saveAndReload !== undefined) { + saveAndReload = response.saveAndReload; + } + response = response.message; + } + var error = extractErrorFromAddOnResponse(response); + if (error) { + addonError(error, el, button); + return; + } + afterAddonInstall(response, button, message, el, saveAndReload, action); + + /** + * Trigger an action after successfully toggling the addon state. + * + * @param {Object} response + */ + wp.hooks.doAction('frm_update_addon_state', response); + }, + error: function error() { + button.removeClass('frm_loading_button'); + } + }); +} +function extractErrorFromAddOnResponse(response) { + if (typeof response !== 'string') { + if (response.success) { + return false; + } + if (response.form) { + if (jQuery(response.form).is('#message')) { + return { + message: jQuery(response.form).find('p').html() + }; + } + } + return response; + } + return false; +} +function afterAddonInstall(response, button, message, el, saveAndReload) { + var action = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 'frm_activate_addon'; + var frmAdminJs = frm_admin_js; + var addonStatuses = document.querySelectorAll('.frm-addon-status'); + addonStatuses.forEach(function (addonStatus) { + addonStatus.textContent = response; + addonStatus.style.display = 'block'; + }); + + // The Ajax request was successful, so let's update the output. + button.css({ + opacity: '0' + }); + document.querySelectorAll('.frm-oneclick').forEach(function (oneClick) { + oneClick.style.display = 'none'; + }); + showUpgradeModalSuccess(); + + // Proceed with CSS changes + var actionMap = { + frm_activate_addon: { + class: 'frm-addon-active', + message: frmAdminJs.active + }, + frm_deactivate_addon: { + class: 'frm-addon-installed', + message: frmAdminJs.installed + }, + frm_uninstall_addon: { + class: 'frm-addon-not-installed', + message: frmAdminJs.not_installed + } + }; + actionMap.frm_install_addon = actionMap.frm_activate_addon; + var _message = _slicedToArray(message, 1), + messageElement = _message[0]; + if (messageElement) { + messageElement.textContent = actionMap[action].message; + } + var _el = _slicedToArray(el, 1), + parentElement = _el[0].parentElement; + parentElement.classList.remove('frm-addon-not-installed', 'frm-addon-installed', 'frm-addon-active'); + parentElement.classList.add(actionMap[action].class); + var _button = _slicedToArray(button, 1), + buttonElement = _button[0]; + buttonElement.classList.remove('frm_loading_button'); + + // Maybe refresh import and SMTP pages + var refreshPage = document.querySelectorAll('.frm-admin-page-import, #frm-admin-smtp, #frm-welcome'); + if (refreshPage.length > 0) { + window.location.reload(); + return; + } + if (['settings', 'form_builder'].includes(saveAndReload)) { + addonStatuses.forEach(function (addonStatus) { + var inModal = null !== addonStatus.closest('#frm_upgrade_modal'); + addonStatus.append(getSaveAndReloadSettingsOptions(saveAndReload, inModal)); + }); + } +} +function addonError(response, el, button) { + if (response.form) { + jQuery('.frm-inline-error').remove(); + button.closest('.frm-card').html(response.form).css({ + padding: 5 + }).find('#upgrade').attr('rel', button.attr('rel')).on('click', installAddonWithCreds); + } else { + el.append("

            ".concat(response.message, "

            ")); + button.removeClass('frm_loading_button'); + jQuery('.frm-addon-error').delay(4000).fadeOut(); + } +} +function getSaveAndReloadSettingsOptions(saveAndReload, inModal) { + var className = 'frm-save-and-reload-options'; + var children = [saveAndReloadSettingsButton(saveAndReload)]; + if (inModal) { + children.push(closePopupButton()); + } + return div({ + className: className, + children: children + }); +} +function saveAndReloadSettingsButton(saveAndReload) { + var button = document.createElement('button'); + button.classList.add('frm-save-and-reload', 'button', 'button-primary', 'frm-button-primary'); + button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Save and Reload', 'formidable'); + button.addEventListener('click', function () { + if (saveAndReload === 'form_builder') { + saveAndReloadFormBuilder(); + } else if (saveAndReload === 'settings') { + saveAndReloadSettings(); + } + }); + return button; +} +function saveAndReloadSettings() { + var page = document.getElementById('form_settings_page'); + if (page) { + var form = page.querySelector('form.frm_form_settings'); + if (null !== form) { + wp.hooks.doAction('frm_reset_fields_updated'); + form.submit(); + } + } +} +function closePopupButton() { + var a = document.createElement('a'); + a.setAttribute('href', '#'); + a.classList.add('button', 'button-secondary', 'frm-button-secondary', 'dismiss'); + a.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Not Now', 'formidable'); + return a; +} +function saveAndReloadFormBuilder() { + var submitButton = document.getElementById('frm_submit_side_top'); + if (submitButton.classList.contains('frm_submit_ajax')) { + submitButton.setAttribute('data-new-addon-installed', true); + } + submitButton.click(); +} + +/** + * Updates the upgrade modal to show successful addon installation state. + * + * @private + * @return {void} + */ +function showUpgradeModalSuccess() { + var upgradeModal = document.getElementById('frm_upgrade_modal'); + if (!upgradeModal) { + return; + } + upgradeModal.classList.add('frm-success'); + var upgradeMessage = upgradeModal.querySelector('.frm-upgrade-message'); + if (upgradeMessage) { + var image = upgradeMessage.querySelector('img'); + upgradeMessage.replaceChildren((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Great! Everything\'s ready to go!', 'formidable'), document.createElement('br'), (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You just need to refresh the builder so the new field becomes available.', 'formidable')); + if (image) { + upgradeMessage.append(image); + } + } + var frmAddonStatus = document.querySelector('.frm-addon-status'); + if (frmAddonStatus) { + frmAddonStatus.textContent = ''; + } + var circledIcon = upgradeModal.querySelector('.frm-circled-icon'); + if (circledIcon) { + var _circledIcon$querySel; + circledIcon.classList.add('frm-circled-icon-green'); + (_circledIcon$querySel = circledIcon.querySelector('svg')) === null || _circledIcon$querySel === void 0 || _circledIcon$querySel.replaceWith(svg({ + href: '#frm_checkmark_icon' + })); + } +} +function installAddonWithCreds(e) { + // Prevent the default action, let the user know we are attempting to install again and go with it. + e.preventDefault(); + + // Now let's make another Ajax request once the user has submitted their credentials. + var proceed = jQuery(this); + var el = proceed.parent().parent(); + var plugin = proceed.attr('rel'); + proceed.addClass('frm_loading_button'); + jQuery.ajax({ + url: ajaxurl, + type: 'POST', + async: true, + cache: false, + dataType: 'json', + data: { + action: 'frm_install_addon', + nonce: frmAdminJs.nonce, + plugin: plugin, + hostname: el.find('#hostname').val(), + username: el.find('#username').val(), + password: el.find('#password').val() + }, + success: function success(response) { + var _response$data2, _response2; + response = (_response$data2 = (_response2 = response) === null || _response2 === void 0 ? void 0 : _response2.data) !== null && _response$data2 !== void 0 ? _response$data2 : response; + var error = extractErrorFromAddOnResponse(response); + if (error) { + addonError(error, el, proceed); + return; + } + afterAddonInstall(response, proceed, message, el); + }, + error: function error() { + proceed.removeClass('frm_loading_button'); + } + }); +} + +/***/ }), + +/***/ "./js/src/admin/upgrade-popup.js": +/*!***************************************!*\ + !*** ./js/src/admin/upgrade-popup.js ***! + \***************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addOneClick: () => (/* binding */ addOneClick), +/* harmony export */ initModal: () => (/* binding */ initModal), +/* harmony export */ initUpgradeModal: () => (/* binding */ initUpgradeModal) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); + +var _frmDom = frmDom, + svg = _frmDom.svg; +function getShowLinkHrefValue(link, showLink) { + var customLink = link.getAttribute('data-link'); + if (customLink === null || customLink === undefined || customLink === '') { + customLink = showLink.getAttribute('data-default'); + } + return customLink; +} + +/** + * Allow addons to be installed from the upgrade modal. + * + * @param {Element} link + * @param {string} context Either 'modal' or 'tab'. + * @param {string|undefined} upgradeLabel + */ +function addOneClick(link, context, upgradeLabel) { + var container; + if ('modal' === context) { + container = document.getElementById('frm_upgrade_modal'); + } else if ('tab' === context) { + container = document.getElementById(link.getAttribute('href').substr(1)); + } else { + return; + } + var oneclickMessage = container.querySelector('.frm-oneclick'); + var upgradeMessage = container.querySelector('.frm-upgrade-message'); + var showLink = container.querySelector('.frm-upgrade-link'); + var button = container.querySelector('.frm-oneclick-button'); + var addonStatus = container.querySelector('.frm-addon-status'); + var oneclick = link.getAttribute('data-oneclick'); + var newMessage = link.getAttribute('data-message'); + var showIt = 'block'; + var showMsg = 'block'; + var hideIt = 'none'; + var modalIconWrapper = container.querySelector('.frm-circled-icon'); + if (modalIconWrapper) { + var _modalIconWrapper$que; + modalIconWrapper.classList.remove('frm-circled-icon-green'); + (_modalIconWrapper$que = modalIconWrapper.querySelector('svg')) === null || _modalIconWrapper$que === void 0 || _modalIconWrapper$que.replaceWith(svg({ + href: '#frm_filled_lock_icon' + })); + } + var learnMoreLink = container.querySelector('.frm-learn-more'); + if (learnMoreLink) { + learnMoreLink.href = link.dataset.learnMore; + } + + // If one click upgrade, hide other content. + if (oneclickMessage !== null && button !== null && oneclick !== undefined && oneclick) { + if (newMessage === null) { + showMsg = 'none'; + } + showIt = 'none'; + hideIt = 'block'; + oneclick = JSON.parse(oneclick); + button.className = button.className.replace(' frm-install-addon', '').replace(' frm-activate-addon', ''); + button.className = "".concat(button.className, " ").concat(oneclick.class); + button.rel = oneclick.url; + oneclickMessage.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('This plugin is not activated. Would you like to activate it now?', 'formidable'); + button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Activate', 'formidable'); + var linkIcon = link.querySelector('use'); + if (linkIcon) { + modalIconWrapper === null || modalIconWrapper === void 0 || modalIconWrapper.querySelector('svg').replaceWith(svg({ + href: linkIcon.getAttribute('href') || linkIcon.getAttribute('xlink:href'), + // Get the icon from xlink:href if it has not been updated to use href + classList: ['frm_svg32'] + })); + } + } + if (!newMessage) { + newMessage = upgradeMessage.getAttribute('data-default'); + } + if (undefined !== upgradeLabel) { + newMessage = newMessage.replace('', upgradeLabel); + } + upgradeMessage.innerHTML = newMessage; + if (link.dataset.upsellImage) { + upgradeMessage.append(frmDom.img({ + src: link.dataset.upsellImage, + alt: link.dataset.upgrade + })); + } + + // Either set the link or use the default. + showLink.href = getShowLinkHrefValue(link, showLink); + addonStatus.style.display = 'none'; + if (oneclickMessage) { + oneclickMessage.style.display = hideIt; + } + if (button) { + button.style.display = hideIt === 'block' ? 'inline-block' : hideIt; + } + upgradeMessage.style.display = showMsg; + showLink.style.display = showIt === 'block' ? 'inline-block' : showIt; + var showLinkParent = showLink.closest('.frm-upgrade-modal-actions'); + if (showLinkParent) { + showLinkParent.style.display = showIt === 'block' ? 'flex' : showIt; + } +} +function initModal(id, width) { + var $info = jQuery(id); + if (!$info.length) { + return false; + } + if (width === undefined) { + width = '552px'; + } + var dialogArgs = { + dialogClass: 'frm-dialog', + modal: true, + autoOpen: false, + closeOnEscape: true, + width: width, + resizable: false, + draggable: false, + open: function open() { + jQuery('.ui-dialog-titlebar').addClass('frm_hidden').removeClass('ui-helper-clearfix'); + jQuery('#wpwrap').addClass('frm_overlay'); + jQuery('.frm-dialog').removeClass('ui-widget ui-widget-content ui-corner-all'); + $info.removeClass('ui-dialog-content ui-widget-content'); + bindClickForDialogClose($info); + }, + close: function close() { + jQuery('#wpwrap').removeClass('frm_overlay'); + jQuery('.spinner').css('visibility', 'hidden'); + this.removeAttribute('data-option-type'); + var optionType = document.getElementById('bulk-option-type'); + if (optionType) { + optionType.value = ''; + } + } + }; + $info.dialog(dialogArgs); + return $info; +} +function bindClickForDialogClose($modal) { + var closeModal = function closeModal() { + $modal.dialog('close'); + }; + jQuery('.ui-widget-overlay').on('click', closeModal); + $modal.on('click', 'a.dismiss', closeModal); +} +function initUpgradeModal() { + var $info = initModal('#frm_upgrade_modal'); + if ($info === false) { + return; + } + document.addEventListener('click', handleUpgradeClick); + frmDom.util.documentOn('change', 'select.frm_select_with_upgrade', handleUpgradeClick); + function handleUpgradeClick(event) { + var element; + var link; + var content; + element = event.target; + if (!element.classList) { + return; + } + var showExpiredModal = element.classList.contains('frm_show_expired_modal') || null !== element.querySelector('.frm_show_expired_modal') || element.closest('.frm_show_expired_modal'); + + // If a `select` element is clicked, check if the selected option has a 'data-upgrade' attribute + if (event.type === 'change' && element.classList.contains('frm_select_with_upgrade')) { + var selectedOption = element.options[element.selectedIndex]; + if (selectedOption && selectedOption.dataset.upgrade) { + element = selectedOption; + } + } + if (!element.dataset.upgrade) { + var parent = element.closest('[data-upgrade]'); + if (!parent) { + parent = element.closest('.frm_field_box'); + if (!parent) { + return; + } + // Fake it if it's missing to avoid error. + element.dataset.upgrade = ''; + } + element = parent; + } + if (showExpiredModal) { + var hookName = 'frm_show_expired_modal'; + wp.hooks.doAction(hookName, element); + return; + } + var upgradeLabel = element.dataset.upgrade; + if (!upgradeLabel || element.classList.contains('frm_show_upgrade_tab')) { + return; + } + event.preventDefault(); + var modal = $info.get(0); + modal.classList.remove('frm-success'); + var lockIcon = modal.querySelector('.frm_lock_icon'); + if (lockIcon) { + lockIcon.style.display = 'block'; + lockIcon.classList.remove('frm_lock_open_icon'); + lockIcon.querySelector('use').setAttribute('href', '#frm_lock_icon'); + } + var upgradeImageId = 'frm_upgrade_modal_image'; + var oldImage = document.getElementById(upgradeImageId); + if (oldImage) { + oldImage.remove(); + } + if (element.dataset.image && lockIcon) { + lockIcon.style.display = 'none'; + lockIcon.parentNode.insertBefore(frmDom.img({ + id: upgradeImageId, + src: "".concat(frmGlobal.url, "/images/").concat(element.dataset.image) + }), lockIcon); + } + var level = modal.querySelector('.license-level'); + if (level) { + level.textContent = getRequiredLicenseFromTrigger(element); + } + + // If one click upgrade, hide other content + addOneClick(element, 'modal', upgradeLabel); + var notInstalled = modal.querySelector('.frm_are_not_installed'); + notInstalled.style.display = element.dataset.image || element.dataset.oneclick ? 'none' : 'inline-block'; + notInstalled.textContent = notInstalled.dataset.default; + modal.querySelector('.frm-upgrade-modal-title-prefix').style.display = element.dataset.oneclick ? 'inline' : 'none'; + modal.querySelector('.frm_feature_label').textContent = upgradeLabel; + modal.querySelector('.frm-upgrade-modal-title-suffix').style.display = 'none'; + modal.querySelector('h2').style.display = 'block'; + $info.dialog('open'); + + // set the utm medium + var button = modal.querySelector('.button-primary:not(.frm-oneclick-button)'); + link = button.getAttribute('href').replace(/(medium=)[a-z_-]+/ig, "$1".concat(element.getAttribute('data-medium'))); + content = element.getAttribute('data-content'); + if (content === null) { + content = ''; + } + link = link.replace(/(content=)[a-z_-]+/ig, "$1".concat(content)); + button.setAttribute('href', link); + if (element.classList.contains('frm_show_update')) { + applyUpdateModalOverrides(modal); + } + } +} + +/** + * Override upgrade modal content for update prompts. + * + * @since 6.29 + * + * @param {Element} modal The upgrade modal element. + */ +function applyUpdateModalOverrides(modal) { + var titlePrefix = modal.querySelector('.frm-upgrade-modal-title-prefix'); + if (titlePrefix) { + titlePrefix.style.display = 'none'; + } + var notInstalled = modal.querySelector('.frm_are_not_installed'); + if (notInstalled) { + notInstalled.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('require an update', 'formidable'); + notInstalled.style.display = ''; // Clear inline style, span defaults to display:inline. + } + var oneclickMsg = modal.querySelector('.frm-oneclick'); + if (oneclickMsg) { + oneclickMsg.style.display = 'none'; + } + var button = modal.querySelector('.frm-oneclick-button'); + if (button) { + button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Update Now', 'formidable'); + } +} +function getRequiredLicenseFromTrigger(element) { + if (element.dataset.requires) { + return element.dataset.requires; + } + return 'Pro'; +} + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. +(() => { +/*!************************************!*\ + !*** ./js/src/frm_testing_mode.js ***! + \************************************/ +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +(function () { + var _require = __webpack_require__(/*! ./admin/addon-state */ "./js/src/admin/addon-state.js"), + toggleAddonState = _require.toggleAddonState; + function onReady() { + jQuery(document).on('click', '#frm_upgrade_modal .frm-install-addon', installAddon); + jQuery(document).on('click', '#frm_upgrade_modal .frm-activate-addon', activateAddon); + function activateAddon(e) { + e.preventDefault(); + toggleAddonState(this, 'frm_activate_addon'); + } + function installAddon(e) { + e.preventDefault(); + toggleAddonState(this, 'frm_install_addon'); + } + initUpgradeModal(); + setupBootstrapDropdowns(); + jQuery(document).on('mouseenter.frm', '.frm_help', function () { + jQuery(this).off('mouseenter.frm'); + jQuery(this).tooltip('show'); + }); + } + function initUpgradeModal() { + return _initUpgradeModal.apply(this, arguments); + } + function _initUpgradeModal() { + _initUpgradeModal = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { + var upgradePopup; + return _regenerator().w(function (_context) { + while (1) switch (_context.n) { + case 0: + _context.n = 1; + return Promise.resolve(/*! import() */).then(__webpack_require__.bind(__webpack_require__, /*! ./admin/upgrade-popup */ "./js/src/admin/upgrade-popup.js")); + case 1: + upgradePopup = _context.v; + upgradePopup.initUpgradeModal(); + case 2: + return _context.a(2); + } + }, _callee); + })); + return _initUpgradeModal.apply(this, arguments); + } + function setupBootstrapDropdowns() { + var _window = window, + frmDom = _window.frmDom; + frmDom.bootstrap.setupBootstrapDropdowns(function () { + var toggle = document.querySelector('#frm_testmode_enabled_form_actions .dropdown-toggle'); + if (toggle) { + toggle.classList.add('frm-dropdown-toggle'); + if (!toggle.hasAttribute('role')) { + toggle.setAttribute('role', 'button'); + } + if (!toggle.hasAttribute('tabindex')) { + toggle.setAttribute('tabindex', 0); + } + } + }); + var element = document.getElementById('frm_testmode_enabled_form_actions'); + if (element) { + element.style.display = 'none'; + frmDom.bootstrap.multiselect.init.bind(element)(); + if (element.disabled) { + element.parentElement.querySelector('.dropdown-toggle').classList.add('frm_noallow'); + } + } + } + if (document.readyState === 'complete') { + onReady(); + } else { + document.addEventListener('DOMContentLoaded', onReady); + } + document.addEventListener('frm_after_start_over', function () { + setupBootstrapDropdowns(); + }); + jQuery(document).on('frmPageChanged frmFormComplete', function () { + setupBootstrapDropdowns(); + }); +})(); +})(); + +/******/ })() +; +//# sourceMappingURL=frm_testing_mode.js.map \ No newline at end of file diff --git a/js/onboarding-wizard.js b/js/onboarding-wizard.js index d114a1e6d6..dff5ef18bc 100644 --- a/js/onboarding-wizard.js +++ b/js/onboarding-wizard.js @@ -1,2 +1,1899 @@ -/*! For license information please see onboarding-wizard.js.LICENSE.txt */ -(()=>{"use strict";function t(e){return t="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},t(e)}function e(t,e){for(var r=0;r1&&void 0!==arguments[1]?arguments[1]:"default";!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.elements=e,this.type=n,this.prepareElements()},n=[{key:"fadeIn",value:function(){var t=this;this.applyStyleToElements(function(e){e.classList.add("frm-fadein-up"),e.addEventListener("animationend",function(){t.resetOpacity(),e.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){t.applyStyleToElements(function(t,n){t.classList.remove("frm-animate"),t.style.transitionDelay="".concat((n+1)*e,"s")})},200)}},{key:"prepareElements",value:function(){var t=this;this.applyStyleToElements(function(e){"default"===t.type&&(e.style.opacity="0.0"),"cascade"===t.type&&e.classList.add("frm-init-cascade-animation"),"cascade-3d"===t.type&&e.classList.add("frm-init-fadein-3d"),e.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(t){return t.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(t){this.elements instanceof Element?t(this.elements,0):00&&void 0!==arguments[0]?arguments[0]:{};if("object"!==_(t)||null===t)throw new Error("createPageState: initialState must be a non-null object");var e=t;return{getState:function(){return e},getSingleState:function(t){var n=Reflect.get(e,t);return void 0===n?null:n},setState:function(t){if("object"!==_(t)||null===t)throw new Error("setState: newState must be a non-null object");e=T(T({},e),t)},setSingleState:function(t,n){Reflect.has(e,t)&&Reflect.set(e,t,n)}}}({processedSteps:[],installedAddons:[]}),I=A.getState,D=(A.getSingleState,A.setState,A.setSingleState),C=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==j(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var e=t;return{getElements:function(){return e},addElements:function(t){if("object"!==j(t)||null===t)throw new Error("addElements: newElements must be a non-null object");e=g(g({},e),t)}}}({onboardingWizardPage:document.getElementById("".concat(E,"-wizard-page")),container:document.getElementById("".concat(E,"-container")),rootline:document.getElementById("".concat(E,"-rootline")),steps:document.querySelectorAll(".".concat(E,"-step")),skipStepButtons:document.querySelectorAll(".".concat(E,"-skip-step")),backButtons:document.querySelectorAll(".".concat(E,"-back-button")),consentTrackingButton:document.getElementById("".concat(E,"-consent-tracking")),installAddonsButton:document.getElementById("".concat(E,"-install-addons-button")),hiddenLicenseKeyInput:document.getElementById("frm-license-key")}),N=C.getElements;C.addElements;var U=function(t){var e,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"pushState",o=document.querySelector(".".concat(E,'-step[data-step-name="').concat(t,'"]'));if(o){var i=document.querySelector(".".concat(E,"-step.").concat(S));i&&(i.classList.remove(S),null==(e=i)||e.classList.add(b)),o.classList.add(S),function(t){null==t||t.classList.remove(b)}(o),new r(o).fadeIn(),N().onboardingWizardPage.setAttribute("data-current-step",t),function(t,e){var n,r,o,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"pushState";if(p.set(t,e),f.search=p.toString(),["pushState","replaceState"].includes(i)){var a=(n={},o=e,(r=function(t){var e=function(t){if("object"!=s(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=s(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==s(e)?e:e+""}(r=t))in n?Object.defineProperty(n,r,{value:o,enumerable:!0,configurable:!0,writable:!0}):n[r]=o,n);window.history[i](a,"",f)}f.toString()}("step",t,n),function(t){t===P.UNSUCCESSFUL&&(t=P.SUCCESS);var e=N().rootline,n=e.querySelector('.frm-rootline-item[data-step="'.concat(t,'"]'));e.querySelectorAll(".frm-rootline-item").forEach(function(t){t.classList.remove(B),t.classList.remove(S)});var r=n.previousElementSibling;if(r)for(;r;)r.classList.add(B),r=r.previousElementSibling;t===P.SUCCESS?n.classList.add(B):n.classList.add(S)}(t)}},x=function(){var t=document.querySelector(".".concat(E,"-step.").concat(S)),e=null==t?void 0:t.nextElementSibling;if(e){var n=t.dataset.stepName,r=e.dataset.stepName,o=I().processedSteps;o.includes(n)||(o.push(n),D("processedSteps",o)),function(t,e){var n=function(t,e){var n;if(P.SUCCESS===e||P.UNSUCCESSFUL===e){var r=I().processedSteps;r.length>1&&(r.includes(e)||r.push(e),(n=new FormData).append("processed_steps",r.join(",")),n.append("completed_steps",!0))}if(P.INSTALL_ADDONS===t){var o=I().installedAddons;o.length>0&&(n=null!=n?n:new FormData).append("installed_addons",o.join(","))}return n}(t,e);n&&(0,frmDom.ajax.doJsonPost)("onboarding_setup_usage_data",n)}(n,r),U(r)}};var B="frm-completed-step",F=".frm-option-box";function G(t){"input"===t.target.tagName.toLowerCase()&&t.currentTarget.closest(F).classList.toggle("frm-checked")}var q=function(){x()};var z=function(){var t,e;(e=null==(t=document.querySelector(".".concat(E,"-step.").concat(S)))?void 0:t.previousElementSibling)&&U(e.dataset.stepName)};function R(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function i(n,r,o,i){var u=r&&r.prototype instanceof c?r:c,l=Object.create(u.prototype);return J(l,"_invoke",function(n,r,o){var i,c,u,l=0,s=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,n){return i=e,c=0,u=t,p.n=n,a}};function d(n,r){for(c=n,u=r,e=0;!f&&l&&!o&&e3?(o=y===r)&&(u=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=n<2&&dr||r>y)&&(i[4]=n,i[5]=r,p.n=y,c=0))}if(o||n>1)return a;throw f=!0,r}return function(o,s,y){if(l>1)throw TypeError("Generator is already running");for(f&&1===s&&d(s,y),c=s,u=y;(e=c<2?t:u)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,u)):p.n=u:p.v=u);try{if(l=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,u)))throw TypeError("iterator result is not an object");if(!e.done)return e;u=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(u=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?u:n.call(r,p))!==a)break}catch(e){i=t,c=1,u=e}finally{l=1}}return{value:e,done:f}}}(n,o,i),!0),l}var a={};function c(){}function u(){}function l(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(J(e={},r,function(){return this}),e),f=l.prototype=c.prototype=Object.create(s);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,l):(t.__proto__=l,J(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return u.prototype=l,J(f,"constructor",l),J(l,"constructor",u),u.displayName="GeneratorFunction",J(l,o,"GeneratorFunction"),J(f),J(f,o,"Generator"),J(f,r,function(){return this}),J(f,"toString",function(){return"[object Generator]"}),(R=function(){return{w:i,m:p}})()}function J(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}J=function(t,e,n,r){function i(e,n){J(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(i("next",0),i("throw",1),i("return",2))},J(t,e,n,r)}function M(t,e,n,r,o,i,a){try{var c=t[i](a),u=c.value}catch(t){return void n(t)}c.done?e(u):Promise.resolve(u).then(r,o)}var W=function(){var t,e=(t=R().m(function t(){return R().w(function(t){for(;;)switch(t.n){case 0:(0,frmDom.ajax.doJsonPost)("onboarding_consent_tracking",new FormData).then(x);case 1:return t.a(2)}},t)}),function(){var e=this,n=arguments;return new Promise(function(r,o){var i=t.apply(e,n);function a(t){M(i,r,o,a,c,"next",t)}function c(t){M(i,r,o,a,c,"throw",t)}a(void 0)})});return function(){return e.apply(this,arguments)}}();function K(t){return K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},K(t)}function V(t){if(null!=t){var e=t["function"==typeof Symbol&&Symbol.iterator||"@@iterator"],n=0;if(e)return e.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length))return{next:function(){return t&&n>=t.length&&(t=void 0),{value:t&&t[n++],done:!t}}}}throw new TypeError(K(t)+" is not iterable")}function $(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function i(n,r,o,i){var u=r&&r.prototype instanceof c?r:c,l=Object.create(u.prototype);return H(l,"_invoke",function(n,r,o){var i,c,u,l=0,s=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,n){return i=e,c=0,u=t,p.n=n,a}};function d(n,r){for(c=n,u=r,e=0;!f&&l&&!o&&e3?(o=y===r)&&(u=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=n<2&&dr||r>y)&&(i[4]=n,i[5]=r,p.n=y,c=0))}if(o||n>1)return a;throw f=!0,r}return function(o,s,y){if(l>1)throw TypeError("Generator is already running");for(f&&1===s&&d(s,y),c=s,u=y;(e=c<2?t:u)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,u)):p.n=u:p.v=u);try{if(l=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,u)))throw TypeError("iterator result is not an object");if(!e.done)return e;u=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(u=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?u:n.call(r,p))!==a)break}catch(e){i=t,c=1,u=e}finally{l=1}}return{value:e,done:f}}}(n,o,i),!0),l}var a={};function c(){}function u(){}function l(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(H(e={},r,function(){return this}),e),f=l.prototype=c.prototype=Object.create(s);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,l):(t.__proto__=l,H(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return u.prototype=l,H(f,"constructor",l),H(l,"constructor",u),u.displayName="GeneratorFunction",H(l,o,"GeneratorFunction"),H(f),H(f,o,"Generator"),H(f,r,function(){return this}),H(f,"toString",function(){return"[object Generator]"}),($=function(){return{w:i,m:p}})()}function H(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}H=function(t,e,n,r){function i(e,n){H(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(i("next",0),i("throw",1),i("return",2))},H(t,e,n,r)}function Q(t,e){var n="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!n){if(Array.isArray(t)||(n=function(t,e){if(t){if("string"==typeof t)return X(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?X(t,e):void 0}}(t))||e&&t&&"number"==typeof t.length){n&&(t=n);var r=0,o=function(){};return{s:o,n:function(){return r>=t.length?{done:!0}:{done:!1,value:t[r++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,c=!1;return{s:function(){n=n.call(t)},n:function(){var t=n.next();return a=t.done,t},e:function(t){c=!0,i=t},f:function(){try{a||null==n.return||n.return()}finally{if(c)throw i}}}}function X(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n { // webpackBootstrap +/******/ "use strict"; +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": +/*!*****************************************************************!*\ + !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ domReady) +/* harmony export */ }); +/** + * @typedef {() => void} Callback + * + * TODO: Remove this typedef and inline `() => void` type. + * + * This typedef is used so that a descriptive type is provided in our + * automatically generated documentation. + * + * An in-line type `() => void` would be preferable, but the generated + * documentation is `null` in that case. + * + * @see https://github.com/WordPress/gutenberg/issues/18045 + */ + +/** + * Specify a function to execute when the DOM is fully loaded. + * + * @param {Callback} callback A function to execute after the DOM is ready. + * + * @example + * ```js + * import domReady from '@wordpress/dom-ready'; + * + * domReady( function() { + * //do something after DOM loads. + * } ); + * ``` + * + * @return {void} + */ +function domReady(callback) { + if (typeof document === 'undefined') { + return; + } + + if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. + document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. + ) { + return void callback(); + } // DOMContentLoaded has not fired yet, delay callback until then. + + + document.addEventListener('DOMContentLoaded', callback); +} +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/events/index.js": +/*!*************************************!*\ + !*** ./js/src/core/events/index.js ***! + \*************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addOptionBoxEvents: () => (/* reexport safe */ _optionBoxListener__WEBPACK_IMPORTED_MODULE_0__.addOptionBoxEvents) +/* harmony export */ }); +/* harmony import */ var _optionBoxListener__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./optionBoxListener */ "./js/src/core/events/optionBoxListener.js"); + + +/***/ }), + +/***/ "./js/src/core/events/optionBoxListener.js": +/*!*************************************************!*\ + !*** ./js/src/core/events/optionBoxListener.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addOptionBoxEvents: () => (/* binding */ addOptionBoxEvents) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + +var OPTION_BOX_CLASS = '.frm-option-box'; + +/** + * Manages event handling for an option-box. + * + * @return {void} + */ +function addOptionBoxEvents() { + var optionBoxes = document.querySelectorAll(OPTION_BOX_CLASS); + optionBoxes.forEach(function (optionBox) { + optionBox.addEventListener('click', onOptionBoxClick); + }); +} + +/** + * Handles the click event on a option box item. + * + * @private + * @param {Event} event The click event object. + */ +function onOptionBoxClick(event) { + if (event.target.tagName.toLowerCase() !== 'input') { + return; + } + var optionBox = event.currentTarget.closest(OPTION_BOX_CLASS); + optionBox.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_0__.CHECKED_CLASS); +} + +/***/ }), + +/***/ "./js/src/core/factory/createPageElements.js": +/*!***************************************************!*\ + !*** ./js/src/core/factory/createPageElements.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* binding */ createPageElements) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page elements manager. + * + * @param {Object} [initialElements={}] An object containing initial DOM elements. + * @throws {Error} Throws an error if the `initialElements` is not an object. + * @return {Object} An object with methods to get and add elements. + */ +function createPageElements() { + var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialElements) !== 'object' || initialElements === null) { + throw new Error('createPageElements: initialElements must be a non-null object'); + } + var elements = initialElements; + + /** + * Retrieve the initialized essential DOM elements. + * + * @return {Object} The initialized elements object. + */ + function getElements() { + return elements; + } + + /** + * Add new elements to the elements object. + * + * @param {Object} newElements An object containing new elements to be added. + * @throws {Error} Throws an error if the `newElements` is not a non-null object. + * @return {void} Updates the elements object by merging the new elements into it. + */ + function addElements(newElements) { + if (_typeof(newElements) !== 'object' || newElements === null) { + throw new Error('addElements: newElements must be a non-null object'); + } + elements = _objectSpread(_objectSpread({}, elements), newElements); + } + return { + getElements: getElements, + addElements: addElements + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/createPageState.js": +/*!************************************************!*\ + !*** ./js/src/core/factory/createPageState.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageState: () => (/* binding */ createPageState) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page state manager. + * + * @param {Object} [initialState={}] An object containing the initial state. + * @throws {Error} Throws an error if the `initialState` is not a plain object. + * @return {Object} An object with methods to initialize, get, and set the page state. + */ +function createPageState() { + var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialState) !== 'object' || initialState === null) { + throw new Error('createPageState: initialState must be a non-null object'); + } + var state = initialState; + + /** + * Returns the current page state. + * + * @return {Object|null} The current state of the page or null if not initialized. + */ + var getState = function getState() { + return state; + }; + + /** + * Returns a specific property from the current page state. + * + * @param {string} propertyName The name of the property to retrieve. + * @return {*} The value of the specified property, or null if it doesn't exist. + */ + var getSingleState = function getSingleState(propertyName) { + var value = Reflect.get(state, propertyName); + + // We convert `undefined` to `null` for a consistent API. + // This makes it easier for users to handle the results since all missing properties return `null`. + return value === undefined ? null : value; + }; + + /** + * Updates the page state with new values. + * + * @param {Object} newState The new values to update the state with. + * @throws {Error} Throws an error if `newState` is not a plain object. + * @return {void} + */ + var setState = function setState(newState) { + if (_typeof(newState) !== 'object' || newState === null) { + throw new Error('setState: newState must be a non-null object'); + } + state = _objectSpread(_objectSpread({}, state), newState); + }; + + /** + * Updates a specific property in the page state with a new value. + * + * @param {string} propertyName The name of the property to update. + * @param {*} value The new value to set for the property. + * @return {void} + */ + var setSingleState = function setSingleState(propertyName, value) { + if (Reflect.has(state, propertyName)) { + Reflect.set(state, propertyName, value); + } + }; + return { + getState: getState, + getSingleState: getSingleState, + setState: setState, + setSingleState: setSingleState + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/index.js": +/*!**************************************!*\ + !*** ./js/src/core/factory/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), +/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) +/* harmony export */ }); +/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); +/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); + + + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }), + +/***/ "./js/src/onboarding-wizard/dataUtils/index.js": +/*!*****************************************************!*\ + !*** ./js/src/onboarding-wizard/dataUtils/index.js ***! + \*****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ setupUsageData: () => (/* reexport safe */ _setupUsageData__WEBPACK_IMPORTED_MODULE_0__["default"]) +/* harmony export */ }); +/* harmony import */ var _setupUsageData__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupUsageData */ "./js/src/onboarding-wizard/dataUtils/setupUsageData.js"); + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/dataUtils/setupUsageData.js": +/*!**************************************************************!*\ + !*** ./js/src/onboarding-wizard/dataUtils/setupUsageData.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); +/** + * Internal Dependencies + */ + + +/** + * Processes and submits usage data for the specified onboarding step. + * + * @param {string} processedStep The name of the step that has just been processed. + * @param {string} nextStepName The name of the next step in the onboarding process. + * @return {void} + */ +function setupUsageData(processedStep, nextStepName) { + var formData = processDataForStep(processedStep, nextStepName); + if (!formData) { + return; + } + + // Send the POST request + var doJsonPost = frmDom.ajax.doJsonPost; + doJsonPost('onboarding_setup_usage_data', formData); +} + +/** + * Processes onboarding step data and returns the corresponding FormData. + * + * @private + * @param {string} processedStep The name of the step that has just been processed. + * @param {string} nextStepName The name of the next step in the onboarding process. + * @return {FormData|null} The FormData to be submitted for the step, or null if there's no data. + */ +function processDataForStep(processedStep, nextStepName) { + var formData; + + // Append completed steps if moving to the success step + if (_shared__WEBPACK_IMPORTED_MODULE_0__.STEPS.SUCCESS === nextStepName || _shared__WEBPACK_IMPORTED_MODULE_0__.STEPS.UNSUCCESSFUL === nextStepName) { + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_0__.getState)(), + processedSteps = _getState.processedSteps; + if (processedSteps.length > 1) { + if (!processedSteps.includes(nextStepName)) { + processedSteps.push(nextStepName); + } + formData = new FormData(); + formData.append('processed_steps', processedSteps.join(',')); + formData.append('completed_steps', true); + } + } + + // Append installed addons for the addon installation step + if (_shared__WEBPACK_IMPORTED_MODULE_0__.STEPS.INSTALL_ADDONS === processedStep) { + var _getState2 = (0,_shared__WEBPACK_IMPORTED_MODULE_0__.getState)(), + installedAddons = _getState2.installedAddons; + if (installedAddons.length > 0) { + formData = formData !== null && formData !== void 0 ? formData : new FormData(); + formData.append('installed_addons', installedAddons.join(',')); + } + } + return formData; +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (setupUsageData); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/elements/elements.js": +/*!*******************************************************!*\ + !*** ./js/src/onboarding-wizard/elements/elements.js ***! + \*******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* binding */ addElements), +/* harmony export */ getElements: () => (/* binding */ getElements) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + +var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)({ + onboardingWizardPage: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-wizard-page")), + container: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-container")), + rootline: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-rootline")), + steps: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-step")), + skipStepButtons: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-skip-step")), + backButtons: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-back-button")), + consentTrackingButton: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-consent-tracking")), + installAddonsButton: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-install-addons-button")), + hiddenLicenseKeyInput: document.getElementById('frm-license-key') + }), + getElements = _createPageElements.getElements, + addElements = _createPageElements.addElements; + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/elements/index.js": +/*!****************************************************!*\ + !*** ./js/src/onboarding-wizard/elements/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/onboarding-wizard/elements/elements.js"); + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/events/backButtonListener.js": +/*!***************************************************************!*\ + !*** ./js/src/onboarding-wizard/events/backButtonListener.js ***! + \***************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + +/** + * Manages event handling for the "Back" button. + * + * @return {void} + */ +function addBackButtonEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + backButtons = _getElements.backButtons; + + // Attach click event listeners to each back buttons + backButtons.forEach(function (backButton) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(backButton, onBackButtonClick); + }); +} + +/** + * Handles the click event on a "Back" button. + * + * @private + * @return {void} + */ +var onBackButtonClick = function onBackButtonClick() { + (0,_utils__WEBPACK_IMPORTED_MODULE_2__.navigateToPrevStep)(); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addBackButtonEvents); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/events/consentTrackingButtonListener.js": +/*!**************************************************************************!*\ + !*** ./js/src/onboarding-wizard/events/consentTrackingButtonListener.js ***! + \**************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + +/** + * Manages event handling for the "Allow & Continue" button in the "Never miss an important update" step. + * + * @return {void} + */ +function addConsentTrackingButtonEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + consentTrackingButton = _getElements.consentTrackingButton; + + // Attach click event listener + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(consentTrackingButton, onConsentTrackingButtonClick); +} + +/** + * Handles the click event on the "Allow & Continue" button in the "Never miss an important update" step. + * + * @private + * @return {void} + */ +var onConsentTrackingButtonClick = /*#__PURE__*/function () { + var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { + var doJsonPost; + return _regenerator().w(function (_context) { + while (1) switch (_context.n) { + case 0: + doJsonPost = frmDom.ajax.doJsonPost; + doJsonPost('onboarding_consent_tracking', new FormData()).then(_utils__WEBPACK_IMPORTED_MODULE_2__.navigateToNextStep); + case 1: + return _context.a(2); + } + }, _callee); + })); + return function onConsentTrackingButtonClick() { + return _ref.apply(this, arguments); + }; +}(); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addConsentTrackingButtonEvents); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/events/index.js": +/*!**************************************************!*\ + !*** ./js/src/onboarding-wizard/events/index.js ***! + \**************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) +/* harmony export */ }); +/* harmony import */ var core_events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/events */ "./js/src/core/events/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _skipStepButtonListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./skipStepButtonListener */ "./js/src/onboarding-wizard/events/skipStepButtonListener.js"); +/* harmony import */ var _backButtonListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./backButtonListener */ "./js/src/onboarding-wizard/events/backButtonListener.js"); +/* harmony import */ var _consentTrackingButtonListener__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./consentTrackingButtonListener */ "./js/src/onboarding-wizard/events/consentTrackingButtonListener.js"); +/* harmony import */ var _installAddonsButtonListener__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./installAddonsButtonListener */ "./js/src/onboarding-wizard/events/installAddonsButtonListener.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + + + +/** + * Attaches event listeners for handling user interactions. + * + * @return {void} + */ +function addEventListeners() { + // Add event handling for the "Skip" and "Back" buttons + (0,_skipStepButtonListener__WEBPACK_IMPORTED_MODULE_2__["default"])(); + (0,_backButtonListener__WEBPACK_IMPORTED_MODULE_3__["default"])(); + (0,_consentTrackingButtonListener__WEBPACK_IMPORTED_MODULE_4__["default"])(); + + // Add event handling for the "Install & Finish Setup" button in the "Install Formidable Add-ons" step + (0,_installAddonsButtonListener__WEBPACK_IMPORTED_MODULE_5__["default"])(); + // Add event handling for an option-box + (0,core_events__WEBPACK_IMPORTED_MODULE_0__.addOptionBoxEvents)(); +} + +/** + * Responds to browser navigation events (back/forward) by updating the UI to match the step indicated in the URL or history state. + * + * @param {PopStateEvent} event The event object associated with the navigation action. + * @return {void} + */ +window.addEventListener('popstate', function (event) { + var _event$state; + var stepName = ((_event$state = event.state) === null || _event$state === void 0 ? void 0 : _event$state.step) || (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.getQueryParam)('step'); + // Navigate to the specified step without adding to browser history + (0,_utils__WEBPACK_IMPORTED_MODULE_6__.navigateToStep)(stepName, 'replaceState'); +}); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/events/installAddonsButtonListener.js": +/*!************************************************************************!*\ + !*** ./js/src/onboarding-wizard/events/installAddonsButtonListener.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _regeneratorValues(e) { if (null != e) { var t = e["function" == typeof Symbol && Symbol.iterator || "@@iterator"], r = 0; if (t) return t.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) return { next: function next() { return e && r >= e.length && (e = void 0), { value: e && e[r++], done: !e }; } }; } throw new TypeError(_typeof(e) + " is not iterable"); } +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } +function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } +function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + +/** + * Manages event handling for the "Install & Finish Setup" button in the "Install Formidable Add-ons" step. + * + * @return {void} + */ +function addInstallAddonsButtonEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), + installAddonsButton = _getElements.installAddonsButton; + + // Attach click event listener + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(installAddonsButton, onInstallAddonsButtonClick); +} + +/** + * Handles the click event on the "Install & Finish Setup" button in the "Install Formidable Add-ons" step. + * + * @private + * @param {Event} event The click event object. + * @return {void} + */ +var onInstallAddonsButtonClick = /*#__PURE__*/function () { + var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(event) { + var addons, _getState, installedAddons, installAddonsButton, _iterator, _step, _loop, _t2; + return _regenerator().w(function (_context2) { + while (1) switch (_context2.p = _context2.n) { + case 0: + addons = document.querySelectorAll('.frm-option-box.frm-checked:not(.frm-disabled)'); + _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), installedAddons = _getState.installedAddons; + installAddonsButton = event.currentTarget; + installAddonsButton.classList.add('frm_loading_button'); + _iterator = _createForOfIteratorHelper(addons); + _context2.p = 1; + _loop = /*#__PURE__*/_regenerator().m(function _loop() { + var addon, addonTitle, _t; + return _regenerator().w(function (_context) { + while (1) switch (_context.p = _context.n) { + case 0: + addon = _step.value; + _context.p = 1; + _context.n = 2; + return (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue)(function () { + return installAddon(addon.getAttribute('rel'), addon.dataset); + }); + case 2: + // Capture addon title + addonTitle = addon.dataset.title; + if (!installedAddons.includes(addonTitle)) { + installedAddons.push(addonTitle); + } + _context.n = 4; + break; + case 3: + _context.p = 3; + _t = _context.v; + console.error('An error occurred:', _t); + case 4: + return _context.a(2); + } + }, _loop, null, [[1, 3]]); + }); + _iterator.s(); + case 2: + if ((_step = _iterator.n()).done) { + _context2.n = 4; + break; + } + return _context2.d(_regeneratorValues(_loop()), 3); + case 3: + _context2.n = 2; + break; + case 4: + _context2.n = 6; + break; + case 5: + _context2.p = 5; + _t2 = _context2.v; + _iterator.e(_t2); + case 6: + _context2.p = 6; + _iterator.f(); + return _context2.f(6); + case 7: + installAddonsButton.classList.remove('frm_loading_button'); + (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('installedAddons', installedAddons); + (0,_utils__WEBPACK_IMPORTED_MODULE_4__.navigateToNextStep)(); + case 8: + return _context2.a(2); + } + }, _callee, null, [[1, 5, 6, 7]]); + })); + return function onInstallAddonsButtonClick(_x) { + return _ref.apply(this, arguments); + }; +}(); + +/** + * Installs an add-on or plugin based on the provided plugin name and vendor status. + * + * @private + * @param {string} plugin The unique identifier or name of the plugin or add-on to be installed. + * @param {Object} options An object containing additional options for the installation. + * @param {boolean} options.isInstalled Indicates whether the plugin is already installed. + * @param {boolean} options.isVendor Indicates whether the plugin is a vendor plugin (true) or a regular add-on (false). + * @return {Promise} A promise that resolves with the JSON response from the server after the installation request is completed. + */ +function installAddon(_x2, _x3) { + return _installAddon.apply(this, arguments); +} +function _installAddon() { + _installAddon = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2(plugin, _ref2) { + var isVendor, isInstalled, formData, addonAction, response, _t3; + return _regenerator().w(function (_context3) { + while (1) switch (_context3.p = _context3.n) { + case 0: + isVendor = _ref2.isVendor, isInstalled = _ref2.isInstalled; + // Prepare FormData for the POST request + formData = new FormData(); + formData.append('nonce', core_constants__WEBPACK_IMPORTED_MODULE_0__.nonce); + formData.append('plugin', plugin); + addonAction = isInstalled ? 'frm_activate_addon' : 'frm_install_addon'; + formData.append('action', isVendor ? 'frm_install_plugin' : addonAction); + _context3.p = 1; + _context3.n = 2; + return fetch(ajaxurl, { + method: 'POST', + body: formData + }); + case 2: + response = _context3.v; + if (response.ok) { + _context3.n = 3; + break; + } + throw new Error("Server responded with status ".concat(response.status)); + case 3: + _context3.n = 4; + return response.json(); + case 4: + return _context3.a(2, _context3.v); + case 5: + _context3.p = 5; + _t3 = _context3.v; + console.error('An error occurred:', _t3); + case 6: + return _context3.a(2); + } + }, _callee2, null, [[1, 5]]); + })); + return _installAddon.apply(this, arguments); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addInstallAddonsButtonEvents); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/events/skipStepButtonListener.js": +/*!*******************************************************************!*\ + !*** ./js/src/onboarding-wizard/events/skipStepButtonListener.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + +/** + * Manages event handling for the "Skip" step button. + * + * @return {void} + */ +function addSkipStepButtonEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + skipStepButtons = _getElements.skipStepButtons; + + // Attach click event listeners to each skip buttons + skipStepButtons.forEach(function (skipButton) { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(skipButton, onSkipStepButtonClick); + }); +} + +/** + * Handles the click event on a "Skip" step button. + * + * @private + * @return {void} + */ +var onSkipStepButtonClick = function onSkipStepButtonClick() { + (0,_utils__WEBPACK_IMPORTED_MODULE_2__.navigateToNextStep)(); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addSkipStepButtonEvents); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/initializeOnboardingWizard.js": +/*!****************************************************************!*\ + !*** ./js/src/onboarding-wizard/initializeOnboardingWizard.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/onboarding-wizard/ui/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./js/src/onboarding-wizard/events/index.js"); +/** + * Internal dependencies + */ + + + +/** + * Initializes Onboarding Wizard. + * + * @return {void} + */ +function initializeOnboardingWizard() { + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.setupInitialView)(); + (0,_events__WEBPACK_IMPORTED_MODULE_1__.addEventListeners)(); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeOnboardingWizard); + +/***/ }), + +/***/ "./js/src/onboarding-wizard/shared/constants.js": +/*!******************************************************!*\ + !*** ./js/src/onboarding-wizard/shared/constants.js ***! + \******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ INITIAL_STEP: () => (/* binding */ INITIAL_STEP), +/* harmony export */ PREFIX: () => (/* binding */ PREFIX), +/* harmony export */ STEPS: () => (/* binding */ STEPS) +/* harmony export */ }); +var INITIAL_STEP = window.frmOnboardingWizardVars.INITIAL_STEP; + +var PREFIX = 'frm-onboarding'; +var STEPS = { + INITIAL: INITIAL_STEP, + INSTALL_ADDONS: 'install-addons', + SUCCESS: 'success', + UNSUCCESSFUL: 'unsuccessful' +}; + +/***/ }), + +/***/ "./js/src/onboarding-wizard/shared/index.js": +/*!**************************************************!*\ + !*** ./js/src/onboarding-wizard/shared/index.js ***! + \**************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ INITIAL_STEP: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.INITIAL_STEP), +/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), +/* harmony export */ STEPS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.STEPS), +/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getSingleState), +/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getState), +/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setSingleState), +/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setState) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/onboarding-wizard/shared/constants.js"); +/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageState */ "./js/src/onboarding-wizard/shared/pageState.js"); + + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/shared/pageState.js": +/*!******************************************************!*\ + !*** ./js/src/onboarding-wizard/shared/pageState.js ***! + \******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getSingleState: () => (/* binding */ getSingleState), +/* harmony export */ getState: () => (/* binding */ getState), +/* harmony export */ setSingleState: () => (/* binding */ setSingleState), +/* harmony export */ setState: () => (/* binding */ setState) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/** + * External dependencies + */ + +var _createPageState = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageState)({ + processedSteps: [], + installedAddons: [] + }), + getState = _createPageState.getState, + getSingleState = _createPageState.getSingleState, + setState = _createPageState.setState, + setSingleState = _createPageState.setSingleState; + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/ui/index.js": +/*!**********************************************!*\ + !*** ./js/src/onboarding-wizard/ui/index.js ***! + \**********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ setupInitialView: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ updateRootline: () => (/* reexport safe */ _rootline__WEBPACK_IMPORTED_MODULE_1__.updateRootline) +/* harmony export */ }); +/* harmony import */ var _setupInitialView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupInitialView */ "./js/src/onboarding-wizard/ui/setupInitialView.js"); +/* harmony import */ var _rootline__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./rootline */ "./js/src/onboarding-wizard/ui/rootline.js"); + + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/ui/rootline.js": +/*!*************************************************!*\ + !*** ./js/src/onboarding-wizard/ui/rootline.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ updateRootline: () => (/* binding */ updateRootline) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + +var COMPLETED_STEP_CLASS = 'frm-completed-step'; + +/** + * Updates the rootline to reflect the current and completed steps. + * + * - Applies COMPLETED_STEP_CLASS to steps before the current one. + * - Applies CURRENT_CLASS to the current step, unless it is the success step. + * + * @param {string} currentStep The current step in the process. + * @return {void} + */ +function updateRootline(currentStep) { + if (currentStep === _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.UNSUCCESSFUL) { + currentStep = _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.SUCCESS; + } + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + rootline = _getElements.rootline; + var currentItem = rootline.querySelector(".frm-rootline-item[data-step=\"".concat(currentStep, "\"]")); + rootline.querySelectorAll('.frm-rootline-item').forEach(function (item) { + item.classList.remove(COMPLETED_STEP_CLASS); + item.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + }); + var prevItem = currentItem.previousElementSibling; + if (prevItem) { + while (prevItem) { + prevItem.classList.add(COMPLETED_STEP_CLASS); + prevItem = prevItem.previousElementSibling; // move to the previous sibling + } + } + if (currentStep === _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.SUCCESS) { + currentItem.classList.add(COMPLETED_STEP_CLASS); + } else { + currentItem.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + } +} + +/***/ }), + +/***/ "./js/src/onboarding-wizard/ui/setupInitialView.js": +/*!*********************************************************!*\ + !*** ./js/src/onboarding-wizard/ui/setupInitialView.js ***! + \*********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ setupInitialView) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); +/** + * External dependencies + */ + + +/** + * Internal dependencies + */ + + + + +/** + * Initializes the onboarding wizard's UI, sets up the initial step based on certain conditions, + * and applies necessary UI enhancements for a smoother user experience. + * + * @return {void} + */ +function setupInitialView() { + navigateToInitialStep(); + fadeInPageElements(); +} + +/** + * Determines the initial step in the onboarding process and navigates to it, considering the installation + * status of Formidable Pro and specific query parameters. + * + * @private + * @return {void} + */ +function navigateToInitialStep() { + var initialStepName = determineInitialStep(); + clearOnboardingQueryParams(); + (0,_utils__WEBPACK_IMPORTED_MODULE_3__.navigateToStep)(initialStepName, 'replaceState'); +} + +/** + * Determines the initial step based on the current state, such as whether Formidable Pro is installed + * and the presence of specific query parameters. Also handles the removal of unnecessary steps. + * + * @private + * @return {string} The name of the initial step to navigate to. + */ +function determineInitialStep() { + var isConnectedAccount = (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('success'); + if (isConnectedAccount === '0') { + return _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.UNSUCCESSFUL; + } + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + hiddenLicenseKeyInput = _getElements.hiddenLicenseKeyInput; + if (hiddenLicenseKeyInput || isConnectedAccount) { + return _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.INSTALL_ADDONS; + } + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('step') || _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.INITIAL; +} + +/** + * Clears specific query parameters related to the onboarding process. + * + * @private + * @return {void} + */ +function clearOnboardingQueryParams() { + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.removeQueryParam)('key'); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.removeQueryParam)('success'); +} + +/** + * Smoothly fades in the background and container elements of the page for a more pleasant user experience. + * + * @private + * @return {void} + */ +function fadeInPageElements() { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + container = _getElements2.container; + new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(container).fadeIn(); +} + +/***/ }), + +/***/ "./js/src/onboarding-wizard/utils/index.js": +/*!*************************************************!*\ + !*** ./js/src/onboarding-wizard/utils/index.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ navigateToNextStep: () => (/* reexport safe */ _navigateToStep__WEBPACK_IMPORTED_MODULE_0__.navigateToNextStep), +/* harmony export */ navigateToPrevStep: () => (/* reexport safe */ _navigateToStep__WEBPACK_IMPORTED_MODULE_0__.navigateToPrevStep), +/* harmony export */ navigateToStep: () => (/* reexport safe */ _navigateToStep__WEBPACK_IMPORTED_MODULE_0__.navigateToStep) +/* harmony export */ }); +/* harmony import */ var _navigateToStep__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./navigateToStep */ "./js/src/onboarding-wizard/utils/navigateToStep.js"); + + +/***/ }), + +/***/ "./js/src/onboarding-wizard/utils/navigateToStep.js": +/*!**********************************************************!*\ + !*** ./js/src/onboarding-wizard/utils/navigateToStep.js ***! + \**********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ navigateToNextStep: () => (/* binding */ navigateToNextStep), +/* harmony export */ navigateToPrevStep: () => (/* binding */ navigateToPrevStep), +/* harmony export */ navigateToStep: () => (/* binding */ navigateToStep) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _dataUtils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../dataUtils */ "./js/src/onboarding-wizard/dataUtils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../ui */ "./js/src/onboarding-wizard/ui/index.js"); +/** + * External dependencies + */ + + + +/** + * Internal dependencies + */ + + + + + +/** + * Navigates to the given step in the onboarding sequence. + * Optionally updates the browser's history state to include the current step. + * + * @param {string} stepName The name of the step to navigate to. + * @param {string} [updateMethod='pushState'] Specifies the method to update the browser's history and URL. Accepts 'pushState' or 'replaceState'. If omitted, defaults to 'pushState'. + * @return {void} + */ +var navigateToStep = function navigateToStep(stepName) { + var updateMethod = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'pushState'; + // Find the target step element + var targetStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step[data-step-name=\"").concat(stepName, "\"]")); + if (!targetStep) { + return; + } + + // Find and hide the current step element + var currentStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step.").concat(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS)); + if (currentStep) { + currentStep.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(currentStep); + } + + // Display the target step element + targetStep.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(targetStep); + new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(targetStep).fadeIn(); + + // Update the onboarding wizard's current step attribute + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), + onboardingWizardPage = _getElements.onboardingWizardPage; + onboardingWizardPage.setAttribute('data-current-step', stepName); + + // Update the URL query parameter, with control over history update method + (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.setQueryParam)('step', stepName, updateMethod); + (0,_ui__WEBPACK_IMPORTED_MODULE_5__.updateRootline)(stepName); +}; + +/** + * Navigates to the next step in the sequence. + * + * The function assumes steps are sequentially ordered in the DOM. + * + * @return {void} + */ +var navigateToNextStep = function navigateToNextStep() { + var currentStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step.").concat(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS)); + var nextStep = currentStep === null || currentStep === void 0 ? void 0 : currentStep.nextElementSibling; + if (!nextStep) { + return; + } + var processedStep = currentStep.dataset.stepName; + var nextStepName = nextStep.dataset.stepName; + + // Save processed steps + var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_4__.getState)(), + processedSteps = _getState.processedSteps; + if (!processedSteps.includes(processedStep)) { + processedSteps.push(processedStep); + (0,_shared__WEBPACK_IMPORTED_MODULE_4__.setSingleState)('processedSteps', processedSteps); + } + (0,_dataUtils__WEBPACK_IMPORTED_MODULE_2__.setupUsageData)(processedStep, nextStepName); + navigateToStep(nextStepName); +}; + +/** + * Navigates to the previous step in the sequence. + * + * The function assumes steps are sequentially ordered in the DOM. + * + * @return {void} + */ +var navigateToPrevStep = function navigateToPrevStep() { + var currentStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step.").concat(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS)); + var prevStep = currentStep === null || currentStep === void 0 ? void 0 : currentStep.previousElementSibling; + if (!prevStep) { + return; + } + navigateToStep(prevStep.dataset.stepName); +}; + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. +(() => { +/*!*******************************************!*\ + !*** ./js/src/onboarding-wizard/index.js ***! + \*******************************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); +/* harmony import */ var _initializeOnboardingWizard__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./initializeOnboardingWizard */ "./js/src/onboarding-wizard/initializeOnboardingWizard.js"); +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + +(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_1__["default"])(function () { + (0,_initializeOnboardingWizard__WEBPACK_IMPORTED_MODULE_0__["default"])(); +}); +})(); + +/******/ })() +; +//# sourceMappingURL=onboarding-wizard.js.map \ No newline at end of file diff --git a/js/src/settings-components/components/slider-component.js b/js/src/settings-components/components/slider-component.js index 9a0cb45e9a..8d5a3294a0 100644 --- a/js/src/settings-components/components/slider-component.js +++ b/js/src/settings-components/components/slider-component.js @@ -240,6 +240,12 @@ export default class frmSliderComponent { * Initializes the position of sliders when a accordion section is opened. */ initSlidersPosition() { + const emailSettings = document.querySelector( '.email_settings' ); + if ( emailSettings ) { + this.initSlidersWidth( emailSettings ); + return; + } + const accordionitems = document.querySelectorAll( '#frm_style_sidebar .accordion-section h3' ); const quickSettings = document.querySelector( '.frm-quick-settings' ); const openedAccordion = document.querySelector( '.accordion-section.open' ); diff --git a/js/src/web-components/frm-border-radius-component/frm-border-radius-component.css b/js/src/web-components/frm-border-radius-component/frm-border-radius-component.css index c3af27b5b1..ff229e6b36 100644 --- a/js/src/web-components/frm-border-radius-component/frm-border-radius-component.css +++ b/js/src/web-components/frm-border-radius-component/frm-border-radius-component.css @@ -1 +1,229 @@ -:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-border-radius-component .frm-border-radius-container{width:100%;display:flex;justify-content:space-between;flex-wrap:wrap}.frm-border-radius-component .frm-border-radius-container button{overflow:hidden;text-indent:-9999px;cursor:pointer;width:36px;height:36px;border-radius:var(--small-radius);border:1px solid var(--grey-300);background:#fff;display:flex;justify-content:center;align-items:center;box-sizing:border-box;background:url('data:image/svg+xml,') no-repeat center center;background-size:20px}.frm-border-radius-component .frm-border-radius-container button.frm-active,.frm-border-radius-component .frm-border-radius-container button:hover{background-color:rgba(0,0,0,.05)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper{width:100%;justify-content:space-between;flex-wrap:wrap}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden){display:flex}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span{position:relative;display:block;overflow:hidden;width:calc(50% - 6px);height:36px;border-radius:var(--small-radius);border:1px solid var(--grey-300);margin-top:12px}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input{width:100%;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding:0 12px 0px 20px;box-sizing:border-box;border:none;text-align:right}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus{outline:none}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before{content:"";position:absolute;display:block;width:12px;height:12px;left:12px;top:0;bottom:0;right:auto;margin:auto;background:url('data:image/svg+xml,') center center no-repeat;background-size:12px}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before{transform:rotate(180deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before{transform:rotate(0deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before{transform:rotate(90deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before{transform:rotate(-90deg)}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper{width:calc(100% - 36px - 12px);height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300);overflow:hidden}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper>*{border:none}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input{width:calc(100% - 44px);height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus{outline:none}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus{outline:none} +/*!********************************************************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-border-radius-component/frm-border-radius-component.scss ***! + \********************************************************************************************************************************************************************************************************************************************************************************/ +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +.frm_hidden { + display: none; +} + +.frm-component:not(.frm-tabs-wrapper) { + display: flex; + justify-content: space-between; + align-items: center; +} +.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { + font-weight: 500; + font-size: var(--text-sm) !important; + color: var(--grey-900) !important; + width: 40% !important; + display: block !important; + margin-right: 12px !important; +} + +.frm-border-radius-component .frm-border-radius-container { + width: 100%; + display: flex; + justify-content: space-between; + flex-wrap: wrap; +} +.frm-border-radius-component .frm-border-radius-container button { + overflow: hidden; + text-indent: -9999px; + cursor: pointer; + width: 36px; + height: 36px; + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + background: white; + display: flex; + justify-content: center; + align-items: center; + box-sizing: border-box; + background: url('data:image/svg+xml,') no-repeat center center; + background-size: 20px; +} +.frm-border-radius-component .frm-border-radius-container button.frm-active, .frm-border-radius-component .frm-border-radius-container button:hover { + background-color: rgba(0, 0, 0, 0.05); +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper { + width: 100%; + justify-content: space-between; + flex-wrap: wrap; +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden) { + display: flex; +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span { + position: relative; + display: block; + overflow: hidden; + width: calc(50% - 6px); + height: 36px; + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + margin-top: 12px; +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input { + width: 100%; + height: 100%; + padding: 0; + font-size: var(--text-sm); + color: rgb(16, 24, 40); + padding: 0 12px 0px 20px; + box-sizing: border-box; + border: none; + text-align: right; +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus { + outline: none; +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before { + content: ""; + position: absolute; + display: block; + width: 12px; + height: 12px; + left: 12px; + top: 0; + bottom: 0; + right: auto; + margin: auto; + background: url('data:image/svg+xml,') center center no-repeat; + background-size: 12px; +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before { + transform: rotate(180deg); +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before { + transform: rotate(0deg); +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before { + transform: rotate(90deg); +} +.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before { + transform: rotate(-90deg); +} +.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper { + width: calc(100% - 36px - 12px); + height: 36px; + display: flex; + justify-content: center; + box-sizing: border-box; + background: white; + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + overflow: hidden; +} +.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper > * { + border: none; +} +.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input { + width: calc(100% - 44px); + height: 100%; + padding: 0; + font-size: var(--text-sm); + color: rgb(16, 24, 40); + padding-left: 12px; + box-sizing: border-box; +} +.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus { + outline: none; +} +.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select { + text-align: right; + padding: 0; + font-size: var(--text-sm); + color: rgb(102, 112, 133); + width: 44px; + background: url("../../images/style/small-arrow.svg") no-repeat; + background-position: center right 12px; +} +.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus { + outline: none; +} + +/*# sourceMappingURL=frm-border-radius-component.css.map*/ \ No newline at end of file diff --git a/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css b/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css index 544c82b1fb..af5620eb54 100644 --- a/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css +++ b/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css @@ -1 +1,154 @@ -:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-colorpicker-component .wp-picker-container button[type=button]{position:relative;height:36px !important;background-image:none !important;background-color:#fff !important;overflow:hidden}.frm-colorpicker-component .wp-picker-container button[type=button]:after{content:"";width:20px;height:20px;display:block;position:absolute;top:0;right:8px;bottom:0;margin:auto;background:url("--frm-plugin-url/images/style/small-arrow.svg") no-repeat;background-position:center;z-index:10}.frm-colorpicker-component .wp-picker-container button[type=button]:focus{border-color:var(--primary-500) !important}.frm-colorpicker-component .wp-color-result-text{line-height:36px !important;padding:0 12px;border:0}.frm-colorpicker-component .color-alpha{width:20px !important;height:20px !important;border-radius:50% !important;border:1px solid #d0d5dd;top:0;left:0;bottom:0;margin:auto;margin-left:12px}.frm-colorpicker-component .wp-picker-input-wrap input{width:calc(100% - 10px) !important;margin:1px 5px;height:32px;line-height:32px} +/*!****************************************************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.scss ***! + \****************************************************************************************************************************************************************************************************************************************************************************/ +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +.frm_hidden { + display: none; +} + +.frm-component:not(.frm-tabs-wrapper) { + display: flex; + justify-content: space-between; + align-items: center; +} +.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { + font-weight: 500; + font-size: var(--text-sm) !important; + color: var(--grey-900) !important; + width: 40% !important; + display: block !important; + margin-right: 12px !important; +} + +.frm-colorpicker-component .wp-picker-container button[type=button] { + position: relative; + height: 36px !important; + background-image: none !important; + background-color: #fff !important; + overflow: hidden; +} +.frm-colorpicker-component .wp-picker-container button[type=button]:after { + content: ""; + width: 20px; + height: 20px; + display: block; + position: absolute; + top: 0; + right: 8px; + bottom: 0; + margin: auto; + background: url("--frm-plugin-url/images/style/small-arrow.svg") no-repeat; + background-position: center; + z-index: 10; +} +.frm-colorpicker-component .wp-picker-container button[type=button]:focus { + border-color: var(--primary-500) !important; +} +.frm-colorpicker-component .wp-color-result-text { + line-height: 36px !important; + padding: 0 12px; + border: 0; +} +.frm-colorpicker-component .color-alpha { + width: 20px !important; + height: 20px !important; + border-radius: 50% !important; + border: 1px solid rgb(208, 213, 221); + top: 0; + left: 0; + bottom: 0; + margin: auto; + margin-left: 12px; +} +.frm-colorpicker-component .wp-picker-input-wrap input { + width: calc(100% - 10px) !important; + margin: 1px 5px; + height: 32px; + line-height: 32px; +} + +/*# sourceMappingURL=frm-colorpicker-component.css.map*/ \ No newline at end of file diff --git a/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css b/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css index a0fddc88ff..aae593022a 100644 --- a/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css +++ b/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css @@ -1 +1,132 @@ -:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-dropdown-component select{width:100%;outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px var(--gap-lg) 5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;line-height:var(--leading);border-width:1px;border-style:solid;background-position:center 5px;background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;background-color:#fff;appearance:none;-webkit-appearance:none;-moz-appearance:none}.frm-dropdown-component select:focus{border-color:var(--primary-500);box-shadow:none} +/*!**********************************************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-dropdown-component/frm-dropdown-component.scss ***! + \**********************************************************************************************************************************************************************************************************************************************************************/ +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +.frm_hidden { + display: none; +} + +.frm-component:not(.frm-tabs-wrapper) { + display: flex; + justify-content: space-between; + align-items: center; +} +.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { + font-weight: 500; + font-size: var(--text-sm) !important; + color: var(--grey-900) !important; + width: 40% !important; + display: block !important; + margin-right: 12px !important; +} + +.frm-dropdown-component select { + width: 100%; + outline: 0; + box-shadow: var(--box-shadow-xs); + border-radius: var(--small-radius); + padding: 5px var(--gap-lg) 5px 14px; + border-color: var(--grey-300); + color: var(--grey-800); + font-size: var(--text-md); + margin: 0; + line-height: var(--leading); + border-width: 1px; + border-style: solid; + background-position: center 5px; + background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; + background-color: #fff; + appearance: none; + -webkit-appearance: none; + -moz-appearance: none; +} +.frm-dropdown-component select:focus { + border-color: var(--primary-500); + box-shadow: none; +} + +/*# sourceMappingURL=frm-dropdown-component.css.map*/ \ No newline at end of file diff --git a/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css b/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css index 2b25df1459..861ead77f7 100644 --- a/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css +++ b/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css @@ -1 +1,290 @@ -.frm-style-component .frm-slider-container{width:calc(100% - 91px);display:flex;align-items:center;color:#1d2939}.frm-style-component .frm-slider-container svg.frmsvg{color:currentColor;margin-right:8px;margin-left:-5px;position:relative;z-index:15}.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover{color:#4199fd;cursor:pointer}.frm-style-component .frm-slider-container .frm-slider-active-track{display:block;height:100%;width:0;position:relative;border-radius:200px}.frm-style-component .frm-slider-container .frm-slider-active-track,.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{background:#4199fd;box-shadow:0 1.88px 4px -1px rgba(16,24,40,.03),0 6px 8px -2px rgba(16,24,40,.08)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{position:absolute;display:block;width:16px;height:16px;border-radius:50%;transform:translateX(15px);cursor:grab;right:0;top:0;bottom:0;margin:auto}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label{position:absolute;display:block;width:48px;height:36px;background:#101828;color:#fff;font-weight:400;font-size:var(--text-sm);line-height:36px;border-radius:var(--small-radius);transform:translate(-18px, -42px) scale3d(0.7, 1, 1);opacity:0;z-index:-2;pointer-events:none;text-align:center;user-select:none}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label{z-index:12;transform:translate(-18px, -42px) scale3d(1, 1, 1);opacity:1;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before{content:"";display:block;position:absolute;width:18px;height:18px;border-radius:50%;left:0;top:0;transform:translate(-5px, -5px) scale3d(0.7, 0.7, 1);border:4px solid #4199fd;opacity:0;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before{opacity:.5;transform:translate(-5px, -5px) scale3d(1, 1, 1);transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after{content:"";position:absolute;display:block;width:180%;height:200%;border-radius:50%;left:0;top:0;transform:translate(-24%, -24%)}.frm-style-component .frm-slider-value{width:86px;height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300)}.frm-style-component .frm-slider-value>*{border:none}.frm-style-component .frm-slider-value input{width:40px;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-style-component .frm-slider-value select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px;padding-right:24px !important}.frm-style-component .frm-slider-value select.frm-single-unit{pointer-events:none;background-image:none;padding-right:12px !important}.frm-style-component .frm-slider{display:block;width:calc(100% - 5px);height:4px;background:#eaecf0;border-radius:200px;cursor:pointer}.frm-slider-component .frm-independent-slider-field{margin-top:10px}.frm-slider-component.frm-disabled .frm-slider-container{pointer-events:none;opacity:.5}.frm-slider-component.frm-disabled .frm-slider-value input[type=text]{width:28px}.frm-slider-component.frm-disabled .frm-slider-value select{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text]{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select{width:28px}.frm-style-component .frm-slider-component.frm-has-multiple-values{margin-bottom:10px}:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-component .frmsvg{width:18px;height:18px}.frm-component .frm-sliders-container{width:100%}.frm-component .frm-group-sliders .frm-slider-component{margin-top:5px} +/*!******************************************************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-range-slider-component/frm-range-slider-component.scss ***! + \******************************************************************************************************************************************************************************************************************************************************************************/ +/** + * Sliders component styles + */ +.frm-style-component .frm-slider-container { + width: calc(100% - 91px); + display: flex; + align-items: center; + color: rgb(29, 41, 57); +} +.frm-style-component .frm-slider-container svg.frmsvg { + color: currentColor; + margin-right: 8px; + margin-left: -5px; + position: relative; + z-index: 15; +} + +.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover { + color: rgb(65, 153, 253); + cursor: pointer; +} + +.frm-style-component .frm-slider-container .frm-slider-active-track { + display: block; + height: 100%; + width: 0; + position: relative; + border-radius: 200px; +} +.frm-style-component .frm-slider-container .frm-slider-active-track, +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { + background: rgb(65, 153, 253); + box-shadow: 0 1.88px 4px -1px rgba(16, 24, 40, 0.03), 0 6px 8px -2px rgba(16, 24, 40, 0.08); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { + position: absolute; + display: block; + width: 16px; + height: 16px; + border-radius: 50%; + transform: translateX(15px); + cursor: grab; + right: 0; + top: 0; + bottom: 0; + margin: auto; +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label { + position: absolute; + display: block; + width: 48px; + height: 36px; + background: rgb(16, 24, 40); + color: white; + font-weight: 400; + font-size: var(--text-sm); + line-height: 36px; + border-radius: var(--small-radius); + transform: translate(-18px, -42px) scale3d(0.7, 1, 1); + opacity: 0; + z-index: -2; + pointer-events: none; + text-align: center; + user-select: none; +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label { + z-index: 12; + transform: translate(-18px, -42px) scale3d(1, 1, 1); + opacity: 1; + transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before { + content: ""; + display: block; + position: absolute; + width: 18px; + height: 18px; + border-radius: 50%; + left: 0; + top: 0; + transform: translate(-5px, -5px) scale3d(0.7, 0.7, 1); + border: 4px solid rgb(65, 153, 253); + opacity: 0; + transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before { + opacity: 0.5; + transform: translate(-5px, -5px) scale3d(1, 1, 1); + transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} +.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after { + content: ""; + position: absolute; + display: block; + width: 180%; + height: 200%; + border-radius: 50%; + left: 0; + top: 0; + transform: translate(-24%, -24%); +} + +.frm-style-component .frm-slider-value { + width: 86px; + height: 36px; + display: flex; + justify-content: center; + box-sizing: border-box; + background: white; + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); +} +.frm-style-component .frm-slider-value > * { + border: none; +} +.frm-style-component .frm-slider-value input { + width: 40px; + height: 100%; + padding: 0; + font-size: var(--text-sm); + color: rgb(16, 24, 40); + padding-left: 12px; + box-sizing: border-box; +} +.frm-style-component .frm-slider-value select { + text-align: right; + padding: 0; + font-size: var(--text-sm); + color: rgb(102, 112, 133); + width: 44px; + background: url("../../images/style/small-arrow.svg") no-repeat; + background-position: center right 12px; + padding-right: 24px !important; +} +.frm-style-component .frm-slider-value select.frm-single-unit { + pointer-events: none; + background-image: none; + padding-right: 12px !important; +} +.frm-style-component .frm-slider { + display: block; + width: calc(100% - 5px); + height: 4px; + background: rgb(234, 236, 240); + border-radius: 200px; + cursor: pointer; +} + +.frm-slider-component .frm-independent-slider-field { + margin-top: 10px; +} +.frm-slider-component.frm-disabled .frm-slider-container { + pointer-events: none; + opacity: 0.5; +} +.frm-slider-component.frm-disabled .frm-slider-value input[type=text] { + width: 28px; +} +.frm-slider-component.frm-disabled .frm-slider-value select { + width: 56px; +} +.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text] { + width: 56px; +} +.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select { + width: 28px; +} + +.frm-style-component .frm-slider-component.frm-has-multiple-values { + margin-bottom: 10px; +} + +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +.frm_hidden { + display: none; +} + +.frm-component:not(.frm-tabs-wrapper) { + display: flex; + justify-content: space-between; + align-items: center; +} +.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { + font-weight: 500; + font-size: var(--text-sm) !important; + color: var(--grey-900) !important; + width: 40% !important; + display: block !important; + margin-right: 12px !important; +} + +.frm-component .frmsvg { + width: 18px; + height: 18px; +} +.frm-component .frm-sliders-container { + width: 100%; +} +.frm-component .frm-group-sliders .frm-slider-component { + margin-top: 5px; +} + +/*# sourceMappingURL=frm-range-slider-component.css.map*/ \ No newline at end of file diff --git a/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css b/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css index 29b60a813b..4e1c15aded 100644 --- a/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css +++ b/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css @@ -1 +1,243 @@ -:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-tabs-wrapper{position:relative;overflow:hidden}.frm-tabs-wrapper .frm-tabs-navigator{margin:0;padding:0;display:flex;gap:var(--gap-xs);justify-content:space-between;align-items:center;background:#f2f4f7;border-radius:var(--small-radius);box-sizing:border-box;height:44px;position:relative;z-index:2}.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item{flex:1;text-align:center;cursor:pointer}.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background{display:block;height:100%;background:#fff;position:absolute;top:0;left:0;z-index:1}.frm-tabs-navs{padding:0;min-height:44px}.frm-tabs-navs ul{margin:0;height:var(--h-md);position:relative;display:flex;justify-content:space-between;list-style-type:none;padding:0px}.frm-tabs-navs ul li,.frm-tabs-navs ul li a{color:var(--grey-500);font-weight:500;font-size:var(--text-sm);line-height:28px}.frm-tabs-navs ul li{flex:1;height:28px;text-align:center;margin-top:var(--gap-xs);margin-bottom:0;cursor:pointer}.frm-tabs-navs ul li.frm-active,.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a{color:var(--grey-900)}.frm-tabs-navs ul li:first-child{margin-left:var(--gap-xs)}.frm-tabs-navs ul li:last-child{margin-right:var(--gap-xs)}.frm-tabs-delimiter{position:absolute;top:0;left:0;width:100%;background:#f2f4f7;height:44px;margin:0;border-radius:var(--small-radius)}.frm-tabs-delimiter .frm-tabs-active-underline{height:28px;background:#fff;position:absolute;left:0;bottom:8px;transition:.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);border-radius:var(--small-radius);box-shadow:var(--button-shadow);display:none}.frm-tabs-container{position:relative;overflow:hidden;margin-top:var(--gap-md);height:100%}.frm-tabs-container .frm-tabs-slide-track{display:flex;transition:.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-tabs-slide-track>div{flex:0 0 100%;opacity:0;transition:.25s opacity linear;position:relative;height:auto;max-height:unset;overflow:hidden;box-sizing:border-box}.frm-tabs-slide-track>div>div{overflow:auto;position:relative;width:100%;padding:0;box-sizing:border-box}.frm-tabs-slide-track>div>div:first-child{height:100%}.frm-tabs-slide-track>div.frm-active{opacity:1;transition:.35s opacity linear} +/*!********************************************************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.scss ***! + \********************************************************************************************************************************************************************************************************************************************************************************/ +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +.frm_hidden { + display: none; +} + +.frm-component:not(.frm-tabs-wrapper) { + display: flex; + justify-content: space-between; + align-items: center; +} +.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { + font-weight: 500; + font-size: var(--text-sm) !important; + color: var(--grey-900) !important; + width: 40% !important; + display: block !important; + margin-right: 12px !important; +} + +.frm-tabs-wrapper { + position: relative; + overflow: hidden; +} +.frm-tabs-wrapper .frm-tabs-navigator { + margin: 0; + padding: 0; + display: flex; + gap: var(--gap-xs); + justify-content: space-between; + align-items: center; + background: rgb(242, 244, 247); + border-radius: var(--small-radius); + box-sizing: border-box; + height: 44px; + position: relative; + z-index: 2; +} +.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item { + flex: 1; + text-align: center; + cursor: pointer; +} +.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background { + display: block; + height: 100%; + background: white; + position: absolute; + top: 0; + left: 0; + z-index: 1; +} + +.frm-tabs-navs { + padding: 0; + min-height: 44px; +} +.frm-tabs-navs ul { + margin: 0; + height: var(--h-md); + position: relative; + display: flex; + justify-content: space-between; + list-style-type: none; + padding: 0px; +} +.frm-tabs-navs ul li, +.frm-tabs-navs ul li a { + color: var(--grey-500); + font-weight: 500; + font-size: var(--text-sm); + line-height: 28px; +} +.frm-tabs-navs ul li { + flex: 1; + height: 28px; + text-align: center; + margin-top: var(--gap-xs); + margin-bottom: 0; + cursor: pointer; +} + +.frm-tabs-navs ul li.frm-active, .frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a { + color: var(--grey-900); +} + +.frm-tabs-navs ul li:first-child { + margin-left: var(--gap-xs); +} + +.frm-tabs-navs ul li:last-child { + margin-right: var(--gap-xs); +} + +.frm-tabs-delimiter { + position: absolute; + top: 0; + left: 0; + width: 100%; + background: rgb(242, 244, 247); + height: 44px; + margin: 0; + border-radius: var(--small-radius); +} +.frm-tabs-delimiter .frm-tabs-active-underline { + height: 28px; + background: white; + position: absolute; + left: 0; + bottom: 8px; + transition: 0.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); + border-radius: var(--small-radius); + box-shadow: var(--button-shadow); + display: none; +} + +.frm-tabs-container { + position: relative; + overflow: hidden; + margin-top: var(--gap-md); + height: 100%; +} + +.frm-tabs-container .frm-tabs-slide-track { + display: flex; + transition: 0.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); +} + +.frm-tabs-slide-track > div { + flex: 0 0 100%; + opacity: 0; + transition: 0.25s opacity linear; + position: relative; + height: auto; + max-height: unset; + overflow: hidden; + box-sizing: border-box; +} + +.frm-tabs-slide-track > div > div { + overflow: auto; + position: relative; + width: 100%; + padding: 0; + box-sizing: border-box; +} + +.frm-tabs-slide-track > div > div:first-child { + height: 100%; +} + +.frm-tabs-slide-track > div.frm-active { + opacity: 1; + transition: 0.35s opacity linear; +} + +/*# sourceMappingURL=frm-tab-navigator-component.css.map*/ \ No newline at end of file diff --git a/js/src/web-components/frm-typography-component/frm-typography-component.css b/js/src/web-components/frm-typography-component/frm-typography-component.css index a399a2a963..7d1ee3da53 100644 --- a/js/src/web-components/frm-typography-component/frm-typography-component.css +++ b/js/src/web-components/frm-typography-component/frm-typography-component.css @@ -1 +1,166 @@ -:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-typography-component .frm-typography-container{display:flex;justify-content:space-between;width:100%}.frm-typography-component .frm-typography-container select{width:calc(70% - 6px);outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;background-color:#fff;line-height:var(--leading);border-width:1px;border-style:solid}.frm-typography-component .frm-typography-container .frm-unit-value{width:28%;height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300);overflow:hidden}.frm-typography-component .frm-typography-container .frm-unit-value>*{border:none}.frm-typography-component .frm-typography-container .frm-unit-value input{width:32px;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:8px;box-sizing:border-box}.frm-typography-component .frm-typography-container .frm-unit-value input:focus{outline:none}.frm-typography-component .frm-typography-container .frm-unit-value select{text-align:left;padding:0;font-size:var(--text-sm);color:#667085;width:36px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px}.frm-typography-component .frm-typography-container .frm-unit-value select:focus{outline:none} +/*!**************************************************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-typography-component/frm-typography-component.scss ***! + \**************************************************************************************************************************************************************************************************************************************************************************/ +/** + * Base - Variables + */ +:root, +.frm-white-body, +.frm_wrap { + --grey-900: #101828; + --grey-800: #1d2939; + --grey-700: #344054; + --grey-600: #475467; + --grey-500: #667085; /* Roughly 65% opacity */ + --grey-400: #98a2b3; + --grey-300: #d0d5dd; + --grey-200: #eaecf0; + --grey-100: #f2f4f7; + --grey-50: #f9fafb; + --grey-25: #fcfcfd; + --dark-grey: var(--grey-700); /* Deprecated */ + --medium-grey: rgba(40, 47, 54, 0.65); + --grey: var(--grey-500); /* Deprecated */ + --grey-border: var(--grey-300); /* Deprecated */ + --lightest-grey: rgb(250, 250, 250); + --sidebar-color: var(--grey-50); + --sidebar-hover: var(--grey-200); + --primary-700: #2b66a9; + --primary-500: #4199fd; + --primary-300: #80bbfe; + --primary-200: #c0ddfe; + --primary-50: #ecf5ff; + --primary-25: #f5faff; + --primary-color: var(--primary-500); /* Deprecated */ + --primary-hover: var(--primary-700); /* Deprecated */ + --light-blue: var(--primary-25); /* Deprecated */ + --blue-border: rgb(188, 224, 253); + --error-700: #b42318; + --error-500: #f04438; + --error-300: #fecdca; + --error-100: #fee4e2; + --error-25: #fff5f4; + --green: rgb(63, 172, 37); + --orange: #f15a24; + --warning-500: #f79009; + --pink: rgb(226, 42, 110); + --purple: rgb(141, 53, 245); + --success-900: #054f31; + --success-800: #065f46; + --success-500: #12b76a; + --success-100: #d1fae5; + --success-200: #a6f4c5; + --success-50: #ecfdf3; + --success-25: #f6fef9; + --border-radius: 35px; + --small-radius: 8px; + --medium-radius: 16px; + --small-sidebar: 275px; + --medium-sidebar: 350px; + --big-sidebar: 390px; + --biggest-sidebar: 450px; + --text-xs: 12px; + --text-sm: 14px; + --text-md: 16px; + --text-lg: 18px; + --text-xl: 20px; + --h-xs: 24px; + --h-sm: 30px; + --h-md: 36px; + --leading: 1.5; + --gap-2xs: 4px; + --gap-xs: 8px; + --gap-sm: 16px; + --gap-md: 24px; + --gap-lg: 32px; + --gap-xl: 40px; + --gap-2xl: 48px; + --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); + --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); + --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); + --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); + --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); + /* Override front-end CSS */ + --check-label-color: var(--grey-700); +} + +.frm_hidden { + display: none; +} + +.frm-component:not(.frm-tabs-wrapper) { + display: flex; + justify-content: space-between; + align-items: center; +} +.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { + font-weight: 500; + font-size: var(--text-sm) !important; + color: var(--grey-900) !important; + width: 40% !important; + display: block !important; + margin-right: 12px !important; +} + +.frm-typography-component .frm-typography-container { + display: flex; + justify-content: space-between; + width: 100%; +} +.frm-typography-component .frm-typography-container select { + width: calc(70% - 6px); + outline: 0; + box-shadow: var(--box-shadow-xs); + border-radius: var(--small-radius); + padding: 5px 14px; + border-color: var(--grey-300); + color: var(--grey-800); + font-size: var(--text-md); + margin: 0; + background-color: #fff; + line-height: var(--leading); + border-width: 1px; + border-style: solid; +} +.frm-typography-component .frm-typography-container .frm-unit-value { + width: 28%; + height: 36px; + display: flex; + justify-content: center; + box-sizing: border-box; + background: white; + border-radius: var(--small-radius); + border: 1px solid var(--grey-300); + overflow: hidden; +} +.frm-typography-component .frm-typography-container .frm-unit-value > * { + border: none; +} +.frm-typography-component .frm-typography-container .frm-unit-value input { + width: 32px; + height: 100%; + padding: 0; + font-size: var(--text-sm); + color: rgb(16, 24, 40); + padding-left: 8px; + box-sizing: border-box; +} +.frm-typography-component .frm-typography-container .frm-unit-value input:focus { + outline: none; +} +.frm-typography-component .frm-typography-container .frm-unit-value select { + text-align: left; + padding: 0; + font-size: var(--text-sm); + color: rgb(102, 112, 133); + width: 36px; + background: url("../../images/style/small-arrow.svg") no-repeat; + background-position: center right 12px; +} +.frm-typography-component .frm-typography-container .frm-unit-value select:focus { + outline: none; +} + +/*# sourceMappingURL=frm-typography-component.css.map*/ \ No newline at end of file diff --git a/js/welcome-tour.js b/js/welcome-tour.js index 20079e0d6c..af97ea8d36 100644 --- a/js/welcome-tour.js +++ b/js/welcome-tour.js @@ -1,2 +1,4436 @@ -/*! For license information please see welcome-tour.js.LICENSE.txt */ -(()=>{var t={8616:t=>{t.exports=function(t,e){var r,n,o=0;function i(){var i,a,c=r,s=arguments.length;t:for(;c;){if(c.args.length===arguments.length){for(a=0;a{var n;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function i(t){return function(t,e){var r,n,a,c,s,u,l,f,p,d=1,h=t.length,m="";for(n=0;n=0),c.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,c.width?parseInt(c.width):0);break;case"e":r=c.precision?parseFloat(r).toExponential(c.precision):parseFloat(r).toExponential();break;case"f":r=c.precision?parseFloat(r).toFixed(c.precision):parseFloat(r);break;case"g":r=c.precision?String(Number(r.toPrecision(c.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=c.precision?r.substring(0,c.precision):r;break;case"t":r=String(!!r),r=c.precision?r.substring(0,c.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=c.precision?r.substring(0,c.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=c.precision?r.substring(0,c.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}o.json.test(c.type)?m+=r:(!o.number.test(c.type)||f&&!c.sign?p="":(p=f?"+":"-",r=r.toString().replace(o.sign,"")),u=c.pad_char?"0"===c.pad_char?"0":c.pad_char.charAt(1):" ",l=c.width-(p+r).length,s=c.width&&l>0?u.repeat(l):"",m+=c.align?p+r+s:"0"===u?p+s+r:s+p+r)}return m}(function(t){if(c[t])return c[t];for(var e,r=t,n=[],i=0;r;){if(null!==(e=o.text.exec(r)))n.push(e[0]);else if(null!==(e=o.modulo.exec(r)))n.push("%");else{if(null===(e=o.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){i|=1;var a=[],s=e[2],u=[];if(null===(u=o.key.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(u[1]);""!==(s=s.substring(u[0].length));)if(null!==(u=o.key_access.exec(s)))a.push(u[1]);else{if(null===(u=o.index_access.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(u[1])}e[2]=a}else i|=2;if(3===i)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}r=r.substring(e[0].length)}return c[t]=n}(t),arguments)}function a(t,e){return i.apply(null,[t].concat(e||[]))}var c=Object.create(null);"undefined"!=typeof window&&(window.sprintf=i,window.vsprintf=a,void 0===(n=function(){return{sprintf:i,vsprintf:a}}.call(e,r,e,t))||(t.exports=n))}()}},e={};function r(n){var o=e[n];if(void 0!==o)return o.exports;var i=e[n]={exports:{}};return t[n](i,i.exports,r),i.exports}r.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return r.d(e,{a:e}),e},r.d=(t,e)=>{for(var n in e)r.o(e,n)&&!r.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:e[n]})},r.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";function t(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),r.push.apply(r,n)}return r}function e(e){for(var r=1;r0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==o(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var r=t;return{getElements:function(){return r},addElements:function(t){if("object"!==o(t)||null===t)throw new Error("addElements: newElements must be a non-null object");r=e(e({},r),t)}}}(i),p=f.getElements,d=f.addElements,h=r(8616),m=r.n(h);function v(t){return v="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},v(t)}function y(t){var e=function(t){if("object"!=v(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var r=e.call(t,"string");if("object"!=v(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==v(e)?e:e+""}r(7604),m()(console.error),c={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},s=["(","?"],u={")":["("],":":["?","?:"]},l=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var b={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,r){if(t)throw e;return r}};var g={contextDelimiter:"",onMissingKey:null};function _(t,e){var r;for(r in this.data=t,this.pluralForms={},this.options={},g)this.options[r]=void 0!==e&&r in e?e[r]:g[r]}function w(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),r.push.apply(r,n)}return r}function x(t){for(var e=1;e=0||c[o]3&&void 0!==arguments[3]?arguments[3]:10,a=t[e];if(j(r)&&S(n))if("function"==typeof o)if("number"==typeof i){var c={callback:o,priority:i,namespace:n};if(a[r]){var s,u=a[r].handlers;for(s=u.length;s>0&&!(i>=u[s-1].priority);s--);s===u.length?u[s]=c:u.splice(s,0,c),a.__current.forEach(function(t){t.name===r&&t.currentIndex>=s&&t.currentIndex++})}else a[r]={handlers:[c],runs:0};"hookAdded"!==r&&t.doAction("hookAdded",r,n,o,i)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},P=function(t,e){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n,o){var i=t[e];if(j(n)&&(r||S(o))){if(!i[n])return 0;var a=0;if(r)a=i[n].handlers.length,i[n]={runs:i[n].runs,handlers:[]};else for(var c=i[n].handlers,s=function(t){c[t].namespace===o&&(c.splice(t,1),a++,i.__current.forEach(function(e){e.name===n&&e.currentIndex>=t&&e.currentIndex--}))},u=c.length-1;u>=0;u--)s(u);return"hookRemoved"!==n&&t.doAction("hookRemoved",n,o),a}}},F=function(t,e){return function(r,n){var o=t[e];return void 0!==n?r in o&&o[r].handlers.some(function(t){return t.namespace===n}):r in o}},T=function(t,e){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var o=t[e];o[n]||(o[n]={handlers:[],runs:0}),o[n].runs++;for(var i=o[n].handlers,a=arguments.length,c=new Array(a>1?a-1:0),s=1;s1&&void 0!==arguments[1]?arguments[1]:"default";n.data[e]=x(x(x({},k),n.data[e]),t),n.data[e][""]=x(x({},k[""]),n.data[e][""])},c=function(t,e){a(t,e),i()},s=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;return n.data[t]||a(void 0,t),n.dcnpgettext(t,e,r,o,i)},u=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},l=function(t,e,n){var o=s(n,e,t);return r?(o=r.applyFilters("i18n.gettext_with_context",o,t,e,n),r.applyFilters("i18n.gettext_with_context_"+u(n),o,t,e,n)):o};if(r){var f=function(t){O.test(t)&&i()};r.addAction("hookAdded","core/i18n",f),r.addAction("hookRemoved","core/i18n",f)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[t]},setLocaleData:c,resetLocaleData:function(t,e){n.data={},n.pluralForms={},c(t,e)},subscribe:function(t){return o.add(t),function(){return o.delete(t)}},__:function(t,e){var n=s(e,void 0,t);return r?(n=r.applyFilters("i18n.gettext",n,t,e),r.applyFilters("i18n.gettext_"+u(e),n,t,e)):n},_x:l,_n:function(t,e,n,o){var i=s(o,void 0,t,e,n);return r?(i=r.applyFilters("i18n.ngettext",i,t,e,n,o),r.applyFilters("i18n.ngettext_"+u(o),i,t,e,n,o)):i},_nx:function(t,e,n,o,i){var a=s(i,o,t,e,n);return r?(a=r.applyFilters("i18n.ngettext_with_context",a,t,e,n,o,i),r.applyFilters("i18n.ngettext_with_context_"+u(i),a,t,e,n,o,i)):a},isRTL:function(){return"rtl"===l("ltr","text direction")},hasTranslation:function(t,e,o){var i,a,c=e?e+""+t:t,s=!(null===(i=n.data)||void 0===i||null===(a=i[null!=o?o:"default"])||void 0===a||!a[c]);return r&&(s=r.applyFilters("i18n.has_translation",s,t,e,o),s=r.applyFilters("i18n.has_translation_"+u(o),s,t,e,o)),s}}}(0,0,C));R.getLocaleData.bind(R),R.setLocaleData.bind(R),R.resetLocaleData.bind(R),R.subscribe.bind(R);var G=R.__.bind(R),N=(R._x.bind(R),R._n.bind(R),R._nx.bind(R),R.isRTL.bind(R),R.hasTranslation.bind(R),Promise.resolve(),frmDom),B=N.div,M=(N.span,N.tag),q=N.a,z=(N.img,N.svg,frmDom.modal),U=z.maybeCreateModal,$=(z.footerButton,frmDom.util),K=$.onClickPreventDefault,Z=($.documentOn,frmDom.ajax.doJsonPost),H=new URL(window.location.href).searchParams,X=window.frmGlobal,J=(X.url,X.nonce,window.frmWelcomeTourVars),W=J.IS_DASHBOARD_PAGE,V=J.IS_WELCOME_TOUR_SEEN,Y=(J.CHECKLIST_STEPS,J.TOUR_URL),Q=J.PROGRESS_BAR_PERCENT;const tt=function(){var t,e;W&&!V&&function(t){p().beginTourModal||d({beginTourModal:t})}(((t=U("frm_get_started_modal",{title:G("Get Started with Formidable Forms","formidable"),content:(e={className:"frm-px-md",text:G("Here's a quick checklist to help you set up and explore the key features of the plugin, so you can start building powerful forms in no time.","formidable")},M("p",e)),footer:B({className:"frmcenter",child:q({className:"button button-primary frm-button-primary",href:Y,text:G("Begin Tour","formidable")})}),width:"440px",dialogClass:"frm-fadein-up-back"})).classList.add("frm_wrap","frm-welcome-tour-modal","frmcenter"),t))};function et(t,e){if(e.offsetParent){var r=e.getBoundingClientRect();if(0!==r.width&&0!==r.height){var n,o=t.dataset.leftPosition;switch(o){case"middle":n=r.left+Math.round(r.width/2);break;case"end":n=r.right;break;default:n=r.left+parseInt(o)}t.style.left="".concat(n||r.left,"px");var i="bottom"===t.dataset.placement?r.top+r.height:r.top+Math.round(r.height/2);t.style.top="".concat(i,"px")}}}function rt(){var t,e,r="function"==typeof Symbol?Symbol:{},n=r.iterator||"@@iterator",o=r.toStringTag||"@@toStringTag";function i(r,n,o,i){var s=n&&n.prototype instanceof c?n:c,u=Object.create(s.prototype);return nt(u,"_invoke",function(r,n,o){var i,c,s,u=0,l=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,r){return i=e,c=0,s=t,p.n=r,a}};function d(r,n){for(c=r,s=n,e=0;!f&&u&&!o&&e3?(o=h===n)&&(s=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=r<2&&dn||n>h)&&(i[4]=r,i[5]=n,p.n=h,c=0))}if(o||r>1)return a;throw f=!0,n}return function(o,l,h){if(u>1)throw TypeError("Generator is already running");for(f&&1===l&&d(l,h),c=l,s=h;(e=c<2?t:s)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,s)):p.n=s:p.v=s);try{if(u=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,s)))throw TypeError("iterator result is not an object");if(!e.done)return e;s=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(s=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?s:r.call(n,p))!==a)break}catch(e){i=t,c=1,s=e}finally{u=1}}return{value:e,done:f}}}(r,o,i),!0),u}var a={};function c(){}function s(){}function u(){}e=Object.getPrototypeOf;var l=[][n]?e(e([][n]())):(nt(e={},n,function(){return this}),e),f=u.prototype=c.prototype=Object.create(l);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,nt(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return s.prototype=u,nt(f,"constructor",u),nt(u,"constructor",s),s.displayName="GeneratorFunction",nt(u,o,"GeneratorFunction"),nt(f),nt(f,o,"Generator"),nt(f,n,function(){return this}),nt(f,"toString",function(){return"[object Generator]"}),(rt=function(){return{w:i,m:p}})()}function nt(t,e,r,n){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}nt=function(t,e,r,n){function i(e,r){nt(t,e,function(t){return this._invoke(e,r,t)})}e?o?o(t,e,{value:r,enumerable:!n,configurable:!n,writable:!n}):t[e]=r:(i("next",0),i("throw",1),i("return",2))},nt(t,e,r,n)}function ot(t,e,r,n,o,i,a){try{var c=t[i](a),s=c.value}catch(t){return void r(t)}c.done?e(s):Promise.resolve(s).then(n,o)}var it="frm-checklist__step";function at(t){return ct.apply(this,arguments)}function ct(){var t;return t=rt().m(function t(e){var r,n,o,i;return rt().w(function(t){for(;;)switch(t.p=t.n){case 0:if(p().checklist){t.n=1;break}return t.a(2);case 1:if(r=document.getElementById("".concat(it,"-").concat(e))){t.n=2;break}return t.a(2);case 2:if(r.classList.contains("".concat(it,"--active"))){t.n=3;break}return t.a(2);case 3:return(n=new FormData).append("step_key",e),t.p=4,t.n=5,Z("mark_checklist_step_as_completed",n);case 5:if(r.classList.remove("".concat(it,"--active")),r.classList.add("".concat(it,"--completed")),o=r.nextElementSibling){t.n=6;break}return t.a(2);case 6:o.classList.add("".concat(it,"--active")),o.dataset.link&&st(o),t.n=8;break;case 7:t.p=7,i=t.v,console.error("Failed to mark step as completed:",i);case 8:return t.a(2)}},t,null,[[4,7]])}),ct=function(){var e=this,r=arguments;return new Promise(function(n,o){var i=t.apply(e,r);function a(t){ot(i,n,o,a,c,"next",t)}function c(t){ot(i,n,o,a,c,"throw",t)}a(void 0)})},ct.apply(this,arguments)}function st(t){var e=t.querySelector(".frm-checklist__step-title");if(null==e||!e.querySelector("a")){var r=q({href:t.dataset.link,className:"frm-h-stack-xs",children:Array.from(e.childNodes)});e.replaceChildren(r)}}function ut(){var t=p(),e=t.welcomeTour,r=t.spotlight;null==e||e.remove(),null==r||r.remove(),Z("dismiss_welcome_tour",new FormData)}function lt(){var t,e,r="function"==typeof Symbol?Symbol:{},n=r.iterator||"@@iterator",o=r.toStringTag||"@@toStringTag";function i(r,n,o,i){var s=n&&n.prototype instanceof c?n:c,u=Object.create(s.prototype);return ft(u,"_invoke",function(r,n,o){var i,c,s,u=0,l=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,r){return i=e,c=0,s=t,p.n=r,a}};function d(r,n){for(c=r,s=n,e=0;!f&&u&&!o&&e3?(o=h===n)&&(s=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=r<2&&dn||n>h)&&(i[4]=r,i[5]=n,p.n=h,c=0))}if(o||r>1)return a;throw f=!0,n}return function(o,l,h){if(u>1)throw TypeError("Generator is already running");for(f&&1===l&&d(l,h),c=l,s=h;(e=c<2?t:s)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,s)):p.n=s:p.v=s);try{if(u=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,s)))throw TypeError("iterator result is not an object");if(!e.done)return e;s=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(s=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?s:r.call(n,p))!==a)break}catch(e){i=t,c=1,s=e}finally{u=1}}return{value:e,done:f}}}(r,o,i),!0),u}var a={};function c(){}function s(){}function u(){}e=Object.getPrototypeOf;var l=[][n]?e(e([][n]())):(ft(e={},n,function(){return this}),e),f=u.prototype=c.prototype=Object.create(l);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,ft(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return s.prototype=u,ft(f,"constructor",u),ft(u,"constructor",s),s.displayName="GeneratorFunction",ft(u,o,"GeneratorFunction"),ft(f),ft(f,o,"Generator"),ft(f,n,function(){return this}),ft(f,"toString",function(){return"[object Generator]"}),(lt=function(){return{w:i,m:p}})()}function ft(t,e,r,n){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}ft=function(t,e,r,n){function i(e,r){ft(t,e,function(t){return this._invoke(e,r,t)})}e?o?o(t,e,{value:r,enumerable:!n,configurable:!n,writable:!n}):t[e]=r:(i("next",0),i("throw",1),i("return",2))},ft(t,e,r,n)}function pt(t,e,r,n,o,i,a){try{var c=t[i](a),s=c.value}catch(t){return void r(t)}c.done?e(s):Promise.resolve(s).then(n,o)}function dt(){return ht.apply(this,arguments)}function ht(){var t;return t=lt().m(function t(){return lt().w(function(t){for(;;)switch(t.n){case 0:return t.n=1,at("style-form");case 1:window.location.reload();case 2:return t.a(2)}},t)}),ht=function(){var e=this,r=arguments;return new Promise(function(n,o){var i=t.apply(e,r);function a(t){pt(i,n,o,a,c,"next",t)}function c(t){pt(i,n,o,a,c,"throw",t)}a(void 0)})},ht.apply(this,arguments)}var mt;mt=function(){var t,e;tt(),document.querySelectorAll(".frm-spotlight").forEach(function(t){setTimeout(function(){!function(t){var e=document.querySelector(t.dataset.target);e&&(document.body.append(t),function(t){for(var e=[window],r=t.parentElement;r&&document.body!==r;){var n=getComputedStyle(r),o=n.overflow,i=n.overflowY;(["auto","scroll"].includes(o)||["auto","scroll"].includes(i))&&e.push(r),r=r.parentElement}return e}(e).forEach(function(r){r.addEventListener("scroll",function(){et(t,e),function(t){var e=document.getElementById("frm_top_bar");if(e){var r=t.getBoundingClientRect().top+24<=e.getBoundingClientRect().bottom;r&&!t.classList.contains("frm-fadeout")?(t.classList.remove("frm-fadein"),t.classList.add("frm-fadeout")):r||t.classList.contains("frm-fadein")||(t.classList.remove("frm-fadeout"),t.classList.add("frm-fadein"))}}(t)},{passive:!0})}),window.addEventListener("resize",function(){return et(t,e)},{passive:!0}),setTimeout(function(){et(t,e),t.classList.remove("frm-force-hidden")},200))}(t)},0)}),(e=document.querySelector(".frm-welcome-tour .frm-checklist__progress-fill"))&&(e.style.width="".concat(Q,"%")),document.addEventListener("frm_added_field",function(){return at("add-fields")}),function(){var t=p().checklist;t&&t.querySelector(".frm-checklist__header").addEventListener("click",function(){return function(t){t.classList.toggle("frm-checklist--collapsed")}(t)})}(),(t=p().dismiss)&&t.addEventListener("click",ut),"formidable-styles"===H.get("page")&&K(document.getElementById("frm_submit_side_top"),dt)},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",mt):mt())})()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@tannin/compile/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/compile/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ compile) +/* harmony export */ }); +/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); +/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); + + + +/** + * Given a C expression, returns a function which can be called to evaluate its + * result. + * + * @example + * + * ```js + * import compile from '@tannin/compile'; + * + * const evaluate = compile( 'n > 1' ); + * + * evaluate( { n: 2 } ); + * // ⇒ true + * ``` + * + * @param {string} expression C expression. + * + * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. + */ +function compile( expression ) { + var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( variables ) { + return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/evaluate/index.js": +/*!************************************************!*\ + !*** ./node_modules/@tannin/evaluate/index.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ evaluate) +/* harmony export */ }); +/** + * Operator callback functions. + * + * @type {Object} + */ +var OPERATORS = { + '!': function( a ) { + return ! a; + }, + '*': function( a, b ) { + return a * b; + }, + '/': function( a, b ) { + return a / b; + }, + '%': function( a, b ) { + return a % b; + }, + '+': function( a, b ) { + return a + b; + }, + '-': function( a, b ) { + return a - b; + }, + '<': function( a, b ) { + return a < b; + }, + '<=': function( a, b ) { + return a <= b; + }, + '>': function( a, b ) { + return a > b; + }, + '>=': function( a, b ) { + return a >= b; + }, + '==': function( a, b ) { + return a === b; + }, + '!=': function( a, b ) { + return a !== b; + }, + '&&': function( a, b ) { + return a && b; + }, + '||': function( a, b ) { + return a || b; + }, + '?:': function( a, b, c ) { + if ( a ) { + throw b; + } + + return c; + }, +}; + +/** + * Given an array of postfix terms and operand variables, returns the result of + * the postfix evaluation. + * + * @example + * + * ```js + * import evaluate from '@tannin/evaluate'; + * + * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' + * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; + * + * evaluate( terms, {} ); + * // ⇒ 6.333333333333334 + * ``` + * + * @param {string[]} postfix Postfix terms. + * @param {Object} variables Operand variables. + * + * @return {*} Result of evaluation. + */ +function evaluate( postfix, variables ) { + var stack = [], + i, j, args, getOperatorResult, term, value; + + for ( i = 0; i < postfix.length; i++ ) { + term = postfix[ i ]; + + getOperatorResult = OPERATORS[ term ]; + if ( getOperatorResult ) { + // Pop from stack by number of function arguments. + j = getOperatorResult.length; + args = Array( j ); + while ( j-- ) { + args[ j ] = stack.pop(); + } + + try { + value = getOperatorResult.apply( null, args ); + } catch ( earlyReturn ) { + return earlyReturn; + } + } else if ( variables.hasOwnProperty( term ) ) { + value = variables[ term ]; + } else { + value = +term; + } + + stack.push( value ); + } + + return stack[ 0 ]; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/plural-forms/index.js": +/*!****************************************************!*\ + !*** ./node_modules/@tannin/plural-forms/index.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ pluralForms) +/* harmony export */ }); +/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); + + +/** + * Given a C expression, returns a function which, when called with a value, + * evaluates the result with the value assumed to be the "n" variable of the + * expression. The result will be coerced to its numeric equivalent. + * + * @param {string} expression C expression. + * + * @return {Function} Evaluator function. + */ +function pluralForms( expression ) { + var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); + + return function( n ) { + return +evaluate( { n: n } ); + }; +} + + +/***/ }), + +/***/ "./node_modules/@tannin/postfix/index.js": +/*!***********************************************!*\ + !*** ./node_modules/@tannin/postfix/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ postfix) +/* harmony export */ }); +var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; + +/** + * Operator precedence mapping. + * + * @type {Object} + */ +PRECEDENCE = { + '(': 9, + '!': 8, + '*': 7, + '/': 7, + '%': 7, + '+': 6, + '-': 6, + '<': 5, + '<=': 5, + '>': 5, + '>=': 5, + '==': 4, + '!=': 4, + '&&': 3, + '||': 2, + '?': 1, + '?:': 1, +}; + +/** + * Characters which signal pair opening, to be terminated by terminators. + * + * @type {string[]} + */ +OPENERS = [ '(', '?' ]; + +/** + * Characters which signal pair termination, the value an array with the + * opener as its first member. The second member is an optional operator + * replacement to push to the stack. + * + * @type {string[]} + */ +TERMINATORS = { + ')': [ '(' ], + ':': [ '?', '?:' ], +}; + +/** + * Pattern matching operators and openers. + * + * @type {RegExp} + */ +PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; + +/** + * Given a C expression, returns the equivalent postfix (Reverse Polish) + * notation terms as an array. + * + * If a postfix string is desired, simply `.join( ' ' )` the result. + * + * @example + * + * ```js + * import postfix from '@tannin/postfix'; + * + * postfix( 'n > 1' ); + * // ⇒ [ 'n', '1', '>' ] + * ``` + * + * @param {string} expression C expression. + * + * @return {string[]} Postfix terms. + */ +function postfix( expression ) { + var terms = [], + stack = [], + match, operator, term, element; + + while ( ( match = expression.match( PATTERN ) ) ) { + operator = match[ 0 ]; + + // Term is the string preceding the operator match. It may contain + // whitespace, and may be empty (if operator is at beginning). + term = expression.substr( 0, match.index ).trim(); + if ( term ) { + terms.push( term ); + } + + while ( ( element = stack.pop() ) ) { + if ( TERMINATORS[ operator ] ) { + if ( TERMINATORS[ operator ][ 0 ] === element ) { + // Substitution works here under assumption that because + // the assigned operator will no longer be a terminator, it + // will be pushed to the stack during the condition below. + operator = TERMINATORS[ operator ][ 1 ] || operator; + break; + } + } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { + // Push to stack if either an opener or when pop reveals an + // element of lower precedence. + stack.push( element ); + break; + } + + // For each popped from stack, push to terms. + terms.push( element ); + } + + if ( ! TERMINATORS[ operator ] ) { + stack.push( operator ); + } + + // Slice matched fragment from expression to continue match. + expression = expression.substr( match.index + operator.length ); + } + + // Push remainder of operand, if exists, to terms. + expression = expression.trim(); + if ( expression ) { + terms.push( expression ); + } + + // Pop remaining items from stack into terms. + return terms.concat( stack.reverse() ); +} + + +/***/ }), + +/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": +/*!*****************************************************************!*\ + !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ domReady) +/* harmony export */ }); +/** + * @typedef {() => void} Callback + * + * TODO: Remove this typedef and inline `() => void` type. + * + * This typedef is used so that a descriptive type is provided in our + * automatically generated documentation. + * + * An in-line type `() => void` would be preferable, but the generated + * documentation is `null` in that case. + * + * @see https://github.com/WordPress/gutenberg/issues/18045 + */ + +/** + * Specify a function to execute when the DOM is fully loaded. + * + * @param {Callback} callback A function to execute after the DOM is ready. + * + * @example + * ```js + * import domReady from '@wordpress/dom-ready'; + * + * domReady( function() { + * //do something after DOM loads. + * } ); + * ``` + * + * @return {void} + */ +function domReady(callback) { + if (typeof document === 'undefined') { + return; + } + + if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. + document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. + ) { + return void callback(); + } // DOMContentLoaded has not fired yet, delay callback until then. + + + document.addEventListener('DOMContentLoaded', callback); +} +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback AddHook + * + * Adds the hook to the appropriate hooks container. + * + * @param {string} hookName Name of hook to add + * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. + * @param {import('.').Callback} callback Function to call when the hook is run + * @param {number} [priority=10] Priority of this hook + */ + +/** + * Returns a function which, when invoked, will add a hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {AddHook} Function that adds a new hook. + */ + +function createAddHook(hooks, storeKey) { + return function addHook(hookName, namespace, callback) { + var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } + + if ('function' !== typeof callback) { + // eslint-disable-next-line no-console + console.error('The hook callback must be a function.'); + return; + } // Validate numeric priority + + + if ('number' !== typeof priority) { + // eslint-disable-next-line no-console + console.error('If specified, the hook priority must be a number.'); + return; + } + + var handler = { + callback: callback, + priority: priority, + namespace: namespace + }; + + if (hooksStore[hookName]) { + // Find the correct insert index of the new hook. + var handlers = hooksStore[hookName].handlers; + /** @type {number} */ + + var i; + + for (i = handlers.length; i > 0; i--) { + if (priority >= handlers[i - 1].priority) { + break; + } + } + + if (i === handlers.length) { + // If append, operate via direct assignment. + handlers[i] = handler; + } else { + // Otherwise, insert before index via splice. + handlers.splice(i, 0, handler); + } // We may also be currently executing this hook. If the callback + // we're adding would come after the current callback, there's no + // problem; otherwise we need to increase the execution index of + // any other runs by 1 to account for the added element. + + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex++; + } + }); + } else { + // This is the first hook of its type. + hooksStore[hookName] = { + handlers: [handler], + runs: 0 + }; + } + + if (hookName !== 'hookAdded') { + hooks.doAction('hookAdded', hookName, namespace, callback, priority); + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); +//# sourceMappingURL=createAddHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Returns a function which, when invoked, will return the name of the + * currently running hook, or `null` if no hook of the given type is currently + * running. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {() => string | null} Function that returns the current hook name or null. + */ +function createCurrentHook(hooks, storeKey) { + return function currentHook() { + var _hooksStore$__current, _hooksStore$__current2; + + var hooksStore = hooks[storeKey]; + return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); +//# sourceMappingURL=createCurrentHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + +/** + * @callback DidHook + * + * Returns the number of times an action has been fired. + * + * @param {string} hookName The hook name to check. + * + * @return {number | undefined} The number of times the hook has run. + */ + +/** + * Returns a function which, when invoked, will return the number of times a + * hook has been called. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DidHook} Function that returns a hook's call count. + */ + +function createDidHook(hooks, storeKey) { + return function didHook(hookName) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { + return; + } + + return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); +//# sourceMappingURL=createDidHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": +/*!***********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! + \***********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback DoingHook + * Returns whether a hook is currently being executed. + * + * @param {string} [hookName] The name of the hook to check for. If + * omitted, will check for any hook being executed. + * + * @return {boolean} Whether the hook is being executed. + */ + +/** + * Returns a function which, when invoked, will return whether a hook is + * currently being executed. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {DoingHook} Function that returns whether a hook is currently + * being executed. + */ +function createDoingHook(hooks, storeKey) { + return function doingHook(hookName) { + var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. + + if ('undefined' === typeof hookName) { + return 'undefined' !== typeof hooksStore.__current[0]; + } // Return the __current hook. + + + return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); +//# sourceMappingURL=createDoingHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * @callback HasHook + * + * Returns whether any handlers are attached for the given hookName and optional namespace. + * + * @param {string} hookName The name of the hook to check for. + * @param {string} [namespace] Optional. The unique namespace identifying the callback + * in the form `vendor/plugin/function`. + * + * @return {boolean} Whether there are handlers that are attached to the given hook. + */ + +/** + * Returns a function which, when invoked, will return whether any handlers are + * attached to a particular hook. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * + * @return {HasHook} Function that returns whether any handlers are + * attached to a particular hook and optional namespace. + */ +function createHasHook(hooks, storeKey) { + return function hasHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; // Use the namespace if provided. + + if ('undefined' !== typeof namespace) { + return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { + return hook.namespace === namespace; + }); + } + + return hookName in hooksStore; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); +//# sourceMappingURL=createHasHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ _Hooks: () => (/* binding */ _Hooks), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); +/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); +/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); +/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); +/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); +/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); +/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); +/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); + + +/** + * Internal dependencies + */ + + + + + + + +/** + * Internal class for constructing hooks. Use `createHooks()` function + * + * Note, it is necessary to expose this class to make its type public. + * + * @private + */ + +var _Hooks = function _Hooks() { + (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); + + /** @type {import('.').Store} actions */ + this.actions = Object.create(null); + this.actions.__current = []; + /** @type {import('.').Store} filters */ + + this.filters = Object.create(null); + this.filters.__current = []; + this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); + this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); + this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); + this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); + this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); + this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); + this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); + this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); + this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); + this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); + this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); + this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); + this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); + this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); + this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); + this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); +}; +/** @typedef {_Hooks} Hooks */ + +/** + * Returns an instance of the hooks object. + * + * @return {Hooks} A Hooks instance. + */ + +function createHooks() { + return new _Hooks(); +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); +//# sourceMappingURL=createHooks.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); +/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); +/** + * Internal dependencies + */ + + +/** + * @callback RemoveHook + * Removes the specified callback (or all callbacks) from the hook with a given hookName + * and namespace. + * + * @param {string} hookName The name of the hook to modify. + * @param {string} namespace The unique namespace identifying the callback in the + * form `vendor/plugin/function`. + * + * @return {number | undefined} The number of callbacks removed. + */ + +/** + * Returns a function which, when invoked, will remove a specified hook or all + * hooks by the given name. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, + * without regard to namespace. Used to create + * `removeAll*` functions. + * + * @return {RemoveHook} Function that removes hooks. + */ + +function createRemoveHook(hooks, storeKey) { + var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function removeHook(hookName, namespace) { + var hooksStore = hooks[storeKey]; + + if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { + return; + } + + if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { + return; + } // Bail if no hooks exist by this name + + + if (!hooksStore[hookName]) { + return 0; + } + + var handlersRemoved = 0; + + if (removeAll) { + handlersRemoved = hooksStore[hookName].handlers.length; + hooksStore[hookName] = { + runs: hooksStore[hookName].runs, + handlers: [] + }; + } else { + // Try to find the specified callback to remove. + var handlers = hooksStore[hookName].handlers; + + var _loop = function _loop(i) { + if (handlers[i].namespace === namespace) { + handlers.splice(i, 1); + handlersRemoved++; // This callback may also be part of a hook that is + // currently executing. If the callback we're removing + // comes after the current callback, there's no problem; + // otherwise we need to decrease the execution index of any + // other runs by 1 to account for the removed element. + + hooksStore.__current.forEach(function (hookInfo) { + if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { + hookInfo.currentIndex--; + } + }); + } + }; + + for (var i = handlers.length - 1; i >= 0; i--) { + _loop(i); + } + } + + if (hookName !== 'hookRemoved') { + hooks.doAction('hookRemoved', hookName, namespace); + } + + return handlersRemoved; + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); +//# sourceMappingURL=createRemoveHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); + + +/** + * Returns a function which, when invoked, will execute all callbacks + * registered to a hook of the specified type, optionally returning the final + * value of the call chain. + * + * @param {import('.').Hooks} hooks Hooks instance. + * @param {import('.').StoreKey} storeKey + * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to + * return its first argument. + * + * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. + */ +function createRunHook(hooks, storeKey) { + var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; + return function runHooks(hookName) { + var hooksStore = hooks[storeKey]; + + if (!hooksStore[hookName]) { + hooksStore[hookName] = { + handlers: [], + runs: 0 + }; + } + + hooksStore[hookName].runs++; + var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. + + if (true) { + // Handle any 'all' hooks registered. + if ('hookAdded' !== hookName && hooksStore.all) { + handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); + } + } + + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + if (!handlers || !handlers.length) { + return returnFirstArg ? args[0] : undefined; + } + + var hookInfo = { + name: hookName, + currentIndex: 0 + }; + + hooksStore.__current.push(hookInfo); + + while (hookInfo.currentIndex < handlers.length) { + var handler = handlers[hookInfo.currentIndex]; + var result = handler.callback.apply(null, args); + + if (returnFirstArg) { + args[0] = result; + } + + hookInfo.currentIndex++; + } + + hooksStore.__current.pop(); + + if (returnFirstArg) { + return args[0]; + } + }; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); +//# sourceMappingURL=createRunHook.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/index.js": +/*!*************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! + \*************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ actions: () => (/* binding */ actions), +/* harmony export */ addAction: () => (/* binding */ addAction), +/* harmony export */ addFilter: () => (/* binding */ addFilter), +/* harmony export */ applyFilters: () => (/* binding */ applyFilters), +/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ currentAction: () => (/* binding */ currentAction), +/* harmony export */ currentFilter: () => (/* binding */ currentFilter), +/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), +/* harmony export */ didAction: () => (/* binding */ didAction), +/* harmony export */ didFilter: () => (/* binding */ didFilter), +/* harmony export */ doAction: () => (/* binding */ doAction), +/* harmony export */ doingAction: () => (/* binding */ doingAction), +/* harmony export */ doingFilter: () => (/* binding */ doingFilter), +/* harmony export */ filters: () => (/* binding */ filters), +/* harmony export */ hasAction: () => (/* binding */ hasAction), +/* harmony export */ hasFilter: () => (/* binding */ hasFilter), +/* harmony export */ removeAction: () => (/* binding */ removeAction), +/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), +/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), +/* harmony export */ removeFilter: () => (/* binding */ removeFilter) +/* harmony export */ }); +/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); +/** + * Internal dependencies + */ + +/** @typedef {(...args: any[])=>any} Callback */ + +/** + * @typedef Handler + * @property {Callback} callback The callback + * @property {string} namespace The namespace + * @property {number} priority The namespace + */ + +/** + * @typedef Hook + * @property {Handler[]} handlers Array of handlers + * @property {number} runs Run counter + */ + +/** + * @typedef Current + * @property {string} name Hook name + * @property {number} currentIndex The index + */ + +/** + * @typedef {Record & {__current: Current[]}} Store + */ + +/** + * @typedef {'actions' | 'filters'} StoreKey + */ + +/** + * @typedef {import('./createHooks').Hooks} Hooks + */ + +var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); +var addAction = defaultHooks.addAction, + addFilter = defaultHooks.addFilter, + removeAction = defaultHooks.removeAction, + removeFilter = defaultHooks.removeFilter, + hasAction = defaultHooks.hasAction, + hasFilter = defaultHooks.hasFilter, + removeAllActions = defaultHooks.removeAllActions, + removeAllFilters = defaultHooks.removeAllFilters, + doAction = defaultHooks.doAction, + applyFilters = defaultHooks.applyFilters, + currentAction = defaultHooks.currentAction, + currentFilter = defaultHooks.currentFilter, + doingAction = defaultHooks.doingAction, + doingFilter = defaultHooks.doingFilter, + didAction = defaultHooks.didAction, + didFilter = defaultHooks.didFilter, + actions = defaultHooks.actions, + filters = defaultHooks.filters; + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": +/*!************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! + \************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a hookName string. + * + * @param {string} hookName The hook name to validate. Should be a non empty string containing + * only numbers, letters, dashes, periods and underscores. Also, + * the hook name cannot begin with `__`. + * + * @return {boolean} Whether the hook name is valid. + */ +function validateHookName(hookName) { + if ('string' !== typeof hookName || '' === hookName) { + // eslint-disable-next-line no-console + console.error('The hook name must be a non-empty string.'); + return false; + } + + if (/^__/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name cannot begin with `__`.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { + // eslint-disable-next-line no-console + console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); +//# sourceMappingURL=validateHookName.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Validate a namespace string. + * + * @param {string} namespace The namespace to validate - should take the form + * `vendor/plugin/function`. + * + * @return {boolean} Whether the namespace is valid. + */ +function validateNamespace(namespace) { + if ('string' !== typeof namespace || '' === namespace) { + // eslint-disable-next-line no-console + console.error('The namespace must be a non-empty string.'); + return false; + } + + if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { + // eslint-disable-next-line no-console + console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); + return false; + } + + return true; +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); +//# sourceMappingURL=validateNamespace.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": +/*!******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! + \******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createI18n: () => (/* binding */ createI18n) +/* harmony export */ }); +/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); +/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * External dependencies + */ + +/** + * @typedef {Record} LocaleData + */ + +/** + * Default locale data to use for Tannin domain when not otherwise provided. + * Assumes an English plural forms expression. + * + * @type {LocaleData} + */ + +var DEFAULT_LOCALE_DATA = { + '': { + /** @param {number} n */ + plural_forms: function plural_forms(n) { + return n === 1 ? 0 : 1; + } + } +}; +/* + * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, + * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. + */ + +var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; +/** + * @typedef {(domain?: string) => LocaleData} GetLocaleData + * + * Returns locale data by domain in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData + * + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** + * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData + * + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + */ + +/** @typedef {() => void} SubscribeCallback */ + +/** @typedef {() => void} UnsubscribeCallback */ + +/** + * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe + * + * Subscribes to changes of locale data + */ + +/** + * @typedef {(domain?: string) => string} GetFilterDomain + * Retrieve the domain to use when calling domain-specific filters. + */ + +/** + * @typedef {(text: string, domain?: string) => string} __ + * + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + */ + +/** + * @typedef {(text: string, context: string, domain?: string) => string} _x + * + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n + * + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + */ + +/** + * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx + * + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + */ + +/** + * @typedef {() => boolean} IsRtl + * + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + */ + +/** + * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation + * + * Check if there is a translation for a given string in singular form. + */ + +/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ + +/** + * An i18n instance + * + * @typedef I18n + * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. + * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. + * @property {__} __ Retrieve the translation of text. + * @property {_x} _x Retrieve translated string with gettext context. + * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied + * number. + * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * @property {IsRtl} isRTL Check if current locale is RTL. + * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. + */ + +/** + * Create an i18n instance + * + * @param {LocaleData} [initialData] Locale data configuration. + * @param {string} [initialDomain] Domain for which configuration applies. + * @param {Hooks} [hooks] Hooks implementation. + * @return {I18n} I18n instance + */ + +var createI18n = function createI18n(initialData, initialDomain, hooks) { + /** + * The underlying instance of Tannin to which exported functions interface. + * + * @type {Tannin} + */ + var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); + var listeners = new Set(); + + var notifyListeners = function notifyListeners() { + listeners.forEach(function (listener) { + return listener(); + }); + }; + /** + * Subscribe to changes of locale data. + * + * @param {SubscribeCallback} callback Subscription callback. + * @return {UnsubscribeCallback} Unsubscribe callback. + */ + + + var subscribe = function subscribe(callback) { + listeners.add(callback); + return function () { + return listeners.delete(callback); + }; + }; + /** @type {GetLocaleData} */ + + + var getLocaleData = function getLocaleData() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return tannin.data[domain]; + }; + /** + * @param {LocaleData} [data] + * @param {string} [domain] + */ + + + var doSetLocaleData = function doSetLocaleData(data) { + var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits + // a plural forms expression). + + tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); + }; + /** @type {SetLocaleData} */ + + + var setLocaleData = function setLocaleData(data, domain) { + doSetLocaleData(data, domain); + notifyListeners(); + }; + /** @type {ResetLocaleData} */ + + + var resetLocaleData = function resetLocaleData(data, domain) { + // Reset all current Tannin locale data. + tannin.data = {}; // Reset cached plural forms functions cache. + + tannin.pluralForms = {}; + setLocaleData(data, domain); + }; + /** + * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not + * otherwise previously assigned. + * + * @param {string|undefined} domain Domain to retrieve the translated text. + * @param {string|undefined} context Context information for the translators. + * @param {string} single Text to translate if non-plural. Used as + * fallback return value on a caught error. + * @param {string} [plural] The text to be used if the number is + * plural. + * @param {number} [number] The number to compare against to use + * either the singular or plural form. + * + * @return {string} The translated string. + */ + + + var dcnpgettext = function dcnpgettext() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + var context = arguments.length > 1 ? arguments[1] : undefined; + var single = arguments.length > 2 ? arguments[2] : undefined; + var plural = arguments.length > 3 ? arguments[3] : undefined; + var number = arguments.length > 4 ? arguments[4] : undefined; + + if (!tannin.data[domain]) { + // use `doSetLocaleData` to set silently, without notifying listeners + doSetLocaleData(undefined, domain); + } + + return tannin.dcnpgettext(domain, context, single, plural, number); + }; + /** @type {GetFilterDomain} */ + + + var getFilterDomain = function getFilterDomain() { + var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; + return domain; + }; + /** @type {__} */ + + + var __ = function __(text, domain) { + var translation = dcnpgettext(domain, undefined, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext', translation, text, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) + ); + }; + /** @type {_x} */ + + + var _x = function _x(text, context, domain) { + var translation = dcnpgettext(domain, context, text); + + if (!hooks) { + return translation; + } + /** + * Filters text with its translation based on context information. + * + * @param {string} translation Translated text. + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) + ); + }; + /** @type {_n} */ + + + var _n = function _n(single, plural, number, domain) { + var translation = dcnpgettext(domain, undefined, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) + ); + }; + /** @type {_nx} */ + + + var _nx = function _nx(single, plural, number, context, domain) { + var translation = dcnpgettext(domain, context, single, plural, number); + + if (!hooks) { + return translation; + } + /** + * Filters the singular or plural form of a string with gettext context. + * + * @param {string} translation Translated text. + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {string} number The number to compare against to use either the singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + + + translation = + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); + return ( + /** @type {string} */ + + /** @type {*} */ + hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) + ); + }; + /** @type {IsRtl} */ + + + var isRTL = function isRTL() { + return 'rtl' === _x('ltr', 'text direction'); + }; + /** @type {HasTranslation} */ + + + var hasTranslation = function hasTranslation(single, context, domain) { + var _tannin$data, _tannin$data2; + + var key = context ? context + "\x04" + single : single; + var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); + + if (hooks) { + /** + * Filters the presence of a translation in the locale data. + * + * @param {boolean} hasTranslation Whether the translation is present or not.. + * @param {string} single The singular form of the translated text (used as key in locale data) + * @param {string} context Context information for the translators. + * @param {string} domain Text domain. Unique identifier for retrieving translated strings. + */ + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation', result, single, context, domain); + result = + /** @type { boolean } */ + + /** @type {*} */ + hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); + } + + return result; + }; + + if (initialData) { + setLocaleData(initialData, initialDomain); + } + + if (hooks) { + /** + * @param {string} hookName + */ + var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { + if (I18N_HOOK_REGEXP.test(hookName)) { + notifyListeners(); + } + }; + + hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); + hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); + } + + return { + getLocaleData: getLocaleData, + setLocaleData: setLocaleData, + resetLocaleData: resetLocaleData, + subscribe: subscribe, + __: __, + _x: _x, + _n: _n, + _nx: _nx, + isRTL: isRTL, + hasTranslation: hasTranslation + }; +}; +//# sourceMappingURL=create-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* binding */ __), +/* harmony export */ _n: () => (/* binding */ _n), +/* harmony export */ _nx: () => (/* binding */ _nx), +/* harmony export */ _x: () => (/* binding */ _x), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), +/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), +/* harmony export */ isRTL: () => (/* binding */ isRTL), +/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), +/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), +/* harmony export */ subscribe: () => (/* binding */ subscribe) +/* harmony export */ }); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); +/** + * Internal dependencies + */ + +/** + * WordPress dependencies + */ + + +var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); +/** + * Default, singleton instance of `I18n`. + */ + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); +/* + * Comments in this file are duplicated from ./i18n due to + * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 + */ + +/** + * @typedef {import('./create-i18n').LocaleData} LocaleData + * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback + * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback + */ + +/** + * Returns locale data by domain in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {string} [domain] Domain for which to get the data. + * @return {LocaleData} Locale data. + */ + +var getLocaleData = i18n.getLocaleData.bind(i18n); +/** + * Merges locale data into the Tannin instance by domain. Accepts data in a + * Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var setLocaleData = i18n.setLocaleData.bind(i18n); +/** + * Resets all current Tannin instance locale data and sets the specified + * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. + * + * @see http://messageformat.github.io/Jed/ + * + * @param {LocaleData} [data] Locale data configuration. + * @param {string} [domain] Domain for which configuration applies. + */ + +var resetLocaleData = i18n.resetLocaleData.bind(i18n); +/** + * Subscribes to changes of locale data + * + * @param {SubscribeCallback} callback Subscription callback + * @return {UnsubscribeCallback} Unsubscribe callback + */ + +var subscribe = i18n.subscribe.bind(i18n); +/** + * Retrieve the translation of text. + * + * @see https://developer.wordpress.org/reference/functions/__/ + * + * @param {string} text Text to translate. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated text. + */ + +var __ = i18n.__.bind(i18n); +/** + * Retrieve translated string with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_x/ + * + * @param {string} text Text to translate. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} Translated context string without pipe. + */ + +var _x = i18n._x.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number. + * + * @see https://developer.wordpress.org/reference/functions/_n/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _n = i18n._n.bind(i18n); +/** + * Translates and retrieves the singular or plural form based on the supplied + * number, with gettext context. + * + * @see https://developer.wordpress.org/reference/functions/_nx/ + * + * @param {string} single The text to be used if the number is singular. + * @param {string} plural The text to be used if the number is plural. + * @param {number} number The number to compare against to use either the + * singular or plural form. + * @param {string} context Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * + * @return {string} The translated singular or plural form. + */ + +var _nx = i18n._nx.bind(i18n); +/** + * Check if current locale is RTL. + * + * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. + * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common + * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, + * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). + * + * @return {boolean} Whether locale is RTL. + */ + +var isRTL = i18n.isRTL.bind(i18n); +/** + * Check if there is a translation for a given string (in singular form). + * + * @param {string} single Singular form of the string to look up. + * @param {string} [context] Context information for the translators. + * @param {string} [domain] Domain to retrieve the translated text. + * @return {boolean} Whether the translation exists or not. + */ + +var hasTranslation = i18n.hasTranslation.bind(i18n); +//# sourceMappingURL=default-i18n.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/index.js": +/*!************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! + \************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), +/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), +/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), +/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), +/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), +/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), +/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), +/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), +/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), +/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), +/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), +/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) +/* harmony export */ }); +/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); +/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); +/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": +/*!**************************************************************!*\ + !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! + \**************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ sprintf: () => (/* binding */ sprintf) +/* harmony export */ }); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); +/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); +/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); +/** + * External dependencies + */ + + +/** + * Log to console, once per message; or more precisely, per referentially equal + * argument set. Because Jed throws errors, we log these to the console instead + * to avoid crashing the application. + * + * @param {...*} args Arguments to pass to `console.error` + */ + +var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console + +/** + * Returns a formatted string. If an error occurs in applying the format, the + * original format string is returned. + * + * @param {string} format The format of the string to generate. + * @param {...*} args Arguments to apply to the format. + * + * @see https://www.npmjs.com/package/sprintf-js + * + * @return {string} The formatted string. + */ + +function sprintf(format) { + try { + for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + args[_key - 1] = arguments[_key]; + } + + return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); + } catch (error) { + logErrorOnce('sprintf error: \n\n' + error.toString()); + return format; + } +} +//# sourceMappingURL=sprintf.js.map + +/***/ }), + +/***/ "./js/src/core/constants.js": +/*!**********************************!*\ + !*** ./js/src/core/constants.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), +/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), +/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), +/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), +/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), +/* harmony export */ HOOKS: () => (/* binding */ HOOKS), +/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), +/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), +/* harmony export */ nonce: () => (/* binding */ nonce) +/* harmony export */ }); +var _window$frmGlobal = window.frmGlobal, + PLUGIN_URL = _window$frmGlobal.url, + nonce = _window$frmGlobal.nonce; + +var HIDDEN_CLASS = 'frm_hidden'; +var DISABLED_CLASS = 'frm_disabled'; +var HIDE_JS_CLASS = 'frm-hide-js'; +var CURRENT_CLASS = 'frm-current'; +var CHECKED_CLASS = 'frm-checked'; +var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; +var HOOKS = { + SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' +}; + +/***/ }), + +/***/ "./js/src/core/factory/createPageElements.js": +/*!***************************************************!*\ + !*** ./js/src/core/factory/createPageElements.js ***! + \***************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* binding */ createPageElements) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page elements manager. + * + * @param {Object} [initialElements={}] An object containing initial DOM elements. + * @throws {Error} Throws an error if the `initialElements` is not an object. + * @return {Object} An object with methods to get and add elements. + */ +function createPageElements() { + var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialElements) !== 'object' || initialElements === null) { + throw new Error('createPageElements: initialElements must be a non-null object'); + } + var elements = initialElements; + + /** + * Retrieve the initialized essential DOM elements. + * + * @return {Object} The initialized elements object. + */ + function getElements() { + return elements; + } + + /** + * Add new elements to the elements object. + * + * @param {Object} newElements An object containing new elements to be added. + * @throws {Error} Throws an error if the `newElements` is not a non-null object. + * @return {void} Updates the elements object by merging the new elements into it. + */ + function addElements(newElements) { + if (_typeof(newElements) !== 'object' || newElements === null) { + throw new Error('addElements: newElements must be a non-null object'); + } + elements = _objectSpread(_objectSpread({}, elements), newElements); + } + return { + getElements: getElements, + addElements: addElements + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/createPageState.js": +/*!************************************************!*\ + !*** ./js/src/core/factory/createPageState.js ***! + \************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageState: () => (/* binding */ createPageState) +/* harmony export */ }); +function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } +function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +/** + * Creates a page state manager. + * + * @param {Object} [initialState={}] An object containing the initial state. + * @throws {Error} Throws an error if the `initialState` is not a plain object. + * @return {Object} An object with methods to initialize, get, and set the page state. + */ +function createPageState() { + var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (_typeof(initialState) !== 'object' || initialState === null) { + throw new Error('createPageState: initialState must be a non-null object'); + } + var state = initialState; + + /** + * Returns the current page state. + * + * @return {Object|null} The current state of the page or null if not initialized. + */ + var getState = function getState() { + return state; + }; + + /** + * Returns a specific property from the current page state. + * + * @param {string} propertyName The name of the property to retrieve. + * @return {*} The value of the specified property, or null if it doesn't exist. + */ + var getSingleState = function getSingleState(propertyName) { + var value = Reflect.get(state, propertyName); + + // We convert `undefined` to `null` for a consistent API. + // This makes it easier for users to handle the results since all missing properties return `null`. + return value === undefined ? null : value; + }; + + /** + * Updates the page state with new values. + * + * @param {Object} newState The new values to update the state with. + * @throws {Error} Throws an error if `newState` is not a plain object. + * @return {void} + */ + var setState = function setState(newState) { + if (_typeof(newState) !== 'object' || newState === null) { + throw new Error('setState: newState must be a non-null object'); + } + state = _objectSpread(_objectSpread({}, state), newState); + }; + + /** + * Updates a specific property in the page state with a new value. + * + * @param {string} propertyName The name of the property to update. + * @param {*} value The new value to set for the property. + * @return {void} + */ + var setSingleState = function setSingleState(propertyName, value) { + if (Reflect.has(state, propertyName)) { + Reflect.set(state, propertyName, value); + } + }; + return { + getState: getState, + getSingleState: getSingleState, + setState: setState, + setSingleState: setSingleState + }; +} + +/***/ }), + +/***/ "./js/src/core/factory/index.js": +/*!**************************************!*\ + !*** ./js/src/core/factory/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), +/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) +/* harmony export */ }); +/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); +/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); + + + +/***/ }), + +/***/ "./js/src/core/utils/animation.js": +/*!****************************************!*\ + !*** ./js/src/core/utils/animation.js ***! + \****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } +function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } +function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +var frmAnimate = /*#__PURE__*/function () { + /** + * Construct frmAnimate + * + * @param {Element|Element[]} elements The elements to animate. + * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d + */ + function frmAnimate(elements) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; + _classCallCheck(this, frmAnimate); + this.elements = elements; + this.type = type; + this.prepareElements(); + } + + /** + * Init animation - fadeIn. + * Requires this.type = 'default'; + * ex: new frmAnimate( elements ).fadeIn(); + */ + return _createClass(frmAnimate, [{ + key: "fadeIn", + value: function fadeIn() { + var _this = this; + this.applyStyleToElements(function (element) { + element.classList.add('frm-fadein-up'); + element.addEventListener('animationend', function () { + _this.resetOpacity(); + element.classList.remove('frm-fadein-up'); + }, { + once: true + }); + }); + } + + /** + * Init animation - cascadeFadeIn. + * Requires this.type = 'cascade'|'cascade-3d'; + * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); + * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); + * + * @param {number} delay The transition delay value. + */ + }, { + key: "cascadeFadeIn", + value: function cascadeFadeIn() { + var _this2 = this; + var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; + setTimeout(function () { + _this2.applyStyleToElements(function (element, index) { + element.classList.remove('frm-animate'); + element.style.transitionDelay = "".concat((index + 1) * delay, "s"); + }); + }, 200); + } + }, { + key: "prepareElements", + value: function prepareElements() { + var _this3 = this; + this.applyStyleToElements(function (element) { + if ('default' === _this3.type) { + element.style.opacity = '0.0'; + } + if ('cascade' === _this3.type) { + element.classList.add('frm-init-cascade-animation'); + } + if ('cascade-3d' === _this3.type) { + element.classList.add('frm-init-fadein-3d'); + } + element.classList.add('frm-animate'); + }); + } + }, { + key: "resetOpacity", + value: function resetOpacity() { + this.applyStyleToElements(function (element) { + return element.style.opacity = '1.0'; + }); + } + }, { + key: "applyStyleToElements", + value: function applyStyleToElements(callback) { + if (this.elements instanceof Element) { + callback(this.elements, 0); + return; + } + if (0 < this.elements.length) { + this.elements.forEach(function (element, index) { + return callback(element, index); + }); + } + } + }]); +}(); + +/***/ }), + +/***/ "./js/src/core/utils/async.js": +/*!************************************!*\ + !*** ./js/src/core/utils/async.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) +/* harmony export */ }); +// Initialize lastPromise with a resolved promise as the starting point for the queue +var lastPromise = Promise.resolve(); + +/** + * Adds a task to the request queue. + * + * @param {function(): Promise} task A function that returns a promise. + * @return {Promise} The new last promise in the queue. + */ +var addToRequestQueue = function addToRequestQueue(task) { + return lastPromise = lastPromise.then(task).catch(task); +}; + +/***/ }), + +/***/ "./js/src/core/utils/error.js": +/*!************************************!*\ + !*** ./js/src/core/utils/error.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ showFormError: () => (/* binding */ showFormError) +/* harmony export */ }); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); +/** + * Internal dependencies + */ + + +/** + * Displays form validation error messages. + * + * @param {string} inputId The ID selector for the input field with the error. + * @param {string} errorId The ID selector for the error message display element. + * @param {string} type The categorization of the error (e.g., "invalid", "empty"). + * @param {string} [message] Optional. The specific error message to display. + * @return {void} + */ +var showFormError = function showFormError(inputId, errorId, type, message) { + var inputElement = document.querySelector(inputId); + var errorElement = document.querySelector(errorId); + if (!inputElement || !errorElement) { + console.warn('showFormError: Unable to find input or error element.'); + return; + } + + // If a message is provided, update the span element's text that matches the error type + if (message) { + var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); + if (span) { + span.textContent = message; + } + } + + // Assign the error type and make the error message visible + errorElement.setAttribute('frm-error', type); + (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); + + // Hide the error message when the user starts typing in the faulty input field + inputElement.addEventListener('keyup', function () { + (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); + }, { + once: true + }); +}; + +/***/ }), + +/***/ "./js/src/core/utils/globalModules.js": +/*!********************************************!*\ + !*** ./js/src/core/utils/globalModules.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* binding */ a), +/* harmony export */ bold: () => (/* binding */ bold), +/* harmony export */ button: () => (/* binding */ button), +/* harmony export */ div: () => (/* binding */ div), +/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), +/* harmony export */ documentOn: () => (/* binding */ documentOn), +/* harmony export */ footerButton: () => (/* binding */ footerButton), +/* harmony export */ img: () => (/* binding */ img), +/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), +/* harmony export */ p: () => (/* binding */ p), +/* harmony export */ span: () => (/* binding */ span), +/* harmony export */ svg: () => (/* binding */ svg), +/* harmony export */ tag: () => (/* binding */ tag) +/* harmony export */ }); +var _frmDom = frmDom, + div = _frmDom.div, + span = _frmDom.span, + tag = _frmDom.tag, + a = _frmDom.a, + img = _frmDom.img, + svg = _frmDom.svg; +var _frmDom$modal = frmDom.modal, + maybeCreateModal = _frmDom$modal.maybeCreateModal, + footerButton = _frmDom$modal.footerButton; +var _frmDom$util = frmDom.util, + onClickPreventDefault = _frmDom$util.onClickPreventDefault, + documentOn = _frmDom$util.documentOn; +var doJsonPost = frmDom.ajax.doJsonPost; +var p = function p(args) { + return tag('p', args); +}; +var bold = function bold(args) { + return tag('strong', args); +}; +var button = function button(args) { + return tag('button', args); +}; + + +/***/ }), + +/***/ "./js/src/core/utils/index.js": +/*!************************************!*\ + !*** ./js/src/core/utils/index.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), +/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), +/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), +/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), +/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), +/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), +/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), +/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), +/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), +/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), +/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), +/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), +/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), +/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), +/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), +/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), +/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), +/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), +/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), +/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), +/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), +/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), +/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), +/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), +/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), +/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), +/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), +/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) +/* harmony export */ }); +/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); +/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); +/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); +/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); +/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); +/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); +/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); + + + + + + + + +/***/ }), + +/***/ "./js/src/core/utils/url.js": +/*!**********************************!*\ + !*** ./js/src/core/utils/url.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), +/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), +/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), +/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), +/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) +/* harmony export */ }); +function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } +function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } +function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } +function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } +/** + * Initializes URL and URLSearchParams objects from the current window's location + */ +var url = new URL(window.location.href); +var urlParams = url.searchParams; + +/** + * Gets the value of a specified query parameter from the current URL. + * + * @param {string} paramName The name of the query parameter to retrieve. + * @return {string|null} The value associated with the specified query parameter name, or null if not found. + */ +var getQueryParam = function getQueryParam(paramName) { + return urlParams.get(paramName); +}; + +/** + * Removes a query parameter from the current URL and returns the updated URL string. + * + * @param {string} paramName The name of the query parameter to remove. + * @return {string} The updated URL string. + */ +var removeQueryParam = function removeQueryParam(paramName) { + urlParams.delete(paramName); + url.search = urlParams.toString(); + return url.toString(); +}; + +/** + * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. + * + * @param {string} paramName The name of the query parameter to set. + * @param {string} paramValue The value to set for the query parameter. + * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. + * @return {string} The updated URL string. + */ +var setQueryParam = function setQueryParam(paramName, paramValue) { + var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; + urlParams.set(paramName, paramValue); + url.search = urlParams.toString(); + if (['pushState', 'replaceState'].includes(updateMethod)) { + var state = _defineProperty({}, paramName, paramValue); + window.history[updateMethod](state, '', url); + } + return url.toString(); +}; + +/** + * Checks if a query parameter exists in the current URL. + * + * @param {string} paramName The name of the query parameter to check. + * @return {boolean} True if the query parameter exists, otherwise false. + */ +var hasQueryParam = function hasQueryParam(paramName) { + return urlParams.has(paramName); +}; + +/** + * Removes a query parameter and updates history with replaceState. + * + * @param {string} paramName The query parameter to remove. + * @return {void} + */ +var removeParamFromHistory = function removeParamFromHistory(paramName) { + return history.replaceState({}, '', removeQueryParam(paramName)); +}; + +/***/ }), + +/***/ "./js/src/core/utils/validation.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/validation.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), +/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), +/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) +/* harmony export */ }); +/** + * Validates an email address using a regular expression. + * + * @param {string} email The email address to validate. + * @return {boolean} True if the email address is valid, otherwise false. + */ +var isValidEmail = function isValidEmail(email) { + return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; +}; + +/** + * Validates if the given element is an instance of HTMLElement. + * + * @param {any} element Element to be checked. + * @return {boolean} True if it's an HTMLElement, otherwise false. + */ +var isHTMLElement = function isHTMLElement(element) { + return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; +}; + +/** + * Checks if the given object is empty. + * + * @param {Object} obj The object to check. + * @return {boolean} True if the object is empty, otherwise false. + */ +var isEmptyObject = function isEmptyObject(obj) { + return Object.keys(obj).length === 0 && obj.constructor === Object; +}; + +/***/ }), + +/***/ "./js/src/core/utils/visibility.js": +/*!*****************************************!*\ + !*** ./js/src/core/utils/visibility.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ hide: () => (/* binding */ hide), +/* harmony export */ hideElements: () => (/* binding */ hideElements), +/* harmony export */ isVisible: () => (/* binding */ isVisible), +/* harmony export */ show: () => (/* binding */ show), +/* harmony export */ showElements: () => (/* binding */ showElements) +/* harmony export */ }); +/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); +/** + * Internal dependencies + */ + + +/** + * Shows specified elements by removing the hidden class. + * + * @param {Array} elements An array of elements to show. + * @return {void} + */ +var showElements = function showElements(elements) { + var _Array$from; + return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { + return show(element); + }); +}; + +/** + * Hides specified elements by adding the hidden class. + * + * @param {Array} elements An array of elements to hide. + * @return {void} + */ +var hideElements = function hideElements(elements) { + var _Array$from2; + return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { + return hide(element); + }); +}; + +/** + * Removes the hidden class to show the element. + * + * @param {Element} element The element to show. + * @return {void} + */ +var show = function show(element) { + return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Adds the hidden class to hide the element. + * + * @param {Element} element The element to hide. + * @return {void} + */ +var hide = function hide(element) { + return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); +}; + +/** + * Checks if an element is visible. + * + * @param {HTMLElement} element The HTML element to check for visibility. + * @return {boolean} Returns true if the element is visible, otherwise false. + */ +var isVisible = function isVisible(element) { + var styles = window.getComputedStyle(element); + return styles.getPropertyValue('display') !== 'none'; +}; + +/***/ }), + +/***/ "./js/src/welcome-tour/elements/beginTourModalElement.js": +/*!***************************************************************!*\ + !*** ./js/src/welcome-tour/elements/beginTourModalElement.js ***! + \***************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ buildBeginTourModalElement: () => (/* binding */ buildBeginTourModalElement) +/* harmony export */ }); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./elements */ "./js/src/welcome-tour/elements/elements.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/welcome-tour/shared/index.js"); +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + + + + +/** + * Build the begin tour modal element. + * + * @return {void} + */ +function buildBeginTourModalElement() { + addBeginTourModalToElements(createBeginTourModalElement()); +} + +/** + * Create and return the begin tour modal HTML element. + * + * @private + * @return {HTMLElement} The begin tour modal element. + */ +function createBeginTourModalElement() { + var beginTourModal = (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.maybeCreateModal)('frm_get_started_modal', { + title: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Get Started with Formidable Forms', 'formidable'), + content: (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.p)({ + className: 'frm-px-md', + text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Here\'s a quick checklist to help you set up and explore the key features of the plugin, so you can start building powerful forms in no time.', 'formidable') + }), + footer: (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.div)({ + className: 'frmcenter', + child: (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.a)({ + className: 'button button-primary frm-button-primary', + href: _shared__WEBPACK_IMPORTED_MODULE_3__.TOUR_URL, + text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Begin Tour', 'formidable') + }) + }), + width: _shared__WEBPACK_IMPORTED_MODULE_3__.MODAL_SIZE, + dialogClass: 'frm-fadein-up-back' + }); + beginTourModal.classList.add('frm_wrap', 'frm-welcome-tour-modal', 'frmcenter'); + return beginTourModal; +} + +/** + * Add the begin tour modal to the elements registry. + * + * @private + * @param {HTMLElement} beginTourModal The begin tour modal element. + * @return {void} + */ +function addBeginTourModalToElements(beginTourModal) { + if (!(0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)().beginTourModal) { + (0,_elements__WEBPACK_IMPORTED_MODULE_2__.addElements)({ + beginTourModal: beginTourModal + }); + } +} + +/***/ }), + +/***/ "./js/src/welcome-tour/elements/elements.js": +/*!**************************************************!*\ + !*** ./js/src/welcome-tour/elements/elements.js ***! + \**************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* binding */ addElements), +/* harmony export */ getElements: () => (/* binding */ getElements) +/* harmony export */ }); +/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); +/** + * External dependencies + */ + +var elements; +var welcomeTour = document.getElementById('frm-welcome-tour'); +if (welcomeTour) { + elements = { + welcomeTour: welcomeTour, + checklist: welcomeTour.querySelector('.frm-checklist'), + dismiss: welcomeTour.querySelector('.frm-checklist__dismiss'), + spotlight: document.querySelector('.frm-welcome-tour-spotlight') + }; +} +var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)(elements), + getElements = _createPageElements.getElements, + addElements = _createPageElements.addElements; + + +/***/ }), + +/***/ "./js/src/welcome-tour/elements/index.js": +/*!***********************************************!*\ + !*** ./js/src/welcome-tour/elements/index.js ***! + \***********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), +/* harmony export */ buildBeginTourModalElement: () => (/* reexport safe */ _beginTourModalElement__WEBPACK_IMPORTED_MODULE_1__.buildBeginTourModalElement), +/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/welcome-tour/elements/elements.js"); +/* harmony import */ var _beginTourModalElement__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./beginTourModalElement */ "./js/src/welcome-tour/elements/beginTourModalElement.js"); + + + +/***/ }), + +/***/ "./js/src/welcome-tour/events/checklistEvents.js": +/*!*******************************************************!*\ + !*** ./js/src/welcome-tour/events/checklistEvents.js ***! + \*******************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); +/** + * Internal dependencies + */ + + +/** + * Adds events to the checklist. + * + * @return {void} + */ +function addChecklistEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), + checklist = _getElements.checklist; + if (!checklist) { + return; + } + checklist.querySelector('.frm-checklist__header').addEventListener('click', function () { + return onChecklistHeaderClick(checklist); + }); +} + +/** + * Handles the checklist header click event. + * + * @private + * @param {HTMLElement} checklist The checklist element. + * @return {void} + */ +function onChecklistHeaderClick(checklist) { + checklist.classList.toggle('frm-checklist--collapsed'); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addChecklistEvents); + +/***/ }), + +/***/ "./js/src/welcome-tour/events/dismissEvents.js": +/*!*****************************************************!*\ + !*** ./js/src/welcome-tour/events/dismissEvents.js ***! + \*****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); +/** + * Internal dependencies + */ + + + +/** + * Adds events to the dismiss button. + * + * @return {void} + */ +function addDismissEvents() { + var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + dismiss = _getElements.dismiss; + if (!dismiss) { + return; + } + dismiss.addEventListener('click', onDismissClick); +} + +/** + * Handles the dismiss button click event. + * + * @private + * @return {void} + */ +function onDismissClick() { + var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), + welcomeTour = _getElements2.welcomeTour, + spotlight = _getElements2.spotlight; + welcomeTour === null || welcomeTour === void 0 || welcomeTour.remove(); + spotlight === null || spotlight === void 0 || spotlight.remove(); + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.doJsonPost)('dismiss_welcome_tour', new FormData()); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addDismissEvents); + +/***/ }), + +/***/ "./js/src/welcome-tour/events/index.js": +/*!*********************************************!*\ + !*** ./js/src/welcome-tour/events/index.js ***! + \*********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) +/* harmony export */ }); +/* harmony import */ var _checklistEvents__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./checklistEvents */ "./js/src/welcome-tour/events/checklistEvents.js"); +/* harmony import */ var _dismissEvents__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./dismissEvents */ "./js/src/welcome-tour/events/dismissEvents.js"); +/* harmony import */ var _stylerUpdateButtonEvents__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./stylerUpdateButtonEvents */ "./js/src/welcome-tour/events/stylerUpdateButtonEvents.js"); + + + + +/** + * Attaches event listeners for handling user interactions. + * + * @return {void} + */ +function addEventListeners() { + (0,_checklistEvents__WEBPACK_IMPORTED_MODULE_0__["default"])(); + (0,_dismissEvents__WEBPACK_IMPORTED_MODULE_1__["default"])(); + (0,_stylerUpdateButtonEvents__WEBPACK_IMPORTED_MODULE_2__["default"])(); +} + +/***/ }), + +/***/ "./js/src/welcome-tour/events/stylerUpdateButtonEvents.js": +/*!****************************************************************!*\ + !*** ./js/src/welcome-tour/events/stylerUpdateButtonEvents.js ***! + \****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils */ "./js/src/welcome-tour/utils/index.js"); +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * Internal dependencies + */ + + + +/** + * Adds events to the styler update button. + * + * @return {void} + */ +function addStylerUpdateEvents() { + if ('formidable-styles' !== (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('page')) { + return; + } + (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(document.getElementById('frm_submit_side_top'), onStylerUpdateClick); +} + +/** + * Handles the styler update button click event. + * + * @private + * @return {void} + */ +function onStylerUpdateClick() { + return _onStylerUpdateClick.apply(this, arguments); +} +function _onStylerUpdateClick() { + _onStylerUpdateClick = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { + return _regenerator().w(function (_context) { + while (1) switch (_context.n) { + case 0: + _context.n = 1; + return (0,_utils__WEBPACK_IMPORTED_MODULE_1__.markStepAsCompleted)('style-form'); + case 1: + window.location.reload(); + case 2: + return _context.a(2); + } + }, _callee); + })); + return _onStylerUpdateClick.apply(this, arguments); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addStylerUpdateEvents); + +/***/ }), + +/***/ "./js/src/welcome-tour/shared/constants.js": +/*!*************************************************!*\ + !*** ./js/src/welcome-tour/shared/constants.js ***! + \*************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKLIST_STEPS: () => (/* binding */ CHECKLIST_STEPS), +/* harmony export */ IS_DASHBOARD_PAGE: () => (/* binding */ IS_DASHBOARD_PAGE), +/* harmony export */ IS_WELCOME_TOUR_SEEN: () => (/* binding */ IS_WELCOME_TOUR_SEEN), +/* harmony export */ MODAL_SIZE: () => (/* binding */ MODAL_SIZE), +/* harmony export */ PREFIX: () => (/* binding */ PREFIX), +/* harmony export */ PROGRESS_BAR_PERCENT: () => (/* binding */ PROGRESS_BAR_PERCENT), +/* harmony export */ TOUR_URL: () => (/* binding */ TOUR_URL) +/* harmony export */ }); +var _window$frmWelcomeTou = window.frmWelcomeTourVars, + IS_DASHBOARD_PAGE = _window$frmWelcomeTou.IS_DASHBOARD_PAGE, + IS_WELCOME_TOUR_SEEN = _window$frmWelcomeTou.IS_WELCOME_TOUR_SEEN, + CHECKLIST_STEPS = _window$frmWelcomeTou.CHECKLIST_STEPS, + TOUR_URL = _window$frmWelcomeTou.TOUR_URL, + PROGRESS_BAR_PERCENT = _window$frmWelcomeTou.PROGRESS_BAR_PERCENT; + +var PREFIX = 'frm-welcome-tour'; +var MODAL_SIZE = '440px'; + +/***/ }), + +/***/ "./js/src/welcome-tour/shared/index.js": +/*!*********************************************!*\ + !*** ./js/src/welcome-tour/shared/index.js ***! + \*********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ CHECKLIST_STEPS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.CHECKLIST_STEPS), +/* harmony export */ IS_DASHBOARD_PAGE: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.IS_DASHBOARD_PAGE), +/* harmony export */ IS_WELCOME_TOUR_SEEN: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.IS_WELCOME_TOUR_SEEN), +/* harmony export */ MODAL_SIZE: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.MODAL_SIZE), +/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), +/* harmony export */ PROGRESS_BAR_PERCENT: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PROGRESS_BAR_PERCENT), +/* harmony export */ TOUR_URL: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.TOUR_URL) +/* harmony export */ }); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/welcome-tour/shared/constants.js"); + + +/***/ }), + +/***/ "./js/src/welcome-tour/ui/checklist.js": +/*!*********************************************!*\ + !*** ./js/src/welcome-tour/ui/checklist.js ***! + \*********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../shared */ "./js/src/welcome-tour/shared/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils */ "./js/src/welcome-tour/utils/index.js"); +/** + * Internal dependencies + */ + + + +/** + * Initializes the checklist. + * + * @return {void} + */ +function initializeChecklist() { + setProgressBarPercent(); + document.addEventListener('frm_added_field', function () { + return (0,_utils__WEBPACK_IMPORTED_MODULE_1__.markStepAsCompleted)('add-fields'); + }); +} + +/** + * Sets the progress bar percent. + * + * @private + * @return {void} + */ +function setProgressBarPercent() { + var progressFill = document.querySelector('.frm-welcome-tour .frm-checklist__progress-fill'); + if (!progressFill) { + return; + } + progressFill.style.width = "".concat(_shared__WEBPACK_IMPORTED_MODULE_0__.PROGRESS_BAR_PERCENT, "%"); +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeChecklist); + +/***/ }), + +/***/ "./js/src/welcome-tour/ui/index.js": +/*!*****************************************!*\ + !*** ./js/src/welcome-tour/ui/index.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ initializeChecklist: () => (/* reexport safe */ _checklist__WEBPACK_IMPORTED_MODULE_2__["default"]), +/* harmony export */ initializeModal: () => (/* reexport safe */ _modal__WEBPACK_IMPORTED_MODULE_0__["default"]), +/* harmony export */ initializeSpotlight: () => (/* reexport safe */ _spotlight__WEBPACK_IMPORTED_MODULE_1__["default"]) +/* harmony export */ }); +/* harmony import */ var _modal__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./modal */ "./js/src/welcome-tour/ui/modal.js"); +/* harmony import */ var _spotlight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./spotlight */ "./js/src/welcome-tour/ui/spotlight.js"); +/* harmony import */ var _checklist__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./checklist */ "./js/src/welcome-tour/ui/checklist.js"); + + + + +/***/ }), + +/***/ "./js/src/welcome-tour/ui/modal.js": +/*!*****************************************!*\ + !*** ./js/src/welcome-tour/ui/modal.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); +/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/welcome-tour/shared/index.js"); +/** + * Internal dependencies + */ + + + +/** + * Initialize the modal widget. + * + * @return {void} + */ +function initializeModal() { + if (_shared__WEBPACK_IMPORTED_MODULE_1__.IS_DASHBOARD_PAGE && !_shared__WEBPACK_IMPORTED_MODULE_1__.IS_WELCOME_TOUR_SEEN) { + (0,_elements__WEBPACK_IMPORTED_MODULE_0__.buildBeginTourModalElement)(); + } +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeModal); + +/***/ }), + +/***/ "./js/src/welcome-tour/ui/spotlight.js": +/*!*********************************************!*\ + !*** ./js/src/welcome-tour/ui/spotlight.js ***! + \*********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/** + * Initialize the spotlight widget. + * + * @return {void} + */ +function initializeSpotlight() { + document.querySelectorAll('.frm-spotlight').forEach(function (spotlightElement) { + setTimeout(function () { + setupSpotlight(spotlightElement); + }, 0); + }); +} + +/** + * Setup spotlight with positioning and scroll listeners. + * + * @private + * @param {HTMLElement} spotlightElement The spotlight container. + * @return {void} + */ +function setupSpotlight(spotlightElement) { + var targetElement = document.querySelector(spotlightElement.dataset.target); + if (!targetElement) { + return; + } + document.body.append(spotlightElement); + + // Add scroll listeners to all scrollable ancestors + var scrollableElements = getScrollableAncestors(targetElement); + scrollableElements.forEach(function (element) { + element.addEventListener('scroll', function () { + updateSpotlightPosition(spotlightElement, targetElement); + handleSpotlightFadeAnimation(spotlightElement); + }, { + passive: true + }); + }); + window.addEventListener('resize', function () { + return updateSpotlightPosition(spotlightElement, targetElement); + }, { + passive: true + }); + + // Re-position and show spotlight after a short delay on page load + setTimeout(function () { + updateSpotlightPosition(spotlightElement, targetElement); + spotlightElement.classList.remove('frm-force-hidden'); + }, 200); +} + +/** + * Update spotlight position based on target element. + * + * @private + * @param {HTMLElement} spotlightElement The spotlight container. + * @param {HTMLElement} targetElement The target element. + * @return {void} + */ +function updateSpotlightPosition(spotlightElement, targetElement) { + if (!targetElement.offsetParent) { + return; + } + var targetRect = targetElement.getBoundingClientRect(); + if (targetRect.width === 0 || targetRect.height === 0) { + return; + } + var left; + var leftPositionAttr = spotlightElement.dataset.leftPosition; + switch (leftPositionAttr) { + case 'middle': + left = targetRect.left + Math.round(targetRect.width / 2); + break; + case 'end': + left = targetRect.right; + break; + default: + left = targetRect.left + parseInt(leftPositionAttr); + break; + } + spotlightElement.style.left = "".concat(left || targetRect.left, "px"); + var top = 'bottom' === spotlightElement.dataset.placement ? targetRect.top + targetRect.height : targetRect.top + Math.round(targetRect.height / 2); + spotlightElement.style.top = "".concat(top, "px"); +} + +/** + * Handle fade animations based on spotlight position relative to #frm_top_bar. + * + * @private + * @param {HTMLElement} spotlightElement The spotlight container. + * @return {void} + */ +function handleSpotlightFadeAnimation(spotlightElement) { + var topBar = document.getElementById('frm_top_bar'); + if (!topBar) { + return; + } + var shouldFadeOut = spotlightElement.getBoundingClientRect().top + 24 <= topBar.getBoundingClientRect().bottom; + if (shouldFadeOut && !spotlightElement.classList.contains('frm-fadeout')) { + spotlightElement.classList.remove('frm-fadein'); + spotlightElement.classList.add('frm-fadeout'); + } else if (!shouldFadeOut && !spotlightElement.classList.contains('frm-fadein')) { + spotlightElement.classList.remove('frm-fadeout'); + spotlightElement.classList.add('frm-fadein'); + } +} + +/** + * Get all scrollable ancestor elements. + * + * @private + * @param {HTMLElement} element The target element. + * @return {HTMLElement[]} Array of scrollable elements. + */ +function getScrollableAncestors(element) { + var scrollables = [window]; + var parent = element.parentElement; + while (parent && document.body !== parent) { + var _getComputedStyle = getComputedStyle(parent), + overflow = _getComputedStyle.overflow, + overflowY = _getComputedStyle.overflowY; + if (['auto', 'scroll'].includes(overflow) || ['auto', 'scroll'].includes(overflowY)) { + scrollables.push(parent); + } + parent = parent.parentElement; + } + return scrollables; +} +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeSpotlight); + +/***/ }), + +/***/ "./js/src/welcome-tour/utils/index.js": +/*!********************************************!*\ + !*** ./js/src/welcome-tour/utils/index.js ***! + \********************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ markStepAsCompleted: () => (/* reexport safe */ _markStepAsCompleted__WEBPACK_IMPORTED_MODULE_1__.markStepAsCompleted), +/* harmony export */ onDashboardPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onDashboardPage), +/* harmony export */ onEditorPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onEditorPage), +/* harmony export */ onFormTemplatesPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onFormTemplatesPage), +/* harmony export */ onStylerPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onStylerPage) +/* harmony export */ }); +/* harmony import */ var _pageDetection__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageDetection */ "./js/src/welcome-tour/utils/pageDetection.js"); +/* harmony import */ var _markStepAsCompleted__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./markStepAsCompleted */ "./js/src/welcome-tour/utils/markStepAsCompleted.js"); + + + +/***/ }), + +/***/ "./js/src/welcome-tour/utils/markStepAsCompleted.js": +/*!**********************************************************!*\ + !*** ./js/src/welcome-tour/utils/markStepAsCompleted.js ***! + \**********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ markStepAsCompleted: () => (/* binding */ markStepAsCompleted) +/* harmony export */ }); +/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); +/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); +function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } +function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } +function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } +function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } +/** + * Internal dependencies + */ + + +var STEP_PREFIX = 'frm-checklist__step'; + +/** + * Marks a step as completed. + * + * @param {string} stepKey The step key. + * @return {Promise} + */ +function markStepAsCompleted(_x) { + return _markStepAsCompleted.apply(this, arguments); +} + +/** + * Wraps step title with anchor link from dataset. + * + * @private + * @param {HTMLElement} stepElement The step element to wrap. + * @return {void} + */ +function _markStepAsCompleted() { + _markStepAsCompleted = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(stepKey) { + var _getElements, checklist, stepElement, formData, nextStep, _t; + return _regenerator().w(function (_context) { + while (1) switch (_context.p = _context.n) { + case 0: + _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), checklist = _getElements.checklist; + if (checklist) { + _context.n = 1; + break; + } + return _context.a(2); + case 1: + stepElement = document.getElementById("".concat(STEP_PREFIX, "-").concat(stepKey)); + if (stepElement) { + _context.n = 2; + break; + } + return _context.a(2); + case 2: + if (stepElement.classList.contains("".concat(STEP_PREFIX, "--active"))) { + _context.n = 3; + break; + } + return _context.a(2); + case 3: + formData = new FormData(); + formData.append('step_key', stepKey); + _context.p = 4; + _context.n = 5; + return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.doJsonPost)('mark_checklist_step_as_completed', formData); + case 5: + stepElement.classList.remove("".concat(STEP_PREFIX, "--active")); + stepElement.classList.add("".concat(STEP_PREFIX, "--completed")); + nextStep = stepElement.nextElementSibling; + if (nextStep) { + _context.n = 6; + break; + } + return _context.a(2); + case 6: + nextStep.classList.add("".concat(STEP_PREFIX, "--active")); + if (nextStep.dataset.link) { + wrapStepTitleWithLink(nextStep); + } + _context.n = 8; + break; + case 7: + _context.p = 7; + _t = _context.v; + console.error('Failed to mark step as completed:', _t); + case 8: + return _context.a(2); + } + }, _callee, null, [[4, 7]]); + })); + return _markStepAsCompleted.apply(this, arguments); +} +function wrapStepTitleWithLink(stepElement) { + var stepTitle = stepElement.querySelector('.frm-checklist__step-title'); + if (stepTitle !== null && stepTitle !== void 0 && stepTitle.querySelector('a')) { + return; + } + var anchor = (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.a)({ + href: stepElement.dataset.link, + className: 'frm-h-stack-xs', + children: Array.from(stepTitle.childNodes) + }); + stepTitle.replaceChildren(anchor); +} + +/***/ }), + +/***/ "./js/src/welcome-tour/utils/pageDetection.js": +/*!****************************************************!*\ + !*** ./js/src/welcome-tour/utils/pageDetection.js ***! + \****************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ onDashboardPage: () => (/* binding */ onDashboardPage), +/* harmony export */ onEditorPage: () => (/* binding */ onEditorPage), +/* harmony export */ onFormTemplatesPage: () => (/* binding */ onFormTemplatesPage), +/* harmony export */ onStylerPage: () => (/* binding */ onStylerPage) +/* harmony export */ }); +/* harmony import */ var core_utils_url__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils/url */ "./js/src/core/utils/url.js"); +/** + * Internal dependencies + */ + + +/** + * Checks if the current page is the editor page. + * + * @return {boolean} True if the current page is the editor page, false otherwise. + */ +var onEditorPage = function onEditorPage() { + return document.getElementById('frm_form_editor_container') !== null; +}; + +/** + * Checks if the current page is the styler page. + * + * @return {boolean} True if the current page is the styler page, false otherwise. + */ +var onStylerPage = function onStylerPage() { + return document.getElementById('frm_active_style_form') !== null; +}; + +/** + * Checks if the current page is the form templates page. + * + * @return {boolean} True if the current page is the form templates page, false otherwise. + */ +var onFormTemplatesPage = function onFormTemplatesPage() { + return (0,core_utils_url__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('page') === 'formidable-form-templates'; +}; + +/** + * Checks if the current page is the dashboard page. + * + * @return {boolean} True if the current page is the dashboard page, false otherwise. + */ +var onDashboardPage = function onDashboardPage() { + return (0,core_utils_url__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('page') === 'formidable-dashboard'; +}; + +/***/ }), + +/***/ "./node_modules/memize/index.js": +/*!**************************************!*\ + !*** ./node_modules/memize/index.js ***! + \**************************************/ +/***/ ((module) => { + +/** + * Memize options object. + * + * @typedef MemizeOptions + * + * @property {number} [maxSize] Maximum size of the cache. + */ + +/** + * Internal cache entry. + * + * @typedef MemizeCacheNode + * + * @property {?MemizeCacheNode|undefined} [prev] Previous node. + * @property {?MemizeCacheNode|undefined} [next] Next node. + * @property {Array<*>} args Function arguments for cache + * entry. + * @property {*} val Function result. + */ + +/** + * Properties of the enhanced function for controlling cache. + * + * @typedef MemizeMemoizedFunction + * + * @property {()=>void} clear Clear the cache. + */ + +/** + * Accepts a function to be memoized, and returns a new memoized function, with + * optional options. + * + * @template {Function} F + * + * @param {F} fn Function to memoize. + * @param {MemizeOptions} [options] Options object. + * + * @return {F & MemizeMemoizedFunction} Memoized function. + */ +function memize( fn, options ) { + var size = 0; + + /** @type {?MemizeCacheNode|undefined} */ + var head; + + /** @type {?MemizeCacheNode|undefined} */ + var tail; + + options = options || {}; + + function memoized( /* ...args */ ) { + var node = head, + len = arguments.length, + args, i; + + searchCache: while ( node ) { + // Perform a shallow equality test to confirm that whether the node + // under test is a candidate for the arguments passed. Two arrays + // are shallowly equal if their length matches and each entry is + // strictly equal between the two sets. Avoid abstracting to a + // function which could incur an arguments leaking deoptimization. + + // Check whether node arguments match arguments length + if ( node.args.length !== arguments.length ) { + node = node.next; + continue; + } + + // Check whether node arguments match arguments values + for ( i = 0; i < len; i++ ) { + if ( node.args[ i ] !== arguments[ i ] ) { + node = node.next; + continue searchCache; + } + } + + // At this point we can assume we've found a match + + // Surface matched node to head if not already + if ( node !== head ) { + // As tail, shift to previous. Must only shift if not also + // head, since if both head and tail, there is no previous. + if ( node === tail ) { + tail = node.prev; + } + + // Adjust siblings to point to each other. If node was tail, + // this also handles new tail's empty `next` assignment. + /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; + if ( node.next ) { + node.next.prev = node.prev; + } + + node.next = head; + node.prev = null; + /** @type {MemizeCacheNode} */ ( head ).prev = node; + head = node; + } + + // Return immediately + return node.val; + } + + // No cached value found. Continue to insertion phase: + + // Create a copy of arguments (avoid leaking deoptimization) + args = new Array( len ); + for ( i = 0; i < len; i++ ) { + args[ i ] = arguments[ i ]; + } + + node = { + args: args, + + // Generate the result from original function + val: fn.apply( null, args ), + }; + + // Don't need to check whether node is already head, since it would + // have been returned above already if it was + + // Shift existing head down list + if ( head ) { + head.prev = node; + node.next = head; + } else { + // If no head, follows that there's no tail (at initial or reset) + tail = node; + } + + // Trim tail if we're reached max size and are pending cache insertion + if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { + tail = /** @type {MemizeCacheNode} */ ( tail ).prev; + /** @type {MemizeCacheNode} */ ( tail ).next = null; + } else { + size++; + } + + head = node; + + return node.val; + } + + memoized.clear = function() { + head = null; + tail = null; + size = 0; + }; + + if ( false ) {} + + // Ignore reason: There's not a clear solution to create an intersection of + // the function with additional properties, where the goal is to retain the + // function signature of the incoming argument and add control properties + // on the return value. + + // @ts-ignore + return memoized; +} + +module.exports = memize; + + +/***/ }), + +/***/ "./node_modules/sprintf-js/src/sprintf.js": +/*!************************************************!*\ + !*** ./node_modules/sprintf-js/src/sprintf.js ***! + \************************************************/ +/***/ ((module, exports, __webpack_require__) => { + +var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ + +!function() { + 'use strict' + + var re = { + not_string: /[^s]/, + not_bool: /[^t]/, + not_type: /[^T]/, + not_primitive: /[^v]/, + number: /[diefg]/, + numeric_arg: /[bcdiefguxX]/, + json: /[j]/, + not_json: /[^j]/, + text: /^[^\x25]+/, + modulo: /^\x25{2}/, + placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, + key: /^([a-z_][a-z_\d]*)/i, + key_access: /^\.([a-z_][a-z_\d]*)/i, + index_access: /^\[(\d+)\]/, + sign: /^[+-]/ + } + + function sprintf(key) { + // `arguments` is not an array, but should be fine for this call + return sprintf_format(sprintf_parse(key), arguments) + } + + function vsprintf(fmt, argv) { + return sprintf.apply(null, [fmt].concat(argv || [])) + } + + function sprintf_format(parse_tree, argv) { + var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign + for (i = 0; i < tree_length; i++) { + if (typeof parse_tree[i] === 'string') { + output += parse_tree[i] + } + else if (typeof parse_tree[i] === 'object') { + ph = parse_tree[i] // convenience purposes only + if (ph.keys) { // keyword argument + arg = argv[cursor] + for (k = 0; k < ph.keys.length; k++) { + if (arg == undefined) { + throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) + } + arg = arg[ph.keys[k]] + } + } + else if (ph.param_no) { // positional argument (explicit) + arg = argv[ph.param_no] + } + else { // positional argument (implicit) + arg = argv[cursor++] + } + + if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { + arg = arg() + } + + if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { + throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) + } + + if (re.number.test(ph.type)) { + is_positive = arg >= 0 + } + + switch (ph.type) { + case 'b': + arg = parseInt(arg, 10).toString(2) + break + case 'c': + arg = String.fromCharCode(parseInt(arg, 10)) + break + case 'd': + case 'i': + arg = parseInt(arg, 10) + break + case 'j': + arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) + break + case 'e': + arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() + break + case 'f': + arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) + break + case 'g': + arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) + break + case 'o': + arg = (parseInt(arg, 10) >>> 0).toString(8) + break + case 's': + arg = String(arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 't': + arg = String(!!arg) + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'T': + arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'u': + arg = parseInt(arg, 10) >>> 0 + break + case 'v': + arg = arg.valueOf() + arg = (ph.precision ? arg.substring(0, ph.precision) : arg) + break + case 'x': + arg = (parseInt(arg, 10) >>> 0).toString(16) + break + case 'X': + arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() + break + } + if (re.json.test(ph.type)) { + output += arg + } + else { + if (re.number.test(ph.type) && (!is_positive || ph.sign)) { + sign = is_positive ? '+' : '-' + arg = arg.toString().replace(re.sign, '') + } + else { + sign = '' + } + pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' + pad_length = ph.width - (sign + arg).length + pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' + output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) + } + } + } + return output + } + + var sprintf_cache = Object.create(null) + + function sprintf_parse(fmt) { + if (sprintf_cache[fmt]) { + return sprintf_cache[fmt] + } + + var _fmt = fmt, match, parse_tree = [], arg_names = 0 + while (_fmt) { + if ((match = re.text.exec(_fmt)) !== null) { + parse_tree.push(match[0]) + } + else if ((match = re.modulo.exec(_fmt)) !== null) { + parse_tree.push('%') + } + else if ((match = re.placeholder.exec(_fmt)) !== null) { + if (match[2]) { + arg_names |= 1 + var field_list = [], replacement_field = match[2], field_match = [] + if ((field_match = re.key.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { + if ((field_match = re.key_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else if ((field_match = re.index_access.exec(replacement_field)) !== null) { + field_list.push(field_match[1]) + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + } + } + else { + throw new SyntaxError('[sprintf] failed to parse named argument key') + } + match[2] = field_list + } + else { + arg_names |= 2 + } + if (arg_names === 3) { + throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') + } + + parse_tree.push( + { + placeholder: match[0], + param_no: match[1], + keys: match[2], + sign: match[3], + pad_char: match[4], + align: match[5], + width: match[6], + precision: match[7], + type: match[8] + } + ) + } + else { + throw new SyntaxError('[sprintf] unexpected placeholder') + } + _fmt = _fmt.substring(match[0].length) + } + return sprintf_cache[fmt] = parse_tree + } + + /** + * export to either browser or node.js + */ + /* eslint-disable quote-props */ + if (true) { + exports.sprintf = sprintf + exports.vsprintf = vsprintf + } + if (typeof window !== 'undefined') { + window['sprintf'] = sprintf + window['vsprintf'] = vsprintf + + if (true) { + !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { + return { + 'sprintf': sprintf, + 'vsprintf': vsprintf + } + }).call(exports, __webpack_require__, exports, module), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) + } + } + /* eslint-enable quote-props */ +}(); // eslint-disable-line + + +/***/ }), + +/***/ "./node_modules/tannin/index.js": +/*!**************************************!*\ + !*** ./node_modules/tannin/index.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ Tannin) +/* harmony export */ }); +/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); + + +/** + * Tannin constructor options. + * + * @typedef {Object} TanninOptions + * + * @property {string} [contextDelimiter] Joiner in string lookup with context. + * @property {Function} [onMissingKey] Callback to invoke when key missing. + */ + +/** + * Domain metadata. + * + * @typedef {Object} TanninDomainMetadata + * + * @property {string} [domain] Domain name. + * @property {string} [lang] Language code. + * @property {(string|Function)} [plural_forms] Plural forms expression or + * function evaluator. + */ + +/** + * Domain translation pair respectively representing the singular and plural + * translation. + * + * @typedef {[string,string]} TanninTranslation + */ + +/** + * Locale data domain. The key is used as reference for lookup, the value an + * array of two string entries respectively representing the singular and plural + * translation. + * + * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain + */ + +/** + * Jed-formatted locale data. + * + * @see http://messageformat.github.io/Jed/ + * + * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData + */ + +/** + * Default Tannin constructor options. + * + * @type {TanninOptions} + */ +var DEFAULT_OPTIONS = { + contextDelimiter: '\u0004', + onMissingKey: null, +}; + +/** + * Given a specific locale data's config `plural_forms` value, returns the + * expression. + * + * @example + * + * ``` + * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' + * ``` + * + * @param {string} pf Locale data plural forms. + * + * @return {string} Plural forms expression. + */ +function getPluralExpression( pf ) { + var parts, i, part; + + parts = pf.split( ';' ); + + for ( i = 0; i < parts.length; i++ ) { + part = parts[ i ].trim(); + if ( part.indexOf( 'plural=' ) === 0 ) { + return part.substr( 7 ); + } + } +} + +/** + * Tannin constructor. + * + * @class + * + * @param {TanninLocaleData} data Jed-formatted locale data. + * @param {TanninOptions} [options] Tannin options. + */ +function Tannin( data, options ) { + var key; + + /** + * Jed-formatted locale data. + * + * @name Tannin#data + * @type {TanninLocaleData} + */ + this.data = data; + + /** + * Plural forms function cache, keyed by plural forms string. + * + * @name Tannin#pluralForms + * @type {Object} + */ + this.pluralForms = {}; + + /** + * Effective options for instance, including defaults. + * + * @name Tannin#options + * @type {TanninOptions} + */ + this.options = {}; + + for ( key in DEFAULT_OPTIONS ) { + this.options[ key ] = options !== undefined && key in options + ? options[ key ] + : DEFAULT_OPTIONS[ key ]; + } +} + +/** + * Returns the plural form index for the given domain and value. + * + * @param {string} domain Domain on which to calculate plural form. + * @param {number} n Value for which plural form is to be calculated. + * + * @return {number} Plural form index. + */ +Tannin.prototype.getPluralForm = function( domain, n ) { + var getPluralForm = this.pluralForms[ domain ], + config, plural, pf; + + if ( ! getPluralForm ) { + config = this.data[ domain ][ '' ]; + + pf = ( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + if ( typeof pf !== 'function' ) { + plural = getPluralExpression( + config[ 'Plural-Forms' ] || + config[ 'plural-forms' ] || + // Ignore reason: As known, there's no way to document the empty + // string property on a key to guarantee this as metadata. + // @ts-ignore + config.plural_forms + ); + + pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); + } + + getPluralForm = this.pluralForms[ domain ] = pf; + } + + return getPluralForm( n ); +}; + +/** + * Translate a string. + * + * @param {string} domain Translation domain. + * @param {string|void} context Context distinguishing terms of the same name. + * @param {string} singular Primary key for translation lookup. + * @param {string=} plural Fallback value used for non-zero plural + * form index. + * @param {number=} n Value to use in calculating plural form. + * + * @return {string} Translated string. + */ +Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { + var index, key, entry; + + if ( n === undefined ) { + // Default to singular. + index = 0; + } else { + // Find index by evaluating plural form for value. + index = this.getPluralForm( domain, n ); + } + + key = singular; + + // If provided, context is prepended to key with delimiter. + if ( context ) { + key = context + this.options.contextDelimiter + singular; + } + + entry = this.data[ domain ][ key ]; + + // Verify not only that entry exists, but that the intended index is within + // range and non-empty. + if ( entry && entry[ index ] ) { + return entry[ index ]; + } + + if ( this.options.onMissingKey ) { + this.options.onMissingKey( singular, domain ); + } + + // If entry not found, fall back to singular vs. plural with zero index + // representing the singular value. + return index === 0 ? singular : plural; +}; + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) +/* harmony export */ }); +function _arrayLikeToArray(r, a) { + (null == a || a > r.length) && (a = r.length); + for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; + return n; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _arrayWithoutHoles(r) { + if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _classCallCheck) +/* harmony export */ }); +function _classCallCheck(a, n) { + if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _defineProperty) +/* harmony export */ }); +/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); + +function _defineProperty(e, r, t) { + return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { + value: t, + enumerable: !0, + configurable: !0, + writable: !0 + }) : e[r] = t, e; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": +/*!********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _iterableToArray) +/* harmony export */ }); +function _iterableToArray(r) { + if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) +/* harmony export */ }); +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _toConsumableArray) +/* harmony export */ }); +/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); +/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); +/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); +/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); + + + + +function _toConsumableArray(r) { + return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! + \****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPrimitive) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); + +function toPrimitive(t, r) { + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; + var e = t[Symbol.toPrimitive]; + if (void 0 !== e) { + var i = e.call(t, r || "default"); + if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; + throw new TypeError("@@toPrimitive must return a primitive value."); + } + return ("string" === r ? String : Number)(t); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ toPropertyKey) +/* harmony export */ }); +/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); +/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); + + +function toPropertyKey(t) { + var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); + return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": +/*!***********************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! + \***********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _typeof) +/* harmony export */ }); +function _typeof(o) { + "@babel/helpers - typeof"; + + return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { + return typeof o; + } : function (o) { + return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; + }, _typeof(o); +} + + +/***/ }), + +/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) +/* harmony export */ }); +/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); + +function _unsupportedIterableToArray(r, a) { + if (r) { + if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); + var t = {}.toString.call(r).slice(8, -1); + return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; + } +} + + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; +// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. +(() => { +"use strict"; +/*!**************************************!*\ + !*** ./js/src/welcome-tour/index.js ***! + \**************************************/ +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); +/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/welcome-tour/ui/index.js"); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./js/src/welcome-tour/events/index.js"); +/** + * WordPress dependencies + */ + + +/** + * Internal dependencies + */ + + +(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__["default"])(function () { + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeModal)(); + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeSpotlight)(); + (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeChecklist)(); + (0,_events__WEBPACK_IMPORTED_MODULE_1__.addEventListeners)(); +}); +})(); + +/******/ })() +; +//# sourceMappingURL=welcome-tour.js.map \ No newline at end of file From c9104bd04664f8ec3dfbd9239febb9a2dd38a940 Mon Sep 17 00:00:00 2001 From: Abdi Tolessa <41271840+AbdiTolesa@users.noreply.github.com> Date: Wed, 18 Mar 2026 14:50:48 +0300 Subject: [PATCH 2/5] Add font size style to td elements --- classes/controllers/FrmEmailStylesController.php | 1 + classes/models/FrmTableHTMLGenerator.php | 1 + 2 files changed, 2 insertions(+) diff --git a/classes/controllers/FrmEmailStylesController.php b/classes/controllers/FrmEmailStylesController.php index ffdb2909e3..e37980af59 100644 --- a/classes/controllers/FrmEmailStylesController.php +++ b/classes/controllers/FrmEmailStylesController.php @@ -252,6 +252,7 @@ public static function get_table_generator( $email_style = false ) { $atts['bg_color'] = $style_settings['container_bg_color']; $atts['alt_bg_color'] = $style_settings['container_bg_color']; $atts['text_color'] = $style_settings['text_color']; + $atts['font_size'] = $style_settings['font_size']; } return new FrmTableHTMLGenerator( 'entry', $atts ); diff --git a/classes/models/FrmTableHTMLGenerator.php b/classes/models/FrmTableHTMLGenerator.php index 6ef76af415..84003fdba7 100644 --- a/classes/models/FrmTableHTMLGenerator.php +++ b/classes/models/FrmTableHTMLGenerator.php @@ -211,6 +211,7 @@ private function init_td_style() { $td_style_attributes = 'text-align:' . ( $this->direction === 'rtl' ? 'right' : 'left' ) . ';'; $td_style_attributes .= 'color:' . $this->style_settings['text_color'] . ';padding:' . $this->cell_padding . ';vertical-align:top;'; $td_style_attributes .= 'border-top:' . $this->style_settings['border_width'] . ' solid ' . $this->style_settings['border_color'] . ';'; + $td_style_attributes .= 'font-size:' . $this->style_settings['font_size'] . ';'; $this->td_style = ' style="' . esc_attr( $td_style_attributes ) . '"'; } From cc2a62e8c461414d0ad1a380e0626ad4813151e8 Mon Sep 17 00:00:00 2001 From: Abdi Tolessa <41271840+AbdiTolesa@users.noreply.github.com> Date: Wed, 18 Mar 2026 15:17:46 +0300 Subject: [PATCH 3/5] Add a condition check needed to set table cell font size --- classes/models/FrmTableHTMLGenerator.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/classes/models/FrmTableHTMLGenerator.php b/classes/models/FrmTableHTMLGenerator.php index 84003fdba7..664f2b8e04 100644 --- a/classes/models/FrmTableHTMLGenerator.php +++ b/classes/models/FrmTableHTMLGenerator.php @@ -211,7 +211,9 @@ private function init_td_style() { $td_style_attributes = 'text-align:' . ( $this->direction === 'rtl' ? 'right' : 'left' ) . ';'; $td_style_attributes .= 'color:' . $this->style_settings['text_color'] . ';padding:' . $this->cell_padding . ';vertical-align:top;'; $td_style_attributes .= 'border-top:' . $this->style_settings['border_width'] . ' solid ' . $this->style_settings['border_color'] . ';'; - $td_style_attributes .= 'font-size:' . $this->style_settings['font_size'] . ';'; + if ( ! empty( $this->style_settings['font_size'] ) ) { + $td_style_attributes .= 'font-size:' . $this->style_settings['font_size'] . ';'; + } $this->td_style = ' style="' . esc_attr( $td_style_attributes ) . '"'; } From 59fadc7d0808d345bfff08d8c293338c616f59d5 Mon Sep 17 00:00:00 2001 From: Abdi Tolessa <41271840+AbdiTolesa@users.noreply.github.com> Date: Wed, 18 Mar 2026 15:21:53 +0300 Subject: [PATCH 4/5] Add a condition check needed to set table cell font size --- classes/controllers/FrmEmailStylesController.php | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/classes/controllers/FrmEmailStylesController.php b/classes/controllers/FrmEmailStylesController.php index e37980af59..4f4bd9ca8a 100644 --- a/classes/controllers/FrmEmailStylesController.php +++ b/classes/controllers/FrmEmailStylesController.php @@ -252,7 +252,9 @@ public static function get_table_generator( $email_style = false ) { $atts['bg_color'] = $style_settings['container_bg_color']; $atts['alt_bg_color'] = $style_settings['container_bg_color']; $atts['text_color'] = $style_settings['text_color']; - $atts['font_size'] = $style_settings['font_size']; + if ( ! empty( $style_settings['font_size'] ) ) { + $atts['font_size'] = $style_settings['font_size']; + } } return new FrmTableHTMLGenerator( 'entry', $atts ); From ebfefa79705bae94cb00df6f1860efb52be27182 Mon Sep 17 00:00:00 2001 From: Abdi Tolessa <41271840+AbdiTolesa@users.noreply.github.com> Date: Wed, 18 Mar 2026 21:14:05 +0300 Subject: [PATCH 5/5] Rebuild files --- css/admin/frm-settings-components.css | 627 +- css/admin/welcome-tour.css | 153 +- css/font_icons.css | 89 +- css/frm_admin.css | 11946 +------------- css/frm_testing_mode.css | 2860 +--- js/addons-page.js | 4846 +----- js/form-templates.js | 6800 +------- js/formidable-settings-components.js | 2932 +--- js/formidable-web-components.js | 5836 +------ js/formidable_admin.js | 13301 +--------------- js/formidable_blocks.js | 2716 +--- js/formidable_dashboard.js | 960 +- js/formidable_overlay.js | 794 +- js/formidable_styles.js | 3161 +--- js/frm_testing_mode.js | 3487 +--- js/onboarding-wizard.js | 1901 +-- .../frm-border-radius-component.css | 230 +- .../frm-colorpicker-component.css | 155 +- .../frm-dropdown-component.css | 133 +- .../frm-range-slider-component.css | 291 +- .../frm-tab-navigator-component.css | 244 +- .../frm-typography-component.css | 167 +- js/welcome-tour.js | 4438 +----- 23 files changed, 29 insertions(+), 68038 deletions(-) diff --git a/css/admin/frm-settings-components.css b/css/admin/frm-settings-components.css index c2a027558e..460b746c3a 100644 --- a/css/admin/frm-settings-components.css +++ b/css/admin/frm-settings-components.css @@ -1,626 +1 @@ -/*!***********************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/admin/frm-settings-components.scss ***! - \***********************************************************************************************************************************************************************************************************************************************/ -/** - * Formidable Forms settings components styles - */ -/** - * Accordion settings component styles - */ -.formidable_page_formidable-styles.js .control-section .accordion-section-title:focus { - background: none; -} -.formidable_page_formidable-styles .frm-right-panel h3.accordion-section-title:hover > svg:last-child, -.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title > svg:first-child, -.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title > svg:last-child { - color: var(--grey-900); -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component { - align-self: center; -} - -/** - * Color picker component styles - */ -.frm_settings_form .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button, -.formidable_page_formidable-styles .frm-right-panel .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button { - background-color: #fff !important; -} -.frm_settings_form .frm-style-component .wp-picker-container button, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container button { - position: relative; - height: 36px !important; - background-image: none !important; - overflow: hidden; - background-color: #fff !important; -} -.frm_settings_form .frm-style-component .wp-picker-container::after, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container::after { - content: ""; - width: 20px; - height: 20px; - display: block; - position: absolute; - top: 0; - right: 8px; - bottom: 0; - margin: auto; - background: url("../../images/style/small-arrow.svg") no-repeat; - background-position: center; - z-index: 10; -} -.frm_settings_form .frm-style-component .wp-color-result-text, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-color-result-text { - line-height: 36px !important; - padding: 0 12px; - border: 0; -} -.frm_settings_form .frm-style-component .color-alpha, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component .color-alpha { - width: 20px !important; - height: 20px !important; - border-radius: 50% !important; - border: 1px solid rgb(208, 213, 221); - top: 0; - left: 0; - bottom: 0; - margin: auto; - margin-left: 12px; -} -.frm_settings_form .frm-style-component .wp-picker-input-wrap input, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-input-wrap input { - width: calc(100% - 10px) !important; - margin: 1px 5px; - height: 32px; - line-height: 32px; -} - -/** - * Background image component styles - */ -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component > div { - max-width: 216px; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .wp-picker-container { - max-width: calc(100% - 44px); - position: relative; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component button.frm_choose_image_box { - width: 36px; - height: 36px; - padding: 0; - background: white; - overflow: hidden; - text-indent: -999px; - flex-wrap: wrap; - border: none; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_styling_frame { - margin-left: 0; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper { - position: relative; - width: 36px; - height: 36px; - margin: 0; - border: 1px solid var(--grey-300); - border-radius: var(--small-radius); - overflow: hidden; - box-sizing: border-box; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame { - max-width: 120%; - height: 120%; - margin: -10%; - position: relative; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_data { - position: absolute; - left: 0; - top: 0; - width: 100%; - height: 100%; - overflow: hidden; - margin: 0; - border-radius: var(--small-radius); -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option { - width: 100%; - height: 100%; - border: 1px solid var(--red-500); - text-indent: -9999px; - position: absolute; - top: 0; - left: 0; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::before { - opacity: 0; - content: ""; - display: block; - position: absolute; - width: 100%; - height: 100%; - z-index: 1; - top: 0; - left: 0; - background: rgba(255, 255, 255, 0.8); -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::after { - opacity: 0; - content: ""; - display: block; - position: absolute; - width: 100%; - height: 100%; - z-index: 1; - top: 0; - left: 0; - background: url("../../images/style/close.svg") no-repeat; - background-position: center; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::before, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::after { - opacity: 1; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame img { - width: 100%; - height: 100%; -} -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper + *, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_title, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_bg_image_additional_settings, -.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option * { - display: none; -} - -/** - * Radio buttons component styles - */ -.frm-style-component .frm-radio-container { - max-width: 216px; - height: 36px; - background: rgb(242, 244, 247); - gap: var(--small-gap); - padding: var(--gap-2xs); - box-sizing: border-box; - border-radius: var(--small-radius); - position: relative; -} -.frm-style-component.frm-field-shape .frm-radio-container { - max-width: unset; -} -.frm-style-component.frm-direction-component .frm-radio-container { - gap: var(--gap-xs); -} -.frm-style-component .frm-radio-container svg { - width: 16px; -} -.frm-style-component .frm-radio-container .frm-radio-active-tracker { - display: block; - width: 28%; - height: calc(100% - 8px); - background: white; - border-radius: var(--small-radius); - box-shadow: var(--button-shadow); - position: absolute; - top: var(--gap-2xs); - bottom: 0; - left: var(--gap-2xs); - z-index: 1; - transition: 0.35s transform cubic-bezier(0.075, 0.82, 0.165, 1); -} -.frm-style-component.frm-field-shape .frm-radio-container .frm-radio-active-tracker { - width: 23%; -} -.frm-style-component.frm-align-component.frm-2-options .frm-radio-container .frm-radio-active-tracker, .frm-style-component.frm-direction-component .frm-radio-container .frm-radio-active-tracker, .frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker { - width: calc(50% - var(--gap-xs)); -} -.frm-style-component .frm-radio-container > label { - width: 30%; - height: 100%; - margin: 0; - cursor: pointer; - position: relative; - display: flex; - z-index: 2; -} -.frm-style-component.frm-field-shape .frm-radio-container > label { - width: 23%; -} -.frm-style-component.frm-align-component.frm-2-options .frm-radio-container > label, .frm-style-component.frm-direction-component .frm-radio-container > label, .frm-style-component.frm-text-toggle-component .frm-radio-container > label { - width: 50%; -} -.frm-style-component.frm-text-toggle-component .frm-radio-container { - height: 44px; - max-width: unset; - gap: var(--gap-xs); - padding: var(--gap-xs); -} -.frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker { - height: calc(100% - var(--gap-sm)); - top: var(--gap-xs); -} - -.frm-style-tabs-wrapper .frm-tabs-navs ul > li:not(.frm-active):hover, -.frm-style-component .frm-radio-container input:not(:checked) + label:hover { - background: rgb(234, 236, 240); - border-radius: var(--small-radius); - box-shadow: var(--button-shadow); -} - -.frm-style-component .frm-radio-container input { - display: none; -} - -/** - * Sliders component styles - */ -.frm-style-component .frm-slider-container { - width: calc(100% - 91px); - display: flex; - align-items: center; - color: rgb(29, 41, 57); -} -.frm-style-component .frm-slider-container svg.frmsvg { - color: currentColor; - margin-right: 8px; - margin-left: -5px; - position: relative; - z-index: 15; -} - -.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover { - color: rgb(65, 153, 253); - cursor: pointer; -} - -.frm-style-component .frm-slider-container .frm-slider-active-track { - display: block; - height: 100%; - width: 0; - position: relative; - border-radius: 200px; -} -.frm-style-component .frm-slider-container .frm-slider-active-track, -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { - background: rgb(65, 153, 253); - box-shadow: 0 1.88px 4px -1px rgba(16, 24, 40, 0.03), 0 6px 8px -2px rgba(16, 24, 40, 0.08); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { - position: absolute; - display: block; - width: 16px; - height: 16px; - border-radius: 50%; - transform: translateX(15px); - cursor: grab; - right: 0; - top: 0; - bottom: 0; - margin: auto; -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label { - position: absolute; - display: block; - width: 48px; - height: 36px; - background: rgb(16, 24, 40); - color: white; - font-weight: 400; - font-size: var(--text-sm); - line-height: 36px; - border-radius: var(--small-radius); - transform: translate(-18px, -42px) scale3d(0.7, 1, 1); - opacity: 0; - z-index: -2; - pointer-events: none; - text-align: center; - user-select: none; -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label { - z-index: 12; - transform: translate(-18px, -42px) scale3d(1, 1, 1); - opacity: 1; - transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before { - content: ""; - display: block; - position: absolute; - width: 18px; - height: 18px; - border-radius: 50%; - left: 0; - top: 0; - transform: translate(-5px, -5px) scale3d(0.7, 0.7, 1); - border: 4px solid rgb(65, 153, 253); - opacity: 0; - transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before { - opacity: 0.5; - transform: translate(-5px, -5px) scale3d(1, 1, 1); - transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after { - content: ""; - position: absolute; - display: block; - width: 180%; - height: 200%; - border-radius: 50%; - left: 0; - top: 0; - transform: translate(-24%, -24%); -} - -.frm-style-component .frm-slider-value { - width: 86px; - height: 36px; - display: flex; - justify-content: center; - box-sizing: border-box; - background: white; - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); -} -.frm-style-component .frm-slider-value > * { - border: none; -} -.frm-style-component .frm-slider-value input { - width: 40px; - height: 100%; - padding: 0; - font-size: var(--text-sm); - color: rgb(16, 24, 40); - padding-left: 12px; - box-sizing: border-box; -} -.frm-style-component .frm-slider-value select { - text-align: right; - padding: 0; - font-size: var(--text-sm); - color: rgb(102, 112, 133); - width: 44px; - background: url("../../images/style/small-arrow.svg") no-repeat; - background-position: center right 12px; - padding-right: 24px !important; -} -.frm-style-component .frm-slider-value select.frm-single-unit { - pointer-events: none; - background-image: none; - padding-right: 12px !important; -} -.frm-style-component .frm-slider { - display: block; - width: calc(100% - 5px); - height: 4px; - background: rgb(234, 236, 240); - border-radius: 200px; - cursor: pointer; -} - -.frm-slider-component .frm-independent-slider-field { - margin-top: 10px; -} -.frm-slider-component.frm-disabled .frm-slider-container { - pointer-events: none; - opacity: 0.5; -} -.frm-slider-component.frm-disabled .frm-slider-value input[type=text] { - width: 28px; -} -.frm-slider-component.frm-disabled .frm-slider-value select { - width: 56px; -} -.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text] { - width: 56px; -} -.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select { - width: 28px; -} - -.frm-style-component .frm-slider-component.frm-has-multiple-values { - margin-bottom: 10px; -} - -/** - * Tabs component styles - */ -.frm-tabs-wrapper { - position: relative; - overflow: hidden; -} -.frm-tabs-wrapper .frm-tabs-navigator { - margin: 0; - padding: 0; - display: flex; - gap: var(--gap-xs); - justify-content: space-between; - align-items: center; - background: rgb(242, 244, 247); - border-radius: var(--small-radius); - box-sizing: border-box; - height: 44px; - position: relative; - z-index: 2; -} -.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item { - flex: 1; - text-align: center; - cursor: pointer; -} -.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background { - display: block; - height: 100%; - background: white; - position: absolute; - top: 0; - left: 0; - z-index: 1; -} - -.frm-style-tabs-wrapper { - position: relative; -} -.frm-style-tabs-wrapper .frm-tabs-navs { - padding: 0; - min-height: 44px; -} -.frm-style-tabs-wrapper .frm-tabs-navs ul { - margin: 0; - height: var(--h-md); - position: relative; - justify-content: space-between; -} -.frm-style-tabs-wrapper .frm-tabs-navs ul li, -.frm-style-tabs-wrapper .frm-tabs-navs ul li a { - color: var(--grey-500); - font-weight: 500; - font-size: var(--text-sm); - line-height: 28px; -} -.frm-style-tabs-wrapper .frm-tabs-navs ul li { - flex: 1; - height: 28px; - text-align: center; - margin-top: var(--gap-xs); - margin-bottom: 0; - cursor: pointer; -} -.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active, .frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a { - color: var(--grey-900); -} -.frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child { - margin-left: var(--gap-xs); -} -.frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child { - margin-right: var(--gap-xs); -} -.frm-style-tabs-wrapper .frm-tabs-delimiter { - position: absolute; - top: 0; - left: 0; - width: 100%; - background: rgb(242, 244, 247); - height: 44px; - margin: 0; - border-radius: var(--small-radius); -} -.frm-style-tabs-wrapper .frm-tabs-delimiter .frm-tabs-active-underline { - height: 28px; - background: white; - position: absolute; - left: 0; - bottom: 8px; - transition: 0.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); - border-radius: var(--small-radius); - box-shadow: var(--button-shadow); - display: none; -} - -.frm-tabs-container { - position: relative; - overflow: hidden; - margin-top: var(--gap-md); - height: 100%; -} - -.frm-style-tabs-wrapper .frm-tabs-container .frm-tabs-slide-track { - transition: 0.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-tabs-wrapper .frm-tabs-slide-track > div { - flex: 0 0 100%; - opacity: 0; - transition: 0.25s opacity linear; - position: relative; - height: auto; - max-height: unset; - overflow: hidden; - box-sizing: border-box; -} -.frm-style-tabs-wrapper .frm-tabs-slide-track > div > div { - overflow: auto; - position: relative; - width: 100%; - padding: 0; - box-sizing: border-box; -} - -.frm-tabs-slide-track > div > div:first-child { - height: 100%; -} -.frm-tabs-slide-track > div.frm-active { - opacity: 1; - transition: 0.35s opacity linear; -} - -/** - * Miscellaneous settings component styles - */ -.frm-style-component .frm_toggle_slider { - background: rgb(242, 244, 247); -} - -.frm-style-component label.frm-copy-text { - line-height: 32px; - cursor: pointer; - white-space: nowrap; -} - -.frm-style-component .wp-picker-holder { - right: 0; -} - -.frm-style-component .CodeMirror { - min-height: unset !important; - height: 350px !important; -} -.frm-style-component .CodeMirror .CodeMirror-placeholder { - color: var(--grey-400); -} - -.formidable_page_formidable-styles .accordion-section-content .frm-style-item-heading { - font-weight: 500; - font-size: var(--text-md); - color: var(--grey-900); -} - -.frm-unit-input { - position: relative; - display: flex; - align-items: center; -} -.frm-unit-input input[type=number]::-webkit-outer-spin-button, -.frm-unit-input input[type=number]::-webkit-inner-spin-button { - -webkit-appearance: none; - appearance: none; -} -.frm-unit-input .frm-input-group-suffix { - position: absolute; - top: 1px; - right: 1px; - display: flex; - align-items: center; - height: calc(100% - 2px); - padding-right: var(--gap-xs); -} -.frm-unit-input .frm-input-group-suffix select { - width: fit-content; - height: 100%; - min-height: unset; - font-size: var(--text-sm); - text-align: right; - color: var(--grey-500) !important; - background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%23667085' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 0 top 50%; - padding-left: var(--gap-2xs); - padding-right: 21px !important; - border: transparent; -} -.frm-unit-input .frm-input-group-suffix select:focus-visible { - outline: 1px solid var(--primary-500); - outline-offset: -2px; -} - -/*# sourceMappingURL=frm-settings-components.css.map*/ \ No newline at end of file +.formidable_page_formidable-styles.js .control-section .accordion-section-title:focus{background:none}.formidable_page_formidable-styles .frm-right-panel h3.accordion-section-title:hover>svg:last-child,.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title>svg:first-child,.formidable_page_formidable-styles .frm-right-panel .open h3.accordion-section-title>svg:last-child{color:var(--grey-900)}.formidable_page_formidable-styles .frm-right-panel .frm-style-component{align-self:center}.frm_settings_form .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button,.formidable_page_formidable-styles .frm-right-panel .frm-style-editor-form.frm-pro .frm-style-component .wp-picker-container button{background-color:#fff !important}.frm_settings_form .frm-style-component .wp-picker-container button,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container button{position:relative;height:36px !important;background-image:none !important;overflow:hidden;background-color:#fff !important}.frm_settings_form .frm-style-component .wp-picker-container::after,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-container::after{content:"";width:20px;height:20px;display:block;position:absolute;top:0;right:8px;bottom:0;margin:auto;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center;z-index:10}.frm_settings_form .frm-style-component .wp-color-result-text,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-color-result-text{line-height:36px !important;padding:0 12px;border:0}.frm_settings_form .frm-style-component .color-alpha,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .color-alpha{width:20px !important;height:20px !important;border-radius:50% !important;border:1px solid #d0d5dd;top:0;left:0;bottom:0;margin:auto;margin-left:12px}.frm_settings_form .frm-style-component .wp-picker-input-wrap input,.formidable_page_formidable-styles .frm-right-panel .frm-style-component .wp-picker-input-wrap input{width:calc(100% - 10px) !important;margin:1px 5px;height:32px;line-height:32px}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component>div{max-width:216px}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .wp-picker-container{max-width:calc(100% - 44px);position:relative}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component button.frm_choose_image_box{width:36px;height:36px;padding:0;background:#fff;overflow:hidden;text-indent:-999px;flex-wrap:wrap;border:none}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_styling_frame{margin-left:0}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper{position:relative;width:36px;height:36px;margin:0;border:1px solid var(--grey-300);border-radius:var(--small-radius);overflow:hidden;box-sizing:border-box}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame{max-width:120%;height:120%;margin:-10%;position:relative}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_data{position:absolute;left:0;top:0;width:100%;height:100%;overflow:hidden;margin:0;border-radius:var(--small-radius)}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option{width:100%;height:100%;border:1px solid var(--red-500);text-indent:-9999px;position:absolute;top:0;left:0}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::before{opacity:0;content:"";display:block;position:absolute;width:100%;height:100%;z-index:1;top:0;left:0;background:rgba(255,255,255,.8)}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option::after{opacity:0;content:"";display:block;position:absolute;width:100%;height:100%;z-index:1;top:0;left:0;background:url("../../images/style/close.svg") no-repeat;background-position:center}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::before,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option:hover::after{opacity:1}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_frame .frm_image_styling_frame img{width:100%;height:100%}.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper+*,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_image_preview_wrapper .frm_image_preview_title,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_bg_image_additional_settings,.formidable_page_formidable-styles .frm-right-panel .frm-style-component.frm-background-image-component .frm_remove_image_option *{display:none}.frm-style-component .frm-radio-container{max-width:216px;height:36px;background:#f2f4f7;gap:var(--small-gap);padding:var(--gap-2xs);box-sizing:border-box;border-radius:var(--small-radius);position:relative}.frm-style-component.frm-field-shape .frm-radio-container{max-width:unset}.frm-style-component.frm-direction-component .frm-radio-container{gap:var(--gap-xs)}.frm-style-component .frm-radio-container svg{width:16px}.frm-style-component .frm-radio-container .frm-radio-active-tracker{display:block;width:28%;height:calc(100% - 8px);background:#fff;border-radius:var(--small-radius);box-shadow:var(--button-shadow);position:absolute;top:var(--gap-2xs);bottom:0;left:var(--gap-2xs);z-index:1;transition:.35s transform cubic-bezier(0.075, 0.82, 0.165, 1)}.frm-style-component.frm-field-shape .frm-radio-container .frm-radio-active-tracker{width:23%}.frm-style-component.frm-align-component.frm-2-options .frm-radio-container .frm-radio-active-tracker,.frm-style-component.frm-direction-component .frm-radio-container .frm-radio-active-tracker,.frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker{width:calc(50% - var(--gap-xs))}.frm-style-component .frm-radio-container>label{width:30%;height:100%;margin:0;cursor:pointer;position:relative;display:flex;z-index:2}.frm-style-component.frm-field-shape .frm-radio-container>label{width:23%}.frm-style-component.frm-align-component.frm-2-options .frm-radio-container>label,.frm-style-component.frm-direction-component .frm-radio-container>label,.frm-style-component.frm-text-toggle-component .frm-radio-container>label{width:50%}.frm-style-component.frm-text-toggle-component .frm-radio-container{height:44px;max-width:unset;gap:var(--gap-xs);padding:var(--gap-xs)}.frm-style-component.frm-text-toggle-component .frm-radio-container .frm-radio-active-tracker{height:calc(100% - var(--gap-sm));top:var(--gap-xs)}.frm-style-tabs-wrapper .frm-tabs-navs ul>li:not(.frm-active):hover,.frm-style-component .frm-radio-container input:not(:checked)+label:hover{background:#eaecf0;border-radius:var(--small-radius);box-shadow:var(--button-shadow)}.frm-style-component .frm-radio-container input{display:none}.frm-style-component .frm-slider-container{width:calc(100% - 91px);display:flex;align-items:center;color:#1d2939}.frm-style-component .frm-slider-container svg.frmsvg{color:currentColor;margin-right:8px;margin-left:-5px;position:relative;z-index:15}.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover{color:#4199fd;cursor:pointer}.frm-style-component .frm-slider-container .frm-slider-active-track{display:block;height:100%;width:0;position:relative;border-radius:200px}.frm-style-component .frm-slider-container .frm-slider-active-track,.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{background:#4199fd;box-shadow:0 1.88px 4px -1px rgba(16,24,40,.03),0 6px 8px -2px rgba(16,24,40,.08)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{position:absolute;display:block;width:16px;height:16px;border-radius:50%;transform:translateX(15px);cursor:grab;right:0;top:0;bottom:0;margin:auto}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label{position:absolute;display:block;width:48px;height:36px;background:#101828;color:#fff;font-weight:400;font-size:var(--text-sm);line-height:36px;border-radius:var(--small-radius);transform:translate(-18px, -42px) scale3d(0.7, 1, 1);opacity:0;z-index:-2;pointer-events:none;text-align:center;user-select:none}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label{z-index:12;transform:translate(-18px, -42px) scale3d(1, 1, 1);opacity:1;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before{content:"";display:block;position:absolute;width:18px;height:18px;border-radius:50%;left:0;top:0;transform:translate(-5px, -5px) scale3d(0.7, 0.7, 1);border:4px solid #4199fd;opacity:0;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before{opacity:.5;transform:translate(-5px, -5px) scale3d(1, 1, 1);transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after{content:"";position:absolute;display:block;width:180%;height:200%;border-radius:50%;left:0;top:0;transform:translate(-24%, -24%)}.frm-style-component .frm-slider-value{width:86px;height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300)}.frm-style-component .frm-slider-value>*{border:none}.frm-style-component .frm-slider-value input{width:40px;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-style-component .frm-slider-value select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px;padding-right:24px !important}.frm-style-component .frm-slider-value select.frm-single-unit{pointer-events:none;background-image:none;padding-right:12px !important}.frm-style-component .frm-slider{display:block;width:calc(100% - 5px);height:4px;background:#eaecf0;border-radius:200px;cursor:pointer}.frm-slider-component .frm-independent-slider-field{margin-top:10px}.frm-slider-component.frm-disabled .frm-slider-container{pointer-events:none;opacity:.5}.frm-slider-component.frm-disabled .frm-slider-value input[type=text]{width:28px}.frm-slider-component.frm-disabled .frm-slider-value select{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text]{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select{width:28px}.frm-style-component .frm-slider-component.frm-has-multiple-values{margin-bottom:10px}.frm-tabs-wrapper{position:relative;overflow:hidden}.frm-tabs-wrapper .frm-tabs-navigator{margin:0;padding:0;display:flex;gap:var(--gap-xs);justify-content:space-between;align-items:center;background:#f2f4f7;border-radius:var(--small-radius);box-sizing:border-box;height:44px;position:relative;z-index:2}.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item{flex:1;text-align:center;cursor:pointer}.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background{display:block;height:100%;background:#fff;position:absolute;top:0;left:0;z-index:1}.frm-style-tabs-wrapper{position:relative}.frm-style-tabs-wrapper .frm-tabs-navs{padding:0;min-height:44px}.frm-style-tabs-wrapper .frm-tabs-navs ul{margin:0;height:var(--h-md);position:relative;justify-content:space-between}.frm-style-tabs-wrapper .frm-tabs-navs ul li,.frm-style-tabs-wrapper .frm-tabs-navs ul li a{color:var(--grey-500);font-weight:500;font-size:var(--text-sm);line-height:28px}.frm-style-tabs-wrapper .frm-tabs-navs ul li{flex:1;height:28px;text-align:center;margin-top:var(--gap-xs);margin-bottom:0;cursor:pointer}.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active,.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a{color:var(--grey-900)}.frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child{margin-left:var(--gap-xs)}.frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child{margin-right:var(--gap-xs)}.frm-style-tabs-wrapper .frm-tabs-delimiter{position:absolute;top:0;left:0;width:100%;background:#f2f4f7;height:44px;margin:0;border-radius:var(--small-radius)}.frm-style-tabs-wrapper .frm-tabs-delimiter .frm-tabs-active-underline{height:28px;background:#fff;position:absolute;left:0;bottom:8px;transition:.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);border-radius:var(--small-radius);box-shadow:var(--button-shadow);display:none}.frm-tabs-container{position:relative;overflow:hidden;margin-top:var(--gap-md);height:100%}.frm-style-tabs-wrapper .frm-tabs-container .frm-tabs-slide-track{transition:.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-tabs-wrapper .frm-tabs-slide-track>div{flex:0 0 100%;opacity:0;transition:.25s opacity linear;position:relative;height:auto;max-height:unset;overflow:hidden;box-sizing:border-box}.frm-style-tabs-wrapper .frm-tabs-slide-track>div>div{overflow:auto;position:relative;width:100%;padding:0;box-sizing:border-box}.frm-tabs-slide-track>div>div:first-child{height:100%}.frm-tabs-slide-track>div.frm-active{opacity:1;transition:.35s opacity linear}.frm-style-component .frm_toggle_slider{background:#f2f4f7}.frm-style-component label.frm-copy-text{line-height:32px;cursor:pointer;white-space:nowrap}.frm-style-component .wp-picker-holder{right:0}.frm-style-component .CodeMirror{min-height:unset !important;height:350px !important}.frm-style-component .CodeMirror .CodeMirror-placeholder{color:var(--grey-400)}.formidable_page_formidable-styles .accordion-section-content .frm-style-item-heading{font-weight:500;font-size:var(--text-md);color:var(--grey-900)}.frm-unit-input{position:relative;display:flex;align-items:center}.frm-unit-input input[type=number]::-webkit-outer-spin-button,.frm-unit-input input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none}.frm-unit-input .frm-input-group-suffix{position:absolute;top:1px;right:1px;display:flex;align-items:center;height:calc(100% - 2px);padding-right:var(--gap-xs)}.frm-unit-input .frm-input-group-suffix select{width:fit-content;height:100%;min-height:unset;font-size:var(--text-sm);text-align:right;color:var(--grey-500) !important;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%23667085' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 0 top 50%;padding-left:var(--gap-2xs);padding-right:21px !important;border:rgba(0,0,0,0)}.frm-unit-input .frm-input-group-suffix select:focus-visible{outline:1px solid var(--primary-500);outline-offset:-2px} diff --git a/css/admin/welcome-tour.css b/css/admin/welcome-tour.css index 306d2df092..6b3f3cf0fc 100644 --- a/css/admin/welcome-tour.css +++ b/css/admin/welcome-tour.css @@ -1,152 +1 @@ -/*!************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/admin/welcome-tour.scss ***! - \************************************************************************************************************************************************************************************************************************************/ -.frm-checklist { - width: 316px; - height: 400px; - overflow: hidden; -} -.frm-checklist, -.frm-checklist *, -.frm-checklist *::before, -.frm-checklist *::after { - box-sizing: border-box; -} -.frm-checklist p, -.frm-checklist span { - font-size: var(--text-xs); -} -.frm-checklist__header .frmsvg { - transition: transform 200ms ease-out 50ms; -} -.frm-checklist__progress-bar { - height: 8px; -} -.frm-checklist__progress-fill { - width: 0; -} -.frm-checklist__dismiss { - height: 50px; - border-top: 1px solid var(--grey-100) !important; - cursor: pointer; - transition: height 150ms cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-checklist__dismiss > span { - transition: color 150ms ease-out; -} -.frm-checklist__dismiss:hover > span { - color: var(--grey-600) !important; -} -.frm-checklist__completed { - height: 100%; -} -.frm-checklist__completed p { - color: var(--grey-800); - margin: 0; -} -.frm-checklist__step-status { - height: 16px; - width: 16px; - border-radius: 50%; - border: 1.5px dashed var(--grey-400); -} -.frm-checklist__step-description { - background-color: var(--grey-50); - border-radius: var(--small-radius); - line-height: var(--leading); - display: none; -} -.frm-checklist__step--active .frm-checklist__step-title, -.frm-checklist__step--active .frm-checklist__step-title a { - font-weight: 600; - color: var(--grey-800); -} -.frm-checklist__step--active .frm-checklist__step-description { - display: block; -} -.frm-checklist__step--completed .frm-checklist__step-status { - background-color: var(--success-500); - border-style: solid; - border-color: var(--success-500); -} -.frm-checklist--collapsed { - height: auto; -} -.frm-checklist--collapsed .frm-checklist__steps { - display: none; -} -.frm-checklist--collapsed .frm-checklist__dismiss { - height: 0; - overflow: hidden; -} -.frm-checklist--collapsed .frm-checklist__header .frmsvg { - transform: rotate(-180deg); -} - -.frm-spotlight { - --fadeout-time: 25ms; - position: fixed; - cursor: default; -} -.frm-spotlight[data-placement=right] { - transform: translateY(-50%); -} -.frm-spotlight[data-placement=bottom] { - transform: translateX(-50%); -} -.frm-spotlight > * { - flex: 0 0 auto; -} -.frm-spotlight__content { - position: relative; - box-sizing: border-box; - flex-shrink: 0; - width: 242px; - border: 1px solid var(--grey-200); - overflow: visible; -} -.frm-spotlight__content::after { - content: ""; - position: absolute; - width: 11px; - height: 11px; - background-color: inherit; - transform: translateY(-50%) rotate(45deg); - border-left: 1px solid var(--grey-200); - border-radius: 2px; -} -.frm-spotlight[data-placement=right] .frm-spotlight__content::after { - top: 50%; - left: -6px; - transform: translateY(-50%) rotate(45deg); - border-bottom: 1px solid var(--grey-200); -} -.frm-spotlight[data-placement=bottom] .frm-spotlight__content::after { - top: -6px; - left: 50%; - transform: translateX(-50%) rotate(45deg); - border-top: 1px solid var(--grey-200); -} -.frm-spotlight__pointer { - box-sizing: border-box; - width: 14px; - height: 14px; - background-color: var(--grey-600); - padding: 3px; - border-radius: 50%; -} -.frm-spotlight[data-placement=right] .frm-spotlight__pointer { - margin-right: var(--gap-2xs); -} -.frm-spotlight[data-placement=bottom] .frm-spotlight__pointer { - margin-bottom: var(--gap-2xs); -} - -.frm-welcome-tour .frm-checklist { - position: fixed; - right: var(--gap-md); - bottom: var(--gap-sm); - z-index: 9999; -} - -/*# sourceMappingURL=welcome-tour.css.map*/ \ No newline at end of file +.frm-checklist{width:316px;height:400px;overflow:hidden}.frm-checklist,.frm-checklist *,.frm-checklist *::before,.frm-checklist *::after{box-sizing:border-box}.frm-checklist p,.frm-checklist span{font-size:var(--text-xs)}.frm-checklist__header .frmsvg{transition:transform 200ms ease-out 50ms}.frm-checklist__progress-bar{height:8px}.frm-checklist__progress-fill{width:0}.frm-checklist__dismiss{height:50px;border-top:1px solid var(--grey-100) !important;cursor:pointer;transition:height 150ms cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-checklist__dismiss>span{transition:color 150ms ease-out}.frm-checklist__dismiss:hover>span{color:var(--grey-600) !important}.frm-checklist__completed{height:100%}.frm-checklist__completed p{color:var(--grey-800);margin:0}.frm-checklist__step-status{height:16px;width:16px;border-radius:50%;border:1.5px dashed var(--grey-400)}.frm-checklist__step-description{background-color:var(--grey-50);border-radius:var(--small-radius);line-height:var(--leading);display:none}.frm-checklist__step--active .frm-checklist__step-title,.frm-checklist__step--active .frm-checklist__step-title a{font-weight:600;color:var(--grey-800)}.frm-checklist__step--active .frm-checklist__step-description{display:block}.frm-checklist__step--completed .frm-checklist__step-status{background-color:var(--success-500);border-style:solid;border-color:var(--success-500)}.frm-checklist--collapsed{height:auto}.frm-checklist--collapsed .frm-checklist__steps{display:none}.frm-checklist--collapsed .frm-checklist__dismiss{height:0;overflow:hidden}.frm-checklist--collapsed .frm-checklist__header .frmsvg{transform:rotate(-180deg)}.frm-spotlight{--fadeout-time: 25ms;position:fixed;cursor:default}.frm-spotlight[data-placement=right]{transform:translateY(-50%)}.frm-spotlight[data-placement=bottom]{transform:translateX(-50%)}.frm-spotlight>*{flex:0 0 auto}.frm-spotlight__content{position:relative;box-sizing:border-box;flex-shrink:0;width:242px;border:1px solid var(--grey-200);overflow:visible}.frm-spotlight__content::after{content:"";position:absolute;width:11px;height:11px;background-color:inherit;transform:translateY(-50%) rotate(45deg);border-left:1px solid var(--grey-200);border-radius:2px}.frm-spotlight[data-placement=right] .frm-spotlight__content::after{top:50%;left:-6px;transform:translateY(-50%) rotate(45deg);border-bottom:1px solid var(--grey-200)}.frm-spotlight[data-placement=bottom] .frm-spotlight__content::after{top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);border-top:1px solid var(--grey-200)}.frm-spotlight__pointer{box-sizing:border-box;width:14px;height:14px;background-color:var(--grey-600);padding:3px;border-radius:50%}.frm-spotlight[data-placement=right] .frm-spotlight__pointer{margin-right:var(--gap-2xs)}.frm-spotlight[data-placement=bottom] .frm-spotlight__pointer{margin-bottom:var(--gap-2xs)}.frm-welcome-tour .frm-checklist{position:fixed;right:var(--gap-md);bottom:var(--gap-sm);z-index:9999} diff --git a/css/font_icons.css b/css/font_icons.css index b567c55fa0..0a2a2f899a 100644 --- a/css/font_icons.css +++ b/css/font_icons.css @@ -1,88 +1 @@ -/*!****************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/font_icons.scss ***! - \****************************************************************************************************************************************************************************************************************************/ -/** - * Font Icons - */ -@font-face { - font-family: "s11-fp"; - src: url("../fonts/s11-fp.woff?v=7") format("woff"); - font-weight: 400; - font-style: normal; -} -.frm-submenu-highlight { - background: #1da867; -} - -.frm-submenu-highlight a span { - color: #fff; - font-weight: 600; -} - -.frmfont, -.frm_icon_font { - text-decoration: none; - text-shadow: none; - font-weight: 400; - display: inline-block; - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - text-rendering: auto; - line-height: 1.5; - transition: color 0.1s ease-in-out, opacity 0.1s ease-in-out; - font-size: 18px; -} - -i.frmfont, -i.frm_icon_font { - font-style: normal; - font-variant: normal; - speak: none; -} - -.frmfont::before, -select.frmfont, -.frm_icon_font::before, -select.frm_icon_font { - font-family: "s11-fp" !important; - text-align: center; -} - -.frmfont, -a.frmfont, -.frmfont:hover, -a.frmfont:hover .frm_icon_font, -a.frm_icon_font, -.frm_icon_font:hover, -a.frm_icon_font:hover { - text-decoration: none !important; - box-shadow: none; -} - -.frmfont:focus, -.frm_icon_font:focus { - box-shadow: none; -} - -.frmfont:active, -.frm_icon_font:active { - outline: none; -} - -.frm_trigger .frm_icon_font { - padding: 0 5px; -} - -.frm_tooltip_icon::before { - content: "\e611"; -} - -.frm_delete_icon::before { - content: "\e610" !important; -} - -.frm_arrowdown6_icon::before { - content: "\e62a"; -} - -/*# sourceMappingURL=font_icons.css.map*/ \ No newline at end of file +@font-face{font-family:"s11-fp";src:url("../fonts/s11-fp.woff?v=7") format("woff");font-weight:400;font-style:normal}.frm-submenu-highlight{background:#1da867}.frm-submenu-highlight a span{color:#fff;font-weight:600}.frmfont,.frm_icon_font{text-decoration:none;text-shadow:none;font-weight:400;display:inline-block;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:auto;line-height:1.5;transition:color .1s ease-in-out,opacity .1s ease-in-out;font-size:18px}i.frmfont,i.frm_icon_font{font-style:normal;font-variant:normal;speak:none}.frmfont::before,select.frmfont,.frm_icon_font::before,select.frm_icon_font{font-family:"s11-fp" !important;text-align:center}.frmfont,a.frmfont,.frmfont:hover,a.frmfont:hover .frm_icon_font,a.frm_icon_font,.frm_icon_font:hover,a.frm_icon_font:hover{text-decoration:none !important;box-shadow:none}.frmfont:focus,.frm_icon_font:focus{box-shadow:none}.frmfont:active,.frm_icon_font:active{outline:none}.frm_trigger .frm_icon_font{padding:0 5px}.frm_tooltip_icon::before{content:"\e611"}.frm_delete_icon::before{content:"\e610" !important}.frm_arrowdown6_icon::before{content:"\e62a"} diff --git a/css/frm_admin.css b/css/frm_admin.css index b62f9367d2..5e6551eaf3 100644 --- a/css/frm_admin.css +++ b/css/frm_admin.css @@ -1,11945 +1,3 @@ -/*!*********************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/admin/frm_admin.scss ***! - \*********************************************************************************************************************************************************************************************************************************/ -@charset "UTF-8"; -/** - * Formidable Admin Styles - * - * Note: Do not modify the import order unless the change is part of a deliberate refactor. - */ -/** - * Base & Foundation - * - * Core variables, typography, and essential base styles - */ -/** - * Font Icons - */ -@font-face { - font-family: "s11-fp"; - src: url("../fonts/s11-fp.woff?v=7") format("woff"); - font-weight: 400; - font-style: normal; -} -.frm-submenu-highlight { - background: #1da867; -} - -.frm-submenu-highlight a span { - color: #fff; - font-weight: 600; -} - -.frmfont, -.frm_icon_font { - text-decoration: none; - text-shadow: none; - font-weight: 400; - display: inline-block; - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - text-rendering: auto; - line-height: 1.5; - transition: color 0.1s ease-in-out, opacity 0.1s ease-in-out; - font-size: 18px; -} - -i.frmfont, -i.frm_icon_font { - font-style: normal; - font-variant: normal; - speak: none; -} - -.frmfont::before, -select.frmfont, -.frm_icon_font::before, -select.frm_icon_font { - font-family: "s11-fp" !important; - text-align: center; -} - -.frmfont, -a.frmfont, -.frmfont:hover, -a.frmfont:hover .frm_icon_font, -a.frm_icon_font, -.frm_icon_font:hover, -a.frm_icon_font:hover { - text-decoration: none !important; - box-shadow: none; -} - -.frmfont:focus, -.frm_icon_font:focus { - box-shadow: none; -} - -.frmfont:active, -.frm_icon_font:active { - outline: none; -} - -.frm_trigger .frm_icon_font { - padding: 0 5px; -} - -.frm_tooltip_icon::before { - content: "\e611"; -} - -.frm_delete_icon::before { - content: "\e610" !important; -} - -.frm_arrowdown6_icon::before { - content: "\e62a"; -} - -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -/** - * Base - Font - */ -@font-face { - font-family: "Inter"; - src: url("../fonts/Inter-VariableFont_slnt,wght.ttf?v=1") format("truetype"); -} -.with_frm_style, -.frm-white-body .wpbody-content, -.frm_wrap { - font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; -} - -/* Safari 11+ */ -@media not all and (min-resolution: 0.001dpcm) { - @supports (-webkit-appearance: none) and (stroke-color: transparent) { - .with_frm_style, -.frm-white-body .wpbody-content, -.frm_wrap { - -webkit-font-smoothing: antialiased; - } - } -} -/** - * Utilities - Z-index - */ -.frm-sm-z-index { - z-index: 1; -} - -.frm-md-z-index { - z-index: 5; -} - -/** - * Base - Text - */ -.frm-white-body, -.frm-white-body p, -.frm_wrap, -.frm_wrap p, -.frm-modal, -.frm-white-body .postbox .inside { - font-size: var(--text-sm); - color: var(--grey-500); - line-height: var(--leading); -} - -.frm-white-body p, -.frm_wrap p { - margin: var(--gap-sm) 0; -} - -body:not(.frm-admin-page-styles):not(.frm-admin-page-style) .with_frm_style .frm_form_fields > fieldset { - --fieldset-padding: 15px 0; -} - -a, -.widget .widget-top, -.stuffbox h3, -.frm-collapsed { - cursor: pointer; - text-decoration: none; -} - -/** - * Layout & Primary Components - * - * Core structure and primary UI elements - */ -/** - * Layout - Wrap - */ -.post-type-frm_display .wrap > #posts-filter, -.wrap.frm-with-margin, -.frm_wrap > .wrap { - margin: var(--gap-sm) var(--gap-md) var(--gap-md); -} - -#frm_top_bar + .wrap { - margin: var(--gap-xl); -} - -.frm-full-screen #wpbody-content > .wrap { - margin: 0; -} - -.post-type-frm_display .wrap { - margin: 0; -} - -.toplevel_page_formidable #post-body-content { - overflow-x: visible; -} - -/** - * Components - Full Screen - */ -.frm-full-screen { - height: 100%; - overflow: hidden; -} - -.frm-full-screen.frm-admin-page-reports, -.frm-full-screen.frm-admin-page-entries, -.frm-full-screen.post-type-frm_display { - overflow: auto; -} - -.frm-full-screen #wpadminbar, -.frm-full-screen #adminmenumain, -.frm-full-screen .wp-header-end { - display: none; -} - -body.frm-white-body:not(.frm-full-screen) .mce-fullscreen { - top: 32px; - left: 160px; -} - -.frm-full-screen #wpbody-content, -.frm-full-screen #wpbody, -.frm-full-screen #wpcontent { - padding: 0; - overflow: hidden; - margin: 0 !important; -} - -/** - * Layout - Screen Meta - */ -.frm-white-body #wpbody-content { - position: relative; /* For screen meta links */ - padding-bottom: 0; -} - -.post-new-php.post-type-frm_display #screen-meta-links, -.post-php.post-type-frm_display #screen-meta-links { - display: none; -} - -.frm-white-body #screen-meta-links { - position: fixed; - bottom: 0; - right: 20px; -} - -.frm-full-screen #screen-meta-links .screen-meta-toggle { - right: 55px; -} - -.frm-white-body #screen-meta-links .show-settings { - border-radius: var(--small-radius) var(--small-radius) 0 0; - border: 1px solid var(--grey-300); - border-bottom: none; -} - -.frm-white-body.frm-lite #screen-meta-links .screen-meta-toggle { - right: 125px; /* Don't cover the lite upgrade button */ -} - -.frm-white-body #screen-meta { - margin: 0; -} - -.frm-white-body #screen-meta-links .show-settings::after { - color: var(--grey); -} - -/** - * Layout - Columns - */ -.frm-white-body .columns-2 { - border-bottom: 1px solid var(--grey-300); -} - -.frm-full-screen .columns-2 { - border: none; -} - -/** - * Layout - Body - */ -body.post-type-frm_display.edit-php, -body.frm-white-body { - background: #fff; -} - -body.frm-white-body ul#adminmenu a.wp-has-current-submenu::after, -body.frm-white-body ul#adminmenu > li.current > a.current::after { - border-right-color: #fff; -} - -.frm-white-body #wpcontent { - padding-left: 0; - padding-right: 0; -} - -.frm-white-body .wrap #post-body { - padding: 0 20px; -} - -.frm-grey-body #wpbody { - background: var(--grey-100); -} - -.frm-grey-body #frm_top_bar { - background: #fff; -} - -/** - * Components - Table Nav - */ -.post-type-frm_display .tablenav, -.frm_wrap .tablenav { - margin-bottom: 10px; -} - -.frm-white-body .tablenav .actions select, -.wp-admin .frm_wrap .tablenav select { - margin-right: var(--gap-xs); -} - -.tablenav .actions .button { - margin-top: 1px; -} - -/** - * Components - Table Widefat - */ -.frm-white-body table.widefat { - background: var(--lightest-grey); - border-width: 0; - box-shadow: none; - margin: 20px 0; -} - -.frm-white-body table.widefat tfoot, -.frm-white-body table.widefat thead { - background: #fff; -} - -.frm-white-body table.widefat th { - font-size: var(--text-md); -} - -.frm-white-body table.widefat th a { - color: var(--grey-700); -} - -.frm-white-body table.widefat strong a { - color: var(--primary-700); -} - -/** - * Components - Scroll Box - */ -.frm-scroll-box { - clear: both; - overflow: auto; - max-height: 405px; - border: 1px solid var(--grey-300); - border-radius: var(--small-radius); -} - -.frm_form_field.frm_scroll_box .frm_opt_container { - height: 100px; - overflow: auto; - border: 1px solid var(--grey-300); -} - -.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden) + p, -.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden) + div, -.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden) + span { - grid-column: span 6/span 6; - align-content: center; -} - -.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden) + p, -.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden) + div, -.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden) + span { - grid-column: span 12/span 12 !important; - align-content: center; -} - -.frm_form_field.frm-phone-type ~ [id*=frm-field-format-custom-] > label, -.frm_form_field.frm-format-dropdown ~ [id*=frm-field-format-custom-] > label { - opacity: 0; /* Hide the label for the format input in the phone field. */ -} - -.frm_form_field.frm-format-dropdown ~ [id*=frm-field-format-custom-] { - grid-column: span 6/span 6; -} - -/* Adjust "CSS Layout Classes" to full width when the "Format" setting is present. */ -.frm-single-settings.frm-type-textarea > .frm_grid_container [id*=frm-field-format-custom-] + p { - grid-column: span 12/span 12; -} - -.frm-single-settings .frm_grid_container { - column-gap: var(--gap-sm); -} - -.frm-content-center { - align-content: center; -} - -.frm-self-end { - align-self: end; -} - -/** - * Components - Short List - */ -.frm-short-list { - overflow: auto; - max-height: 190px; -} - -/** - * Components - Table Elements - */ -.frm-white-body table.frm-border td { - font-size: var(--text-sm); -} - -.frm-white-body .striped > tbody > :nth-child(odd) { - background-color: #fff; -} - -.frm_wrap td.column-title strong { - display: inline; -} - -/** - * Layout - Top Bar - */ -#frm_top_bar { - display: flex; - gap: var(--gap-sm); - width: 100%; - height: 72px; - margin: 0; - box-sizing: border-box; - text-align: center; - padding: 0 var(--gap-md); -} - -#frm_top_bar > .frm-full-close:last-child, -#frm_top_bar > #frm-publishing:last-child { - margin-left: auto; -} - -#frm_top_bar { - border-bottom: 1px solid var(--grey-300); - padding: 0 var(--gap-md); - overflow: visible; -} - -/** - * Base - Headings - */ -.frm-white-body h1, -.frm-white-body h2, -.frm-white-body h3, -.frm-white-body h4 { - color: var(--grey-900); - font-weight: 400; - line-height: var(--leading) !important; -} - -.frm-white-body .wrap h1, -.frm-white-body h1 { - font-size: var(--text-xl); -} - -.frm-white-body .wrap h2, -.frm-white-body h2 { - font-size: var(--text-lg); - font-weight: 500; -} - -.frm-white-body .wrap h3, -.frm-white-body h3 { - font-size: var(--text-md); -} - -.frm-white-body .wrap h4, -.frm-white-body h4 { - font-size: var(--text-sm); - font-weight: 500; -} - -/** - * Components - Error Modal - */ -#frm_error_modal .frm_lock_simple { - padding: 20px; - border-radius: 50%; - background-color: var(--primary-25); - display: inline-block; -} - -#frm_error_modal #frm_lock_simple { - color: var(--primary-500); -} - -#frm_error_modal .frm-modal-title { - display: block; -} - -#frm_error_modal .frm-modal-title h2 { - font-weight: 600; - font-size: var(--text-xl); - margin: 0; -} - -#frm_error_modal .frm_modal_content { - padding: var(--gap-md); - color: var(--grey-900); -} - -/** - * Layout - Editor Overrides - */ -/* Override CSS in Views plugin. */ -.frm-views-editor-body .frm_page_container #frm_top_bar h1 { - padding: 0 !important; - color: var(--grey-900); - font-size: var(--text-xl) !important; -} - -.post-type-frm_display .frm_top_left { - padding-bottom: 0 !important; -} - -.frm-new-table-view-option.frm-selected-table-view-option { - border-radius: var(--small-radius); - background: var(--primary-25); -} - -.frm-views-editor-body #frm_adv_info .tabs-panel { /* Views sidebar */ - padding-left: 4px; - padding-right: 4px; -} - -#frm_edit_box_content_modal .frm_modal_footer { - padding-top: var(--gap-sm); - border-top: 1px solid var(--grey-300); -} - -#frm_edit_box_content_modal .frm_modal_footer > div { - display: flex; - justify-content: space-between; -} - -#frm_edit_box_content_modal #frm_modal_box_select_area, -#frm_edit_box_content_modal #frm_box_content_wysiwyg_wrapper, -#frm_edit_box_content_modal .frm_modal_content { - max-height: calc(100vh - 176px) !important; -} - -#frm_edit_box_content_modal #frm_modal_box_select_area { - height: calc(100vh - 176px) !important; -} - -#frm_edit_box_content_modal #wp-content-editor-tools { - padding-top: 0; -} - -#frm_edit_box_content_modal.frm-modal .postbox .frm-modal-title + div:last-child { - right: var(--gap-md); -} - -.frm_code_list.frm-full-hover .frm-dropdown-view a { - flex-direction: row-reverse; /* Switch in the HTML */ -} - -#frm_view_editor_left.frm-right-panel .accordion-section-title::before { - content: "" !important; - margin: 0; -} - -/** End Temporary View CSS */ -/** - * Components - Upgrade Bar - */ -.frm-gradient, -.frm-upgrade-bar { - background: linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important; - color: #fff !important; - border: 0 !important; -} - -.frm-gradient.frm-button-primary:not([disabled]), -.frm-gradient.frm-button-primary:not([disabled]):hover, -.frm-gradient.frm-button-primary:not([disabled]):focus { - background: linear-gradient(90deg, #1961d5, #816cfa) !important; -} - -.frm-upgrade-bar, -.frm-gradient { - position: relative; -} - -.frm-upgrade-bar::before, -.frm-gradient::before { - content: ""; - display: none; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - background-color: rgba(255, 255, 255, 0.1); - z-index: 0; -} - -.frm-upgrade-bar:hover::before, -.frm-gradient:hover::before, -.frm-gradient:focus::before { - display: block; -} - -.frm-upgrade-bar-inner, -.frm-gradient > * { - position: relative; - z-index: 1; -} - -.frm-upgrade-bar { - border-bottom: 1px solid var(--sidebar-hover); - padding: 9px 0; - font-size: 12px; - text-align: center; -} - -.frm-upgrade-bar a { - color: currentColor !important; - text-decoration: underline; -} - -.frm-upgrade-bar a:focus { - outline: 1px dotted var(--sidebar-hover); -} - -.frm-upgrade-bar span { - opacity: 0.9; -} - -/** - * Components - Links - */ -a h1 .frmsvg { - color: var(--grey-400); - vertical-align: middle; - min-width: var(--text-sm); -} - -a .frmsvg { - color: currentColor; -} - -.frm_wrap .view-switch a.current::before, -.frm-white-body a, -.frm_wrap a, -.frm_wrap a i { - color: var(--primary-color); -} - -.frm_wrap a:active, -.frm_wrap a:hover { - color: var(--primary-700); - box-shadow: none; -} - -.post-type-frm_display a:focus, -.frm_wrap a:focus { - box-shadow: none; -} - -/** - * Layout - Top Bar - Navigation - */ -.frm_top_left { - text-align: left; - float: left; - white-space: nowrap; - max-width: 250px; - overflow: hidden; - text-overflow: ellipsis; - align-self: center; -} - -.post-type-frm_display .frm_top_left, -.frm_top_left.frm_top_wide { - max-width: 100%; -} - -.post-type-frm_display .frm_nav_bar .frm-header-logo, -.frm_nav_bar .frm-header-logo { - margin: 18px 0 10px; -} - -#frm_top_bar .frm_form_nav { - flex: 1; -} - -ul.frm_form_nav { - margin: 0 auto; - padding-top: 18px; - display: block; - min-width: 240px; -} - -.nav-tab-wrapper.frm_form_nav { - padding: 0 25px; -} - -ul.frm_form_nav > li { - margin: 0 min(3.5%, 32px) 0 0; - display: inline-block; -} - -.post-type-frm_display #advanced-sortables h2.hndle, -.post-type-frm_display #side-sortables h2.hndle, -.post-type-frm_display #normal-sortables h2.hndle, -.post-type-frm_display .frm_form_nav .nav-tab-active, -.frm_form_nav > li > a { - font-size: 1.3em; - text-decoration: none; - display: block; - padding: 6px 2px 4px; - font-weight: 500; - color: var(--grey-700); - border-bottom: 2px solid transparent; -} - -.post-type-frm_display.js .postbox .handlediv .toggle-indicator::before { - margin-top: 10px; -} - -.frm-nav-tabs a:focus, -.frm-nav-tabs a:active, -.frm_form_nav a:active, -.frm_form_nav a:focus { - outline: none; - box-shadow: none; -} - -.frm_form_nav > li > a { - font-size: var(--text-md); - font-weight: 400; - color: var(--grey-500); -} - -.frm_form_nav > li > a:hover { - border-color: var(--primary-700); -} - -.frm_form_nav .frm-dropdown-menu a:hover { - background-color: #eaf2fa; -} - -.post-type-frm_display .frm_form_nav .nav-tab-active, -.post-type-frm_display .frm_form_nav .nav-tab-active:hover, -.frm_form_nav > li a.current_page { - color: var(--primary-500); - border-color: var(--primary-500); - background: transparent; - opacity: 1; - font-weight: 600; -} - -/** - * Components - Full Close - */ -.frm-full-close { - display: none; - padding-left: var(--gap-md); - border: 0 solid var(--grey-300); - border-left-width: 1px; /* Make RTL a bit less maintenance */ - height: 100%; - box-sizing: border-box; -} - -.frm-full-screen .frm-full-close { - display: flex; - align-items: center; -} - -.frm-full-close a { - display: block; -} - -.frm-full-close .frmsvg { - font-size: 20px; - width: 20px; - height: 20px; - color: var(--grey-500); -} - -/** - * Layout - Top Bar - Elements - */ -#frm_top_bar h1 { - font-weight: 400; - padding: 0; - margin: 0; - color: var(--grey-900); - display: inline-flex; - gap: var(--gap-sm); - align-items: center; - text-align: left; - min-width: 200px; -} - -#frm_top_bar h1 span { - max-width: 175px; - text-overflow: ellipsis; - overflow: hidden; - white-space: nowrap; - display: inline-block; - vertical-align: bottom; -} - -#frm_top_bar ul.frm_form_nav, -#frm_top_bar .frm-header-logo, -#frm_top_bar #frm_bs_dropdown { - align-self: center; - margin-top: 0; - margin-bottom: 0; - padding-top: 0; -} - -#frm_top_bar .frm-header-logo { - display: flex; /* Get rid of extra padding below logo */ -} - -#frm_top_bar h2 { - float: left; - margin: 0 0 0 var(--gap-sm); - padding: 2px 0 2px var(--gap-sm); - font-weight: 400; - border-left: 2px solid var(--grey); -} - -.frm_wrap > #frm_top_bar #frm-publishing { - margin-top: 0; -} - -#frm-publishing { - min-width: 225px; - align-self: center; - align-items: center; - display: flex; - flex-direction: row-reverse; - gap: 0 var(--gap-sm); - flex-wrap: wrap; -} - -/** - * Layout - Postbox - */ -.frm_wrap .postbox { - border-color: var(--grey-300); - border-radius: 6px; - box-shadow: none; -} - -.frm_wrap .postbox h3.hndle { - cursor: default; - padding: 10px 20px; - margin: 0; - line-height: 1.4em; - border-color: var(--grey-300); -} - -.frm-pre-hndle { - font-size: 15px; - padding: 5px; - margin: 9px 15px; -} - -/** - * Components - Table - Row - */ -.frm-empty-row { - display: none; -} - -.frm-child-row { - box-shadow: 5px 0 0 0 inset var(--sidebar-hover); -} - -/** - * Utilities - Effects - Animate - */ -.frm_animate_bg { - transition: background 200ms linear, color 200ms linear; -} - -/** - * Components - List - Subsubsub - */ -.wrap > .subsubsub { - clear: both; - margin: 0; -} - -.frm_wrap .subsubsub a { - line-height: var(--leading); - font-size: var(--text-sm); -} - -/** - * Layout - Container - */ -.frm-admin-page-styles .frm_page_container, -.frm_wrap .frm_page_container { /* Use .frm_wrap to avoid messing up Views editor layout */ - height: calc(100vh - 32px); - display: flex; - flex-direction: column; - overflow: hidden; - padding-top: 0; - position: fixed; - top: 32px; - bottom: 0; - left: 0; - right: 0; -} - -.frm-admin-page-translate .frm_wrap .frm_page_container, -.frm-admin-page-update_translations .frm_wrap .frm_page_container { - position: static; -} - -.auto-fold.frm-admin-page-styles .frm_page_container, -.auto-fold .frm_wrap .frm_page_container, -.frm-unfold.frm-admin-page-styles .frm_page_container, -.frm-unfold .frm_wrap .frm_page_container { - left: 160px; -} - -.folded.frm-admin-page-styles .frm_page_container, -.folded .frm_wrap .frm_page_container { - left: 38px; -} - -.frm-full-screen.frm-admin-page-styles .frm_page_container, -.frm-full-screen .frm_wrap .frm_page_container { - height: 100vh; - top: 0; - left: 0; -} - -.frm-full-screen.frm-admin-page-entries .frm_page_container, -.frm-new-entry .frm_page_container, -.frm-admin-page-reports .frm_page_container, -.frm_list_entry_page .frm_page_container { - height: auto; - display: block; -} - -/** - * Layout - Container - Columns Elements - */ -.frm-new-entry .columns-2 { - border: none; -} - -.frm-white-body #frm_top_bar, -.frm-white-body .columns-2 { - flex: 0 0 auto; -} - -.columns-2 .frm-right-panel + div { - padding-bottom: var(--gap-md); - border-left: 1px solid var(--grey-300); -} - -.columns-2 .frm-right-panel + div, -.frm_wrap #post-body-content { - padding-bottom: 0; - padding-top: var(--gap-sm); - margin-bottom: 0; - background: #fff; - width: auto; - float: none; - flex: 2; -} - -.frm-white-body .columns-2 { - flex: 1; - display: flex; - overflow: hidden; -} - -.frm-white-body .columns-2 > div { - overflow-y: auto; - box-sizing: border-box; -} - -.frm_wrap .columns-2 .frm-right-panel, -.frm-right-panel { - flex: 0 0 var(--biggest-sidebar); - float: none; - width: var(--biggest-sidebar); - min-width: var(--biggest-sidebar); - background-color: var(--sidebar-color); - margin: 0; - box-shadow: none; - border: none; - padding-bottom: 25px; -} - -.frm-right-panel .frm_field_list, -.frm_wrap .frm-right-panel #frm_adv_info, -.frm_wrap #postbox-container-1 #frm_adv_info { - box-shadow: none; - border: none; - margin-bottom: 26px; -} - -/** - * Components - Settings - Has Shortcodes - */ -#new_fields, -.frm-has-modal, -p.frm_has_shortcodes { - position: relative; -} - -.frm-inline-modal.postbox { - background: #fff; - border-color: var(--grey-100); - border-radius: var(--small-radius); - box-shadow: var(--box-shadow-lg); -} - -.frm_has_shortcodes .frmsvg:not(.frm_help .frmsvg), -.frm_has_shortcodes i:not([class*=mce-]) { - position: absolute; - color: var(--primary-500); - border-radius: 50%; - border: 1px solid transparent; - z-index: 100; - text-align: center; -} - -.frm_has_shortcodes .frmsvg.frm-show-box { - border-radius: 6px !important; -} - -.frm_has_shortcodes input, -.frm_has_shortcodes textarea { - padding-left: 18px; - box-sizing: border-box; -} - -/** - * Components - Settings - Adv Info - */ -#form_settings_page #frm_adv_info, -#frm_builder_page #frm_adv_info { - display: none; - top: 0; - width: 310px; - max-height: 315px; - min-height: 200px; - overflow-y: scroll; - z-index: 100; -} - -#form_global_settings .columns-2 > div { - overflow: auto; - height: calc(100vh - 32px); -} - -#form_global_settings .columns-2 .frm-right-panel, -#form_settings_page .columns-2 .frm-right-panel, -#wpbody-content .frm-page-skeleton .frm-right-panel { - flex: 0 0 var(--small-sidebar); - width: var(--small-sidebar); - min-width: var(--small-sidebar); -} - -#form_global_settings .frm_grid_container { - gap: 0 var(--gap-md); -} - -.frm-inner-content { - padding: var(--gap-md); -} - -.post-type-frm_display #poststuff { - padding: 0 0 10px 40px; -} - -#postbox-container-2 .postbox .inside { - padding: 15px 25px; -} - -#postbox-container-2 #frm_advanced .inside h3 { - margin: 15px -25px; - font-weight: 600; -} - -#form_settings_page .frm-inner-content { - padding-top: 0; - padding-bottom: 150px; - position: relative; -} - -.frm_wrap #submitdiv { - margin-bottom: 0; - border-width: 0 0 1px; - width: 100%; - min-width: unset; -} - -.frm_wrap #frm_adv_info .handlediv, -.frm_wrap #frm_adv_info .hndle { - display: none; -} - -.frm_wrap .menu-settings { - /* for add-on reverse compatibility */ - border: none; - margin-top: 0; -} - -.nodrag a { - cursor: pointer; -} - -.frm_wrap #frm_adv_info .inside { - margin: 0; -} - -#frm_adv_info > .inside { - padding: 0; -} -#frm_adv_info ul.subsubsub { - padding-bottom: var(--gap-xs) !important; -} -#frm_adv_info ul.subsubsub a { - font-weight: 500; -} -#frm_adv_info ul.subsubsub .frm-vertical-separator { - display: inline-block; - width: 1px; - height: 8px; - background-color: var(--grey-300); -} -#frm_adv_info #frm-insert-condition { - background-color: var(--primary-50); -} -#frm_adv_info #frm-insert-condition:hover { - background-color: var(--primary-25); -} - -#frm_builder_page #frm_adv_info { - width: 322px; - max-height: 356px; - border-radius: var(--small-radius); - overflow: hidden; -} -#frm_builder_page #frm_adv_info #taxonomy-linkcategory { - height: 356px; - overflow: hidden; -} -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div { - max-height: 286px; - padding: 0; -} -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div > * { - padding-bottom: var(--gap-sm); - max-height: unset; -} -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div > *:last-child { - padding-bottom: var(--gap-xs); -} -#frm_builder_page #frm_adv_info #frm-nav-tabs { - display: flex; - gap: var(--gap-xs); - background-color: var(--grey-100); - border-radius: var(--small-radius); - border: 0; - padding: var(--gap-xs); - margin: var(--gap-xs) var(--gap-2xs) var(--gap-sm); -} -#frm_builder_page #frm_adv_info #frm-nav-tabs > li { - flex: 1; - text-align: center; -} -#frm_builder_page #frm_adv_info #frm-nav-tabs > li a { - font-weight: 500; - line-height: 1; - color: var(--grey-500); - border-radius: var(--small-radius); - border: 0; - padding: var(--gap-xs); - margin: 0; -} -#frm_builder_page #frm_adv_info #frm-nav-tabs > li a:hover { - background-color: rgb(234, 236, 240); - color: var(--grey-500) !important; - box-shadow: var(--box-shadow-sm); -} -#frm_builder_page #frm_adv_info #frm-nav-tabs > li.frm-tabs a { - background-color: #fff; - color: var(--grey-900) !important; - box-shadow: var(--box-shadow-sm); -} -#frm_builder_page #frm_adv_info .frm-search, -#frm_builder_page #frm_adv_info .frm-with-search { - padding-top: 0; - margin: 0; -} - -/** - * Components - Modal - Inline Modal - */ -.frm-right-panel .frm-inline-modal.postbox .inside { - margin: 0; - padding: 0 14px 14px; -} -.frm-right-panel .frm-inline-modal.postbox .inside .frm-with-line, -.frm-right-panel .frm-inline-modal.postbox .inside .accordion-section-content h4 { - margin-left: -14px; - margin-right: -14px; -} - -.frm-right-panel .frm-inline-modal .inside p:not(.howto), -.frm-right-panel .frm-inline-modal .inside a { - font-size: 15px; -} - -.frm-inline-modal .inside a.frm_icon_font { - font-size: 18px; -} - -/** - * Components - Nav Tabs - */ -.frm-nav-tabs { - margin: 10px 0 20px; - padding: 0 var(--gap-sm); - display: block; - border-bottom: 1px solid var(--grey-300); -} - -#frm-nav-tabs { - position: -webkit-sticky; - position: sticky; - top: 0; - background-color: var(--sidebar-color); - z-index: 98; /* must be < 99 */ - margin-top: 0; - padding-top: 5px; -} - -.frm_form_settings #frm_adv_info #frm-nav-tabs { - background-color: #fff; - margin: 0 -4px; -} - -.frm_form_settings span.frm-with-right-icon, -#frm_builder_page .frm_has_shortcodes span.frm-with-right-icon:not(.frm_hidden) { - display: block; -} - -.frm-inline-modal .frm-nav-tabs, -#frm_adv_info .frm-nav-tabs { - margin: 5px 0 0; -} - -#frm_adv_info .frm-nav-tabs.frm-compact-nav { - padding-right: 0; - padding-left: 20px; -} - -.frm-nav-tabs li { - display: inline-block; - margin: 0; -} - -.frm-nav-tabs a { - color: var(--grey-700); - padding: 10px 1px; - margin: 0 9px; - border-bottom: 2px solid transparent; -} - -.frm_form_settings #frm_adv_info .frm-nav-tabs a { - padding: 5px 1px; - color: var(--grey-500); -} - -.frm-nav-tabs.frm-compact-nav a { - margin: 0 5px; -} - -.frm-nav-tabs a { - display: block; - opacity: 0.9; -} - -#frm_adv_info .frm-nav-tabs a { - color: var(--grey-700); -} - -.frm-nav-tabs a:hover, -.frm-nav-tabs .frm-tabs a { - color: var(--primary-500) !important; - border-color: var(--primary-500); -} - -.frm_form_settings #frm_adv_info .frm-nav-tabs .frm-tabs a { - font-weight: 500; -} - -/* Payments Page */ -.frm-payments-tabs { - margin-bottom: var(--gap-md); - display: flex; -} -.frm-payments-tabs .frm-payments-tab { - font-weight: 600; - font-size: 14px; - color: var(--grey-900); - display: inline-block; - border-width: 1px; - border-style: solid; - border-color: rgb(234, 236, 240); - padding: 8px 12px; - border-radius: 6px 6px 0 0; - background-color: rgb(249, 250, 251); -} -.frm-payments-tabs .frm-payments-tab-filler { - border-bottom: 1px solid rgb(234, 236, 240); - min-width: var(--gap-xs); -} -.frm-payments-tabs .frm-payments-tab-filler:last-child { - flex: 1; -} - -.frm-payments-tab.frm-active { - background-color: white; - border-bottom: none; -} - -.frm-payments-tab a { - text-decoration: none; - color: var(--grey-900); -} - -/** - * Components - Modal - Bulk Modal - */ -#frm-bulk-modal .howto, -#frm-bulk-modal h3 { - font-size: var(--text-sm); - font-weight: 400; - margin: 5px 0 10px; - color: var(--grey); -} - -#frm-bulk-modal h3 { - margin-left: 20px; -} - -/** - * Layout - Sidebar - */ -.frm-right-panel a.frm_add_logic_link, -.frm-right-panel h3 { - color: var(--grey-700); - font-size: var(--text-lg); - font-weight: 400; - margin: 0; -} -.frm-right-panel h3 i { - color: var(--grey-700); - float: right; - width: 16px; - cursor: pointer; -} - -.frm-settings-panel { - /* Right padding reduced to compensate for scrollbar width (~8px) */ - padding: var(--gap-sm); - padding-right: var(--gap-xs); -} -.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-delimiter { - top: var(--gap-xs); - left: var(--gap-xs); - width: calc(100% - var(--gap-sm)); -} -.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-navs { - padding: var(--gap-xs) var(--gap-xs) 0; -} -.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track > div { - max-height: 0; - visibility: hidden; -} -.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track > div.frm-active { - max-height: unset; - visibility: visible; -} -.frm-settings-panel .frm-embed-field-placeholder { - height: unset; -} -.frm-settings-panel .frm-embed-field-placeholder img { - height: 100px; -} -.frm-settings-panel .frm-embed-field-placeholder .frm-embed-message { - display: flex; - flex-direction: column; - justify-content: center; - align-items: center; - gap: var(--gap-sm); - max-width: unset; - color: var(--grey-800); - padding: var(--gap-lg); - border: 0; - box-shadow: var(--box-shadow-sm); - margin: 1px; -} - -.frm-single-settings .frm-default-value-wrapper > p { - margin-bottom: 0; -} -.frm-single-settings .frm-default-value-wrapper + p:empty { - display: none; -} -.frm-single-settings [class*=frm-lookup-box-] .frm_grid_container p { - margin-top: 0 !important; -} -.frm-single-settings .frm_single_option[id^=frm_watch_lookup_] { - margin-bottom: var(--gap-xs) !important; -} -.frm-single-settings > h3:first-of-type { - position: relative; - background-color: transparent !important; - border-top: none; - padding-top: 0 !important; - margin-top: 0 !important; -} -.frm-single-settings > h3:first-of-type::after { - content: ""; - position: absolute; - left: var(--gap-sm); - right: var(--gap-sm); - bottom: 0; - height: 1px; - background-color: var(--sidebar-hover); -} - -.frm-flex-justify, -.frm-right-panel .frm-single-settings h3 { - display: flex; - justify-content: space-between; - align-items: center; -} - -/* right sidebar */ -#post-body-content + .frm-right-panel { - flex: 0 0 var(--medium-sidebar); - width: var(--medium-sidebar); - min-width: var(--medium-sidebar); - border-left: 1px solid var(--sidebar-hover); -} - -.frm-new-entry #post-body-content + .frm-right-panel, -.frm-new-entry .frm-right-panel { - background: none; - border: none; -} - -#post-body-content + .frm-right-panel h3 { - padding: 20px 20px 0; - font-size: 17px; -} -#post-body-content + .frm-right-panel .frm_with_icons:first-of-type h3 { - border: none; -} - -#frm-insert-fields h3 { - color: var(--grey); - font-size: 15px; - font-weight: 400; - border-top: none; - border-bottom: 1px solid var(--sidebar-hover); - margin: 0; - padding: 10px 10px 10px 25px; -} - -.frm_wrap #frm_adv_info ul.category-tabs { - margin: 0; - padding: 10px 0 9px; - font-size: 15px; - background: transparent; -} -.frm_wrap #frm_adv_info ul.category-tabs li { - padding: 10px; - background-color: transparent !important; -} -.frm_wrap #frm_adv_info ul.category-tabs li:first-child { - border: none; -} - -.frm_wrap #frm_adv_info .categorydiv div.tabs-panel { - border: none; - background: transparent; -} -.frm_wrap #frm-categorydiv { - border-right: none; -} - -#frm_adv_info #frm-conditionals { - padding-top: var(--gap-sm); -} - -#postbox-container-1 #taxonomy-linkcategory #frm-html-tags { - display: none; - max-height: none; -} -#postbox-container-1 .frm_field_list #frm-insert-fields .frmbutton.dropdown { - position: relative; -} - -/** - * Components - Admin Footer - */ -.frm-white-body #footer-upgrade { - display: none; -} - -.frm-admin-footer-links, -.frm-admin-footer-links-nav, -.frm-admin-footer-links-socials { - display: flex; - justify-content: center; -} - -.frm-admin-footer-links { - gap: var(--gap-2xs); - flex-direction: column; - text-align: center; - padding: var(--gap-xl) 0 var(--gap-lg); - font-size: var(--text-xs); - color: var(--grey-400); -} - -body.frm-hidden-overflow { - height: 100%; - overflow: hidden; -} - -.frm-admin-footer-links-nav { - gap: var(--gap-2xs); - margin-bottom: var(--gap-xs); -} - -.frm-admin-footer-links-socials { - gap: var(--gap-xs); -} - -.frm-admin-footer-links-socials a { - color: var(--grey-400); -} - -/** - * Layout - List Entry Page - */ -.frm_list_entry_page h2 { - float: left; -} - -.frm_list_entry_page h2 + .error { - clear: both; -} - -/** - * Layout - Sidebar - Elements - */ -.frm_sidebar select { - width: 100%; - margin-left: 0; - margin-right: 0; -} - -.frm_sidebar #search-submit { - float: right; -} - -/** - * Layout - Single Entry Page - */ -.frm_single_entry_page #submitdiv { - margin: 0; -} - -.frm_single_entry_page .hndle a { - font-size: 13px; -} - -/** - * Components - Publish Actions - */ -.frm-right-panel #publishing-action { - float: none; -} - -.frm-right-panel #major-publishing-actions { - border-top: none; - height: 32px; - background: transparent; -} - -#major-publishing-actions .frm_submit_form { - float: right; - margin-left: 5px; -} - -/** - * Components - Button - */ -.frm_orange_button, -.frm_reverse_button { - font-size: 12px; - border: 1px solid var(--orange); - color: var(--orange); - font-weight: 600; - padding: 1px 4px; - border-radius: 4px; - background: transparent; -} - -.frm_reverse_button:hover, -.frm_reverse_button:active, -.frm_reverse_button:focus { - color: #fff; - background: var(--orange); - border: 1px solid var(--orange); -} - -.frm_reverse_button { - font-size: 1em; - transition: all 0.2s ease; -} - -.frm-button-primary, -.wp-core-ui .button-primary.frm-button-primary, -.wp-core-ui .button.frm-button-primary, -.frm-button-secondary, -.wp-core-ui .button-secondary.frm-button-secondary, -.wp-core-ui .button.frm-button-secondary, -.frm-white-body .frm-search .button, -.frm-white-body .search-box .button, -.frm-white-body .tablenav .button, -.frm_orange_button, -.toplevel_page_formidable #frm_upgrade_modal .button-primary, -.wp-core-ui.frm-white-body .button-primary, -.wp-core-ui.frm-white-body .button-secondary, -.frm-white-body .button-primary, -.frm-white-body .button-secondary, -#frm-form-button button, -.frm-form-button button, -.frm-preview-buttons button, -.frm-button-red, -.frm-button-tertiary { - text-shadow: none; - box-shadow: none; - border-radius: 30px; - border: 1px solid var(--primary-500); - font-size: var(--text-sm); - transition: all 0.2s ease; - padding: 7px 16px; - height: auto; - min-height: 28px; - outline: none; - line-height: var(--leading); - box-sizing: border-box; - font-weight: 500; - margin-bottom: 0; - display: inline-block; -} - -.frm-button-primary.frm-sharp, -.frm-button-secondary.frm-sharp { - border-radius: 12px !important; -} - -#wpcontent .frm-button-secondary.frm-button-gradient { - position: relative; - border-color: transparent !important; - background-clip: padding-box !important; -} -#wpcontent .frm-button-secondary.frm-button-gradient::before { - content: ""; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - z-index: -1; - margin: -1px; - border-radius: inherit; - background: linear-gradient(90deg, #129efd 0%, #a334fd 100%); - transition: opacity 150ms ease-out; -} -#wpcontent .frm-button-secondary:hover::before { - opacity: 0.5; -} - -.no-js.wp-core-ui .frm-search .button.hide-if-no-js, -.js.wp-core-ui .frm-search .button.hide-if-js { - display: none; -} - -.frm-button-tertiary { - border-color: transparent; - color: var(--primary-500); -} - -.frm-button-tertiary:focus { - outline: none; -} - -.frm-button-tertiary.frm_loading_button::before { - border-right-color: var(--grey); - border-bottom-color: var(--grey); -} - -.frm-button-red, -.frm-button-red:focus { - --primary-color: var(--error-500); - --primary-500: var(--error-500); - --primary-700: var(--error-700); -} - -.frm-button-red:not(.frm-button-tertiary), -.frm-button-red:not(.frm-button-tertiary):focus { - color: #fff !important; -} - -.frm-white-body h2 .button, -.post-type-frm_display h2 .frm-button-primary, -.frm-white-body .tablenav .button, -.frm-button-primary.frm-button-sm, -.frm-button-secondary.frm-button-sm, -.frm-button-tertiary.frm-button-sm, -.frm-button-red.frm-button-sm { - padding: 4px 12px !important; - font-size: var(--text-xs) !important; -} - -.frm_no_style_button { - background: transparent; -} - -.frm-with-icon { - display: flex; - gap: var(--gap-xs); - align-items: center; -} - -.frm-with-icon svg { - opacity: 0.65; /* Get close to grey-500 without overriding hover colors */ -} - -.frm-with-icon.button svg { - height: var(--text-sm); - width: var(--text-sm); -} - -.frm-with-icon.frm-button-sm svg { - height: var(--text-xs); - width: var(--text-xs); -} - -.frm-white-body .button.add_media { - /* Media buttons above RTE */ - padding-left: 12px !important; - padding-right: 12px !important; - font-size: var(--text-xs); - border-radius: var(--border-radius); -} - -.wp-core-ui.frm-white-body #post-query-submit.button, -.wp-core-ui.frm-white-body .button.tablenav-pages-navspan, -.wp-core-ui.frm-white-body .button.first-page, -.wp-core-ui.frm-white-body .button.prev-page, -.wp-core-ui.frm-white-body .button.next-page, -.wp-core-ui.frm-white-body .button.last-page, -.wp-core-ui.frm-white-body .button.action { - background-color: transparent; - border-color: var(--grey-300); - color: var(--grey-700); - border-radius: var(--border-radius); -} - -.post-type-frm_display.wp-core-ui .button-primary, -.frm-button-primary, -.wp-core-ui .button-primary.frm-button-primary, -.frm_single_entry_page #frm-publishing .button-primary { - background-color: var(--primary-500) !important; - color: #fff !important; -} - -.frm-button-primary.frm_large, -.frm-button-secondary.frm_large { - height: auto !important; - padding: 12px 16px !important; -} - -.frm-button-secondary.frm-small, -.frm-button-primary.frm-small { - font-size: var(--text-xs) !important; - height: auto !important; - padding: var(--gap-2xs) 12px !important; -} - -.frm-button-primary i::before { - color: #fff; -} - -.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover, -.frm-button-primary:not([disabled]):hover { - background: var(--primary-700) !important; - border-color: var(--primary-700) !important; -} - -.wp-core-ui .button-primary.frm-button-primary:active { - vertical-align: inherit; -} - -.frm-white-body #search-submit, -#frm-form-button .frm_button_submit, -.frm-form-button .frm_button_submit, -.frm-white-body .frm-preview-buttons button, -.frm-white-body .button:not(.frm-button-primary), -.wp-core-ui.frm-white-body .button-secondary, -.wp-core-ui .button-secondary.frm-button-secondary, -.wp-core-ui .button.frm-button-secondary, -.frm-white-body .frm-button-secondary, -.frm-button-secondary { - color: var(--grey-800); - border-color: var(--grey-300); - background-color: #fff; -} - -#wp-content-media-buttons button, -#wp-content-media-buttons a.button { - border-color: var(--grey-300); -} - -.frm_orange_button { - border-color: #da791d !important; - background: var(--orange); - color: #fff; -} - -.frm-white-body .button:not(.frm-button-primary):focus, -.frm-white-body .button:not(.frm-button-primary):active, -.frm-white-body .frm-button-secondary:hover, -.wp-core-ui.frm-white-body .frm-button-secondary:hover, -.wp-core-ui.frm-white-body .button-secondary:hover, -.wp-core-ui.frm-white-body .button-secondary:focus, -.wp-core-ui.frm-white-body .tablenav .button:hover, -.frm_wrap .preview > .button:hover, -.frm-white-body #search-submit:hover { - border-color: var(--grey-300) !important; - color: var(--grey-800); - background: var(--grey-50) !important; - box-shadow: none !important; - outline: none !important; -} - -.frm-button-primary .frmsvg { - color: #fff; -} - -.frm_wrap .preview i { - font-size: inherit; -} - -.frm-white-body .frm-button-primary:focus, -.frm-white-body .frm-button-primary:active, -#frm-addons-page .button-primary:focus, -#form_global_settings .button-primary:focus, -#frm_upgrade_modal .button-primary:focus { - border-color: var(--primary-700) !important; - background-color: var(--primary-700) !important; - box-shadow: none !important; - outline: none !important; -} - -.frm_wrap .preview > .button:focus, -.frm_orange_button:hover, -.frm_orange_button:focus, -.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover, -.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus, -.toplevel_page_formidable .frm_wrap button.button-primary:hover, -.toplevel_page_formidable .frm_wrap button.button-primary:focus { - outline: none; -} - -.frm_orange_button:hover, -.frm_orange_button:focus { - border-color: var(--orange) !important; - background: transparent; - color: var(--orange); - opacity: 1; -} - -.major-publishing-actions.frm_create_form_header { - padding: 8px 0; -} - -.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner { - font-size: 15px; - background: transparent; -} - -.frm-menu-boxes .frm_blank_form_text { - padding-bottom: 26px; -} - -input.frm_insert_in_template { - font-size: 10px; - width: 98%; - font-weight: 400; -} - -.frm-dismissible a.dismiss:focus { - box-shadow: none; -} - -.frm-dismissible a.dismiss { - top: 10px; - right: 10px; - position: absolute; -} - -.frm-dismissible a.dismiss svg { - color: var(--grey-800); -} - -.frm-btn-unstyled { - font: inherit; - background: none; - border: none; - padding: 0; - cursor: pointer; - outline: inherit; -} -.frm-btn-unstyled:hover, .frm-btn-unstyled:focus, .frm-btn-unstyled:active { - text-decoration: none; - background: none; - border: none; - box-shadow: none; -} -.frm-btn-unstyled:disabled, .frm-btn-unstyled[disabled] { - pointer-events: none; - opacity: 0.65; -} - -/** - * Components - Review Request - */ -.wp-admin .frm-review-notice { - position: fixed !important; - bottom: var(--gap-2xl); - right: var(--gap-lg); - width: 380px; - text-align: center; - border-color: var(--grey-100); - padding: var(--gap-lg); - border-radius: var(--medium-radius); - box-shadow: var(--box-shadow-lg) !important; - z-index: 999; - box-sizing: border-box; - --gap-sm: 16px; - --gap-md: 24px; - --gap-2xl: 48px; -} - -.wp-admin .frm-review-notice * { - box-sizing: border-box; -} - -.frm-review-notice-icon { - display: inline-flex; - margin-bottom: var(--gap-sm); -} - -.wp-admin .frm-review-notice-title { - font-weight: 600; - margin-top: 0; - margin-bottom: var(--gap-xs); -} - -.wp-admin .frm-review-notice-text { - margin-top: 0; - margin-bottom: var(--gap-md); -} - -.frm-review-notice-signature { - text-align: left; - margin: var(--gap-md) 0; -} - -.frm-review-notice-signature img { - width: 40px; - height: 40px; - padding: 3px; - box-shadow: var(--box-shadow-md); - border-radius: 100%; -} - -#wpwrap .frm-dismiss-review-notice { - top: 16px; - right: 19px; -} - -.frm-review-notice #frmapi-feedback [class^=frm__] { - display: none; -} - -.frm-review-notice #frmapi-feedback input, -.frm-review-notice #frmapi-feedback textarea { - border-color: var(--grey-300); - border-radius: var(--small-radius); -} - -.frm-review-notice #frmapi-feedback input { - min-height: unset; - max-height: 36px; -} - -.frm-review-notice #frmapi-feedback textarea { - max-height: 80px; - padding-top: var(--gap-xs); -} - -.frm-review-notice #frmapi-feedback .frm_message { - color: var(--success-900); - background-color: var(--success-25); - border: 1px solid var(--success-200); - padding: var(--gap-sm) var(--gap-md); - margin: 0; -} - -.frm-review-notice #frmapi-feedback .frm_message p { - margin: 0; -} - -.frm-review-notice #frmapi-feedback .frm_button_submit { - background-color: var(--primary-500); - border-color: var(--primary-500) !important; - cursor: pointer; -} - -.frm-review-notice #frmapi-feedback .frm_button_submit:hover, -.frm-review-notice #frmapi-feedback .frm_button_submit:focus { - color: #fff; - background-color: var(--primary-700); - border-color: var(--primary-700) !important; -} - -.frm-review-notice .frm_error, -.frm-review-notice label { - color: #444; - text-align: left; -} - -.frm-review-notice label { - font-size: var(--text-sm); -} - -.frm-floating-success-message { - position: fixed; - z-index: 999; - border-radius: 4px; - right: 10px; - bottom: 10px; -} - -/** - * Utility Classes - * - * Reusable helper classes for spacing, typography, effects, etc. - */ -/** - * Utilities - Box Shadow - */ -.frm-box-shadow-xxl { - box-shadow: var(--box-shadow-xxl) !important; -} - -/** - * Utilities - Text Color - */ -.frm-text-white { - color: #fff !important; -} - -.frm-text-primary-500 { - color: var(--primary-500); -} - -.frm-text-grey-400 { - color: var(--grey-400) !important; -} - -.frm-text-grey-500 { - color: var(--grey-500) !important; -} - -.frm-text-grey-600 { - color: var(--grey-600) !important; -} - -.frm-text-grey-700 { - color: var(--grey-700); -} - -.frm-text-grey-800 { - color: var(--grey-800); -} - -.frm-text-grey-900 { - color: var(--grey-900); -} - -.frm-text-success-500 { - color: var(--success-500); -} - -.frm-text-warning-500 { - color: var(--warning-500); -} - -.frm-underline { - text-decoration: underline; -} - -/** - * Utilities - Margin - */ -.frm_no_margin, -.frm-m-0 { - margin: 0 !important; -} - -.frm-m-12 { - margin: var(--gap-2xl); -} - -.frm-m-2xs { - margin: var(--gap-2xs) !important; -} - -.frm_no_top_margin, -.frm-mt-0 { - margin-top: 0 !important; -} - -.frm-mt-2xs { - margin-top: var(--gap-2xs) !important; -} - -.-frm-mt-2xs { - margin-top: calc(-1 * var(--gap-2xs)) !important; -} - -.frm-mt-xs { - margin-top: var(--gap-xs) !important; -} - -.frm-mt-sm { - margin-top: var(--gap-sm) !important; -} - -.frm-mt-md { - margin-top: var(--gap-md) !important; -} - -.frm-mt-lg { - margin-top: var(--gap-lg) !important; -} - -.frm-mt-2xl { - margin-top: var(--gap-2xl) !important; -} - -.frm-mt-auto { - margin-top: auto !important; -} - -.frm_no_bottom_margin, -.frm-mb-0 { - margin-bottom: 0 !important; -} - -.frm-mb-2xs { - margin-bottom: var(--gap-2xs) !important; -} - -.frm-mb-6 { - margin-bottom: 6px !important; -} - -.frm-mb-sm { - margin-bottom: var(--gap-sm) !important; -} - -.frm-mb-12 { - margin-bottom: 12px !important; -} - -.frm-mb-xs { - margin-bottom: var(--gap-xs) !important; -} - -.frm-mb-md { - margin-bottom: var(--gap-md) !important; -} - -.frm-mb-lg { - margin-bottom: var(--gap-lg) !important; -} - -.frm-ml-2xs { - margin-left: var(--gap-2xs) !important; -} - -.frm-ml-xs { - margin-left: var(--gap-xs) !important; -} - -.frm-ml-auto { - margin-left: auto; -} - -.-frm-ml-2xs { - margin-left: calc(-1 * var(--gap-2xs)) !important; -} - -.frm-mr-auto { - margin-right: auto; -} - -.frm-force-mr-auto { - margin-right: auto !important; -} - -.frm-mr-2xs { - margin-right: var(--gap-2xs) !important; -} - -.frm-mr-xs { - margin-right: var(--gap-xs) !important; -} - -.frm-mr-2 { - margin-right: 2px !important; -} - -.frm-mx-0 { - margin-left: 0 !important; - margin-right: 0 !important; -} - -.frm-mx-xs { - margin-left: var(--gap-xs) !important; - margin-right: var(--gap-xs) !important; -} - -.frm-mx-sm { - margin-left: var(--gap-sm) !important; - margin-right: var(--gap-sm) !important; -} - -.frm-my-sm { - margin-top: var(--gap-sm) !important; - margin-bottom: var(--gap-sm) !important; -} - -.frm-my-xs { - margin-top: var(--gap-xs) !important; - margin-bottom: var(--gap-xs) !important; -} - -/** - * Utilities - Padding - */ -.frm-p-0 { - padding: 0 !important; -} - -.frm-p-1, -.frm-p-2xs { - padding: var(--gap-2xs); -} - -.frm-p-sm, -.frm-p-4 { - padding: var(--gap-sm) !important; -} - -.frm-p-xs { - padding: var(--gap-xs) !important; -} - -.frm-p-sm { - padding: var(--gap-sm) !important; -} - -.frm-p-6, -.frm-p-md { - padding: var(--gap-md) !important; -} - -.frm-p-xl { - padding: var(--gap-xl) !important; -} - -.frm-px-0 { - padding-left: 0 !important; - padding-right: 0 !important; -} - -.frm-py-0 { - padding-top: 0 !important; - padding-bottom: 0 !important; -} - -.frm-py-2xs { - padding-top: var(--gap-2xs) !important; - padding-bottom: var(--gap-2xs) !important; -} - -.frm-py-sm { - padding-top: var(--gap-sm) !important; - padding-bottom: var(--gap-sm) !important; -} - -.frm-pt-0 { - padding-top: 0 !important; -} - -.frm-pt-2xs { - padding-top: var(--gap-2xs) !important; -} - -.frm-pt-xs { - padding-top: var(--gap-xs) !important; -} - -.frm-pt-sm { - padding-top: var(--gap-sm) !important; -} - -.frm-pt-md { - padding-top: var(--gap-md) !important; -} - -.frm-pt-xl { - padding-top: var(--gap-xl) !important; -} - -.frm-pr-lg { - padding-right: var(--gap-lg) !important; -} - -.frm-pb-md { - padding-bottom: var(--gap-md) !important; -} - -.frm-pb-sm { - padding-bottom: var(--gap-sm) !important; -} - -.frm-pb-xs { - padding-bottom: var(--gap-xs) !important; -} - -.frm-pb-2xs { - padding-bottom: var(--gap-2xs) !important; -} - -.frm-pb-0 { - padding-bottom: 0 !important; -} - -.frm-px-sm { - padding-right: var(--gap-sm) !important; - padding-left: var(--gap-sm) !important; -} - -.frm-px-xs { - padding-right: var(--gap-xs) !important; - padding-left: var(--gap-xs) !important; -} - -.frm-px-md { - padding-right: var(--gap-md) !important; - padding-left: var(--gap-md) !important; -} - -/** - * Utilities - Font Size - */ -.frm-text-xs { - font-size: var(--text-xs) !important; -} - -.frm-text-sm { - font-size: var(--text-sm) !important; -} - -.frm-text-md { - font-size: var(--text-md) !important; -} - -.frm-text-lg { - font-size: var(--text-lg) !important; -} - -.frm-text-xl { - font-size: var(--text-xl) !important; -} - -.frm-leading-none { - line-height: 1; -} - -.frm-italic { - font-style: italic; -} - -.frm-no-italic { - font-style: normal; -} - -/** - * Utilities - Text Transform - */ -.frm-capitalize { - text-transform: capitalize; -} - -/** - * Utilities - Font Weight - */ -.frm-font-normal { - font-weight: 400 !important; -} - -.frm-font-medium { - font-weight: 500 !important; -} - -.frm-font-semibold { - font-weight: 600 !important; -} - -.frm-font-bold { - font-weight: 700 !important; -} - -/** - * Utilities - Text Overflow - */ -.frm-truncate { - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; -} - -[class*=frm-line-clamp-] { - overflow: hidden; - display: -webkit-box; - -webkit-box-orient: vertical; -} - -.frm-line-clamp-2 { - -webkit-line-clamp: 2; -} - -.frm-white-space-nowrap { - white-space: nowrap; -} - -/** - * Utilities - Border Radius - */ -.frm-rounded-6 { - border-radius: 6px !important; -} - -.frm-rounded-sm { - border-radius: var(--small-radius) !important; -} - -.frm-rounded-12 { - border-radius: 12px !important; -} - -.frm-rounded-md { - border-radius: var(--medium-radius) !important; -} - -/** - * Utilities - Width - */ -.frm-w-auto { - width: auto !important; -} - -.frm-w-full { - width: 100% !important; -} - -.frm-w-half { - width: 50% !important; -} - -.frm-w-fit { - width: fit-content !important; -} - -.frm-max-w-fit { - max-width: fit-content; -} - -.frm-h-auto { - height: auto !important; -} - -/** - * Utilities - Display - */ -#wpwrap .frm-force-hidden, -.frm-force-hidden { - display: none !important; -} - -.frm_block, -.frm-block { - display: block; -} - -.frm_inline { - display: inline; -} - -.frm-force-inline { - display: inline !important; -} - -.frm_inline_block { - display: inline-block !important; -} - -/** - * Utilities - Flex - */ -.frm-inline-flex, -#wpbody-content .frm-inline-flex { - display: inline-flex; -} - -.frm-flex { - display: flex; -} - -.frm-force-flex { - display: flex !important; -} - -.frm_hidden, -.js .frm-hide-js { - display: none; -} - -.frm-flex-box { - display: flex; - gap: var(--gap-sm); -} - -.frm-flex-col { - display: flex; - flex-direction: column; -} - -.frm-flex-full { - flex: 1; -} - -.frm-force-flex-center, .frm-flex-center { - justify-content: center; - align-items: center; -} - -.frm-flex-center { - display: flex; -} - -.frm-force-flex-center { - display: flex !important; -} - -.frm-shrink-0 { - flex-shrink: 0; -} - -.frm-gap-0 { - gap: 0 !important; -} - -.frm-gap-2xs { - gap: var(--gap-2xs); -} - -.frm-gap-xs { - gap: var(--gap-xs); -} - -.frm-gap-sm { - gap: var(--gap-sm); -} - -.frm-gap-md { - gap: var(--gap-md); -} - -.frm-gap-xl { - gap: var(--gap-xl); -} - -.frm-justify-start { - justify-content: start !important; -} - -.frm-justify-center { - justify-content: center !important; -} - -.frm-justify-between { - justify-content: space-between; -} - -.frm-justify-end { - justify-content: end; -} - -.frm-items-start { - align-items: flex-start; -} - -.frm-items-center { - align-items: center; -} - -.frm-items-stretch { - align-items: stretch; -} - -.frm-self-normal { - align-self: normal; -} - -#wpbody-content .frm-flex-wrap { - flex-wrap: wrap; -} - -.frm-grow { - flex-grow: 1; -} - -.frm-order-first { - order: -9999; -} - -.frm-order-last { - order: 9999; -} - -.frm-order-none { - order: 0; -} - -.frm-h-stack-sm, .frm-h-stack-xs, .frm-h-stack { - display: flex !important; - align-items: center; -} -.frm-h-stack-sm > input[type=checkbox], .frm-h-stack-xs > input[type=checkbox], .frm-h-stack > input[type=checkbox], -.frm-h-stack-sm > input[type=radio], -.frm-h-stack-xs > input[type=radio], -.frm-h-stack > input[type=radio] { - margin: 0 !important; -} - -.frm-h-stack { - gap: var(--gap-2xs); -} - -.frm-h-stack-xs { - gap: var(--gap-xs); -} - -.frm-h-stack-sm { - gap: var(--gap-sm); -} - -.frm-flex-row-reverse { - flex-direction: row-reverse; -} - -/** - * Utilities - Transition - */ -.frm-transition-ease { - transition: all 0.2s ease; -} - -/** - * Utilities - Visibility - */ -.frm_invisible { - visibility: hidden; - transition: all 0.2s ease; -} - -.frm_disabled { - opacity: 0.5; - cursor: default; - pointer-events: none; -} -.frm_disabled .frm-show-inline-modal { - pointer-events: none !important; -} - -/** - * Utilities - Float - */ -.frm_no_float { - float: none; -} - -/** - * Utilities - Text Align - */ -.frm-text-right { - text-align: right; -} - -.frm-text-left { - text-align: left; -} - -/** - * Utilities - Border - */ -.frm-border-b { - border-bottom: 1px solid var(--grey-300); -} - -.frm-no-border { - border: none !important; -} - -.frm-hr { - display: block; - height: 1px; - background-color: var(--grey-200); - margin: var(--gap-xs) 0; -} - -/** - * Utilities - Opacity - */ -.frm-opacity-100 { - opacity: 1; -} - -/** - * Utilities - Z-index Helpers - */ -.frm-on-bottom { - z-index: -1; -} - -/** - * Utilities - Transform - */ -.frm-rotate-90 { - transform: rotate(90deg); -} - -/** - * Utilities - Cursor - */ -.frm-cursor-pointer { - cursor: pointer; -} - -/** - * Utilities - Vertical Align - */ -.frm-align-baseline { - vertical-align: baseline !important; -} - -/** - * Utilities - Generic Classes - */ -.frm-fields p > label.frm_hidden, -#wpbody-content label.frm_hidden, -.frm-lookup-modal .dismiss, -.frm-right-panel .inside a.frm_hidden, -#form_global_settings .frm_hidden, -ul.frm_form_nav > li.frm_hidden, -a.frm_hidden, -.button.frm_hidden, -.wp-core-ui .button.frm_hidden { - display: none; -} - -.postbox .inside > p.frm_no_bottom_margin:last-child { - margin-bottom: 0 !important; -} - -.frm_no_section_fields.frm_block { - display: block; -} - -.actions.frm_visible_overflow { - overflow: visible !important; -} - -.frm_full_opacity, -.frm_submit .frm_full_opacity, -.frm_submit .frm-opacity-100 { - opacity: 1; -} - -.frm-dropdown-menu.frm-on-top { - z-index: 99999; -} - -/** - * Utilities - Helper Classes - */ -.frm-vertical-line { - display: inline-block; - width: 1px; - height: 12px; - background-color: var(--grey-300); -} - -.frm-admin-full-screen #adminmenumain, -.frm-admin-full-screen #wpadminbar, -.frm-admin-full-screen #adminmenuback, -.frm-admin-full-screen #adminmenuwrap, -.frm-admin-full-screen #wpfooter { - display: none; -} - -.frm-admin-full-screen #wpcontent, -.frm-admin-full-screen.auto-fold #wpcontent { - margin: 0; - padding: 0; -} - -.frm-admin-full-screen.appearance_page_starter-templates #wpbody-content { - padding: 0; -} - -/** - * Forms & UI Components - * - * Form elements, inputs, fields, modals and interactive components - */ -/** - * Components - General Form Styles - */ -.frm_forms.with_frm_style { - max-width: 100%; -} - -.post-type-frm_display .wrap > .subsubsub, -.post-type-frm_display .wrap > .icl_subsubsub, -.frm_form_settings > p { - margin: 6px var(--gap-md); - padding: 0; -} - -.frm-entry-container { - margin: 0 40px 40px; - padding: 0; -} - -#form_reports_page .frm-inner-content { - width: calc(100% - 40px); - max-width: 900px; - margin: 20px auto; - padding: 20px; -} - -.frm_inner_field_container > .frm_form_fields { - clear: both; -} - -.post-type-frm_display h2, -.frm_wrap h2 { - margin-top: 0 !important; - font-size: var(--text-lg); - line-height: var(--leading); -} - -.post-type-frm_display .wrap > h2:first-child, -.frm_wrap .wrap > h2:first-child { - padding-top: 0; - margin-top: 0 !important; - font-size: var(--text-lg); -} - -#frm_form_editor_container { - position: relative; - margin-top: 28px; -} - -/** - * Components - Form Field - */ -.form-field p { - /* for conflicts */ - background: none; - border: none; -} - -.form-field label.frm_primary_label { - display: block; - float: none; - width: auto; -} - -#frm_view_editor_left label, -#frm_view_editor_left .frm_primary_label, -.frm-dialog .frm-sub-label, -.frm-dialog label, -.dropdown .frm_primary_label, -.accordion-container label, -.frm-fields td > label, -.frm-fields td > div > label, -.frm_form_field > label:first-child, -.frm-fields p > label, -.frm_on_submit_type > label, -.post-type-frm_display .frm_form_field > label, -#new_fields .frm_primary_label, -#form_global_settings .frm_primary_label, -#frm_form_editor_container .frm_primary_label, -#permissions_settings_settings .frm_primary_label { - color: var(--grey-700); - margin: 0 0 6px; - padding: 0; - width: auto; - font-size: var(--text-sm); - display: block; - line-height: var(--leading); -} - -#frm_form_editor_container #frm-show-fields .frm_primary_label { - min-height: 21px; -} - -.frm-fields td input + label { - display: inline; -} - -#frm_form_editor_container .edit_field_type_end_divider .frm_primary_label, -#frm_form_editor_container .edit_field_type_break .frm_primary_label { - display: none; -} - -form .frm_primary_label input { - font-size: 12px; -} - -.with_frm_style form .form-field { - margin-bottom: 20px; -} - -#frm_builder_page .with_frm_style form .frm_combo_inputs_container > .form-field { - margin-bottom: 0; -} - -.frm_description, -.with_frm_style form div.description, -.frm_error, -.with_frm_style form div.description textarea { - padding: 0; - font-size: 11px; -} - -.with_frm_style .description { - color: inherit; -} - -#frm_form_editor_container .divider_section_only .frm_primary_label { - display: flex; - align-items: center; - gap: var(--gap-xs); - font-size: 20px; -} - -#frm_form_editor_container .divider_section_only .frm_primary_label .frm-sub-label { - padding: 0; -} - -#frm-show-fields ul:has(> li:nth-child(7)) .frm-sub-label.frm-field-id { - display: none; -} - -/** - * Token Input Component - * - * Displays space-separated values as selectable tokens - */ -.frm-token-container { - position: relative; - display: block; - direction: ltr; -} -.frm-token-container .frm-tokens { - position: absolute; - top: 0; - left: 0; - max-width: calc(100% - var(--gap-xl)); - display: flex; - align-items: center; - flex-wrap: wrap; - gap: var(--gap-2xs); - padding: 6px var(--gap-xs); - margin: 0; -} -.frm-token-container .frm-token { - position: relative; - display: flex; - align-items: center; - gap: var(--gap-xs); - min-height: 24px; - height: auto; - color: var(--grey-900); - background: var(--grey-100); - border-radius: 4px; - padding: 0 var(--gap-xs); - font-size: var(--text-md); - margin: 0; - z-index: 2; -} -.frm-token-container .frm-token .frm-token-value { - line-height: var(--leading); - white-space: normal; - word-break: break-word; -} -.frm-token-container .frm-token .frm-token-remove { - display: flex; - flex-shrink: 0; - cursor: pointer; -} -.frm-token-container .frm-token .frm-token-remove .frmsvg { - color: var(--grey-900); - position: static; - width: 12px; - height: 12px; - padding: 0; -} -.frm-token-container .frm-token .frm-token-remove:hover .frmsvg { - color: var(--error-500); -} -.frm-token-container .frm-show-inline-modal { - z-index: 3 !important; -} -.frm-token-container .frm-token-proxy-input { - position: relative; - z-index: 1; - padding-right: var(--gap-xl) !important; -} - -/** - * Components - Field Loading - */ -form .form-field.frm_field_loading { - margin-bottom: 0; - min-height: 0; - padding: 0; - text-align: center; -} - -.frm_sorting > .frm_field_loading .frm_visible_spinner.frm-wait { - margin-bottom: 10px; -} - -.frm_sorting > .frm_field_loading ~ .frm_field_loading .frm_visible_spinner.frm-wait { - margin-bottom: 0; - display: none; -} - -/** - * Components - Form Error - */ -.frm_description, -.with_frm_style form div.description, -.frm_error { - margin: 0; -} - -.frm_error { - color: #f04438; -} - -form .frm_blank_field input, -form .frm_blank_field textarea, -form .frm_blank_field select, -form .frm_blank_field .frm-g-recaptcha iframe, -form .frm_blank_field .g-recaptcha iframe { - border-color: #f04438; -} - -form .frm_blank_field label { - color: #f04438; -} - -.frm_required { - color: #f04438; -} - -/** - * Components - MCE Styles - */ -.with_frm_style .wp-editor-container textarea, -.postbox .wp-editor-container textarea, -.frm_remove_border { - border: none; -} - -.with_frm_style .mceIframeContainer, -.postbox .mceIframeContainer { - background-color: #fff; -} - -/** - * Components - License - */ -.frm_pro_license_msg { - clear: left; - margin-top: 10px; -} - -.frm-license-input { - position: relative; -} - -.frm-license-input span { - font-size: var(--text-sm); -} - -.frm-license-input .frmsvg { - width: 20px; - height: 20px; - margin-left: 5px; - vertical-align: text-top; -} - -.frm-license-input .frmsvg, -.frm-license-input span, -.frm-license-input i { - color: rgb(0, 131, 26); -} - -/** - * Components - Upgrade to Pro - */ -.upgrade_to_pro { - padding: 10px 25px 25px; - max-width: 700px; - margin: 20px auto !important; -} - -.upgrade_to_pro .error { - display: none; -} - -/** - * Components - Message Styles - */ -.toplevel_page_formidable #wpbody-content > .error { - margin: 1px; - padding: 5px 12px; -} - -.frm_error_style, -.frm_warning_style, -.frm_note_style2, -.frm_note_style, -.frm_message, -#post-body-content .frm_updated_message, -div.frm_updated_message { - border-radius: var(--small-radius); - background-color: #d5f2dc; - color: #1e561f; - padding: var(--gap-sm) var(--gap-md); - font-size: var(--text-sm); - margin: var(--gap-sm) 0; - text-align: left; -} - -.frm_note_style2 { - background: linear-gradient(90deg, #e9effa, #fcf6fe) padding-box, linear-gradient(90deg, #1961d5, #e8abef) border-box; - border: 1px solid transparent; -} - -#frm_top_bar + .wrap > .frm_updated_message, -#frm_top_bar + .wrap > .frm_warning_style { - display: inline-block; - width: 100%; - box-sizing: border-box; -} - -#post-body-content > .frm_updated_message { - margin: 5px 65px; -} - -#form_global_settings #post-body-content > .frm_updated_message, -#form_global_settings #post-body-content > .frm_warning_style { - margin: 5px 25px; -} - -.frm_error_style { - color: #973937; - background-color: #ebcccc; - clear: both; -} - -.frm_error_style a { - text-decoration: underline; - font-weight: 600; -} - -.frm_error_style svg { - opacity: 0.7; -} - -.frm_warning_style { - color: #7a4d05; - background-color: #fff2d2; -} - -.frm_warning_heading { - font-weight: 700; - margin-bottom: 4px; -} - -/* Warning message dismiss */ -.frm_warning_style { - position: relative; - padding-right: calc(var(--gap-md) + 15px); -} - -body.rtl .frm_warning_style { - padding-right: var(--gap-md); - padding-left: calc(var(--gap-md) + 15px); -} - -.frm-warning-dismiss { - position: absolute; - top: 10px; - right: 10px; - display: flex; - cursor: pointer; - transition: opacity 0.2s ease-out; -} - -body.rtl .frm-warning-dismiss { - left: 10px; - right: auto; -} - -.frm-warning-dismiss:hover { - opacity: 0.8; -} - -.frm-warning-dismiss.frmsvg, -.frm-warning-dismiss.frmsvg svg { - width: 15px; - height: 15px; -} - -.frm_note_style { - background: rgba(188, 224, 253, 0.23); - color: var(--grey-700); -} - -.frm-banner-alert { - text-align: left; - margin: 0; - border-radius: 0; - padding: 10px 0 10px 40px; -} - -.frm-banner-alert a { - color: var(--primary-500); - font-weight: 400; - text-decoration: none; -} - -.frm_updated_message ul, -.frm_updated_message li, -.frm_warning_style ul, -.frm_warning_style li, -.frm_error_style ul, -.frm_error_style li { - margin: 0; -} - -.frm-inline-message { - border: 1px solid var(--primary-700); - border-radius: var(--small-radius); - color: var(--primary-700); - background: #fff; - text-align: center; - padding: 20px; - font-size: var(--text-sm); - line-height: var(--leading); -} - -.frm-inline-message a { - text-decoration: underline; - font-weight: 600; - color: var(--primary-700); -} - -.frm_pro_heading span { - margin-top: 10px; -} - -.frm_pro_heading .alignright { - text-align: right; -} - -.frm-yes { - color: var(--green); - font-size: var(--text-xl); -} - -.frm-nope { - color: var(--grey-400); - font-size: var(--text-xl); -} - -/** - * Components - Upgrade Bar Elements - */ -.upgrade_to_pro a { - color: var(--orange); -} - -.upgrade_to_pro table .frmsvg { - height: var(--text-xl); - width: var(--text-xl); -} - -.upgrade_to_pro table.widefat { - background-color: #fff; - border-collapse: collapse; -} - -.frm-white-body .upgrade_to_pro table th, -.upgrade_to_pro table td { - padding: 10px 15px; - border: 1px solid var(--grey-300); - line-height: var(--leading); - font-size: var(--text-sm); -} - -.upgrade_to_pro table th.frmcenter { - text-align: center; -} - -/** - * Components - Table Styles - */ -.widefat th.frm_table_break { - background-color: var(--sidebar-color); -} - -/** - * Base - Howto - */ -h2.frm-h2 + .howto { - color: var(--medium-grey); - max-width: 850px; - margin: 5px 0 20px; -} - -/** - * Components - Card - */ -.frm-card { - width: 100%; - border-radius: 10px; - border: 1px solid var(--grey-300); - opacity: 1; - transition: opacity 1s; -} - -.frm-card-box { - max-width: 524px; - background-color: #fff; - border-radius: var(--medium-radius); - padding: var(--gap-xl); - border: 1px solid var(--grey-200); - box-shadow: var(--box-shadow-md); -} - -.frm-card-box.frm-has-progress-bar { - position: relative; - overflow: hidden; - border-radius: var(--medium-radius); -} - -.frm-card-box-progress-bar { - position: absolute; - top: 0; - left: 0; - right: 0; - height: var(--gap-xs); - background-color: var(--primary-25); -} - -.frm-card-box-progress-bar > span { - position: absolute; - top: 0; - left: 0; - bottom: 0; - width: 33%; - background-color: var(--primary-500); -} - -.frm-card-box-header { - display: flex; - justify-content: center; - margin-bottom: var(--gap-sm); -} - -.frm-card-box.frm-has-progress-bar .frm-card-box-header { - margin-top: var(--gap-xs); -} - -.frm-card-box-content > :last-child { - margin-bottom: 0; -} - -.frm-card-box-footer { - display: flex; - justify-content: end; - gap: var(--gap-sm); - margin-top: var(--gap-lg); -} - -.frm-card-box-title { - font-size: var(--text-xl) !important; - font-weight: 600 !important; - margin-bottom: var(--gap-xs); -} - -.frm-card-box-text { - font-size: var(--text-md) !important; - color: var(--grey-600) !important; - margin-top: 0 !important; -} - -/** - * Utilities - Fade - */ -.frm-fade { - opacity: 0; - transition: all 1s; -} - -/** - * Components - Add-on Tiles - */ -.frm-addons .frm-card.frm-addon-not-installed { - position: relative; -} - -.frm-addons .plugin-card-top { - min-height: 155px; - padding-top: var(--gap-lg); - overflow: hidden; -} - -.frm-addons .plugin-card-top h2 { - margin-top: 0; - font-weight: 400; -} - -.frm-template-row p, -.frm-addons .plugin-card-top p { - opacity: 0.8; -} - -.frm-addons .plugin-card-top > :not(p):not(h2) { - /* Hide notices from third party plugins */ - display: none; -} - -.frm-addons .plugin-card-bottom { - padding: 5px 20px 20px; - text-align: center; - background: transparent; - border-top: none; -} - -.frm-addons .plugin-card-bottom, -.frm-addons .plugin-card-bottom .button { - font-size: 15px; -} - -.frm-addons .button, -.frm-addons .frm-button-tertiary { - float: right; -} - -.frm-addons .addon-status { - float: left; - padding-top: 4px; -} - -.frm-addon-not-installed .frm-activate-addon, -.frm-addon-not-installed .frm-deactivate-addon, -.frm-addon-not-installed .frm-uninstall-addon, -.frm-addon-installed .frm-install-addon, -.frm-addon-installed .frm-deactivate-addon, -.frm-addon-active .frm-activate-addon, -.frm-addon-active .frm-install-addon, -.frm-addon-active .frm-uninstall-addon, -.plugin-card-pro.frm-addon-active .button, -.plugin-card-pro.frm-addon-active .frm-button-tertiary { - display: none !important; -} - -.frm-save-and-reload-options { - margin-top: 10px; - font-size: 13px; -} - -.frm-save-and-reload, -.frm-save-and-reload + .frm-button-secondary { - visibility: visible !important; -} - -.addon-status-label { - opacity: 0.7; -} - -.frm-addon-active .addon-status-label { - color: var(--green); - opacity: 1; -} - -.frm-addon-error { - position: absolute; - top: 55px; - left: 10px; - right: 10px; - font-weight: 700; - text-align: center; -} - -/** - * Components - Form Templates - */ -.frm-new-template.plugin-card-bottom { - overflow: visible; -} - -#frm-new-template p:first-child { - margin-top: 0; -} - -/** - * Layout - Admin Page - */ -.frm-admin-page-formidableedit #wpbody-content > *:not(.frm-review-notice):not(.frm_previous_install):not(.frm-banner-alert):not(#frm-svg-icons-pack), -#wpbody-content > .updated, -#wpbody-content > #update-nag, -#wpbody-content > .update-nag, -#wpbody-content > .notice, -#wpbody-content > .error:not(.frm_previous_install), -.frm-white-body .updated, -.frm-white-body .notice, -.frm_wrap > .wrap > .notice, -.frm-white-body .error:not(.frm_previous_install) { - display: none; -} - -.frm-admin-page-formidableedit #frm_builder_page { - display: block !important; -} - -.frm-white-body .updated, -.frm-white-body .error { - margin: 0; - padding: 10px 20px; -} - -/** - * Components - Modal - */ -.frm-modal:not(#frm-dismissable-cta) .postbox { - max-height: 600px; - overflow: hidden; - margin-bottom: 0; -} - -.frm-modal .postbox .frm_modal_top, -.frm-dialog .frm_common_modal .postbox > div:first-child, -.frm-error-modal .frm_modal_top { - padding: var(--gap-md) var(--gap-md) 0; - position: relative; -} - -.frm-modal h2, -.frm-modal .postbox .inside h2, -.frm-modal .postbox .frm-modal-title, -.frm-dialog .frm_common_modal .postbox > div:first-child > div:first-child, -.frm-error-modal .frm-modal-title { - display: inline-block; - font-size: var(--text-lg); - color: var(--grey-900); - font-weight: 600; - margin: 0; - padding: 0; -} - -.frm-modal h3 { - font-weight: 500; -} - -/* Dismiss icon button */ -.frm-inline-modal > a.dismiss, -.frm-modal .postbox > a.dismiss, -.frm-modal .postbox .frm-modal-title + div:last-child, -.frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { - position: absolute; - top: 19px; - right: 19px; - display: flex; - z-index: 2; -} - -body.rtl .frm-inline-modal > a.dismiss, -body.rtl .frm-modal .postbox > a.dismiss, -body.rtl .frm-modal .postbox .frm-modal-title + div:last-child, -body.rtl .frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { - right: unset; - left: 30px; -} - -.frm-info-modal .postbox > a.dismiss, -.frm-inline-modal > a.dismiss { - right: 13px; - top: 13px; -} - -.frm-modal .postbox .frm-modal-title + div:last-child a, -.frm-modal a.dismiss .frmsvg, -.frm_common_modal .frm_modal_top a .frmsvg { - color: var(--grey-500); -} - -.frm-modal .postbox .frm-modal-title + div:last-child a:hover, -.frm-modal a.dismiss .frmsvg:hover, -.frm_common_modal .frm_modal_top a .frmsvg:hover { - color: var(--grey-700); -} - -.frm-modal .frm_modal_content > div.inside, -.frm_common_modal .frm_modal_content > div.inside { - padding: var(--gap-md); - margin: 0; - font-size: var(--text-sm); - color: var(--grey-700); -} - -.frm-modal p { - color: var(--grey-900); -} - -.frm_common_modal .postbox { - display: flex; - flex-direction: column; -} - -.frm-modal .postbox > div.inside .cta-inside { - overflow-y: auto; - height: auto; -} - -.frm_modal_footer { - padding: 0 var(--gap-md) var(--gap-sm); - text-align: right; -} - -body.frm-body-with-open-modal { - overflow-y: hidden; -} - -/** - * Components - Template List - */ -/* These template list styles are still used to list the View types in the New View modal. */ -.frm-templates-list { - margin-top: 0; -} - -.frm-templates-list.frm_grid_container li { - margin-bottom: 0; -} - -.frm-templates-list li { - vertical-align: top; - position: relative; - box-sizing: border-box; - border-radius: 6px; - border: 1px solid transparent; - text-align: left; -} - -.frm-templates-list li:not(.frm_hidden) { - display: inline-block; -} - -.frm-templates-list.frm-categories-list li { - width: 100%; -} - -.frm-templates-list li.frm-selectable { - cursor: pointer; -} - -.frm-templates-list li.frm-selectable:hover { - background: var(--light-blue); - border-color: rgba(65, 153, 253, 0.5); -} - -.frm-templates-list li.frm-selectable:hover h3, -.frm-templates-list li.frm-selectable:hover p { - max-width: calc(100% - 65px); -} - -.frm-templates-list .frm-featured-form { - display: flex; - width: 100%; -} - -.frm-templates-list li .frm-featured-form { - padding: 7px 5px; -} - -.frm-templates-list li li > div { - padding-left: 0; -} - -.frm-templates-list li > div > div { - vertical-align: middle; -} - -.frm-category-icon, -.frm-icon-wrapper { - background: var(--primary-500); - border-radius: var(--small-radius); - color: #fff; - width: 32px; - height: 32px; - font-size: 18px; - box-sizing: border-box; - align-self: center; - justify-content: center; - align-items: center; - display: inline-flex; -} - -.frm-templates-list li .frm-category-icon { - overflow: hidden; -} - -.frm-templates-list li h3, -.frm-templates-list li p { - text-align: left; - margin: 0; - white-space: nowrap; - text-overflow: ellipsis; - overflow: hidden; -} - -.frm-templates-list li h3, -.frm-templates-list .frm-install-template h3 { - font-size: var(--text-sm) !important; -} - -.frm-templates-list .frm-install-template div { - text-align: left; -} - -#frm_leave_email, -#frm_code_from_email { - width: 480px; - max-width: 100%; -} - -.frm-templates-list.frm-categories-list li > div > div:last-child { - padding-left: 0; -} - -.frm-hover-icons { - position: absolute; - right: 0; - top: 17px; /* Template item height - borders - icon height */ - max-width: 91px; - height: 100%; - box-sizing: border-box; - padding: 0 10px 0 5px !important; - border-radius: var(--small-radius); - text-align: right; - display: flex; - gap: 5px; -} - -.frm-ready-made-solution .frm-hover-icons { - visibility: hidden; -} - -.frm-ready-made-solution:hover .frm-hover-icons { - visibility: visible; -} - -.frm-hover-icons a { - width: 22px; - height: 22px; - font-size: var(--text-md); - display: inline-flex; - align-items: center; - justify-content: center; - border-radius: 50%; - box-sizing: border-box; - line-height: var(--leading); - text-align: center; -} - -.frm-hover-icons > .frm-preview-form, -.frm-hover-icons > .frm-delete-form { - border: 1px solid var(--primary-500); -} - -.frm-hover-icons > .frm-create-form, -.frm-ready-made-solution .frm-hover-icons a { - background-color: var(--primary-500); -} - -.frm-hover-icons > a .frmsvg { - width: 14px; - height: 14px; - vertical-align: baseline; -} - -.frm-hover-icons > .frm-preview-form .frmsvg, -.frm-hover-icons > .frm-delete-form .frmsvg { - color: var(--primary-500); -} - -.frm-hover-icons > .frm-unlock-form { - background-color: var(--primary-500); -} - -.frm-hover-icons > .frm-unlock-form .frmsvg { - background-color: var(--primary-500); -} - -.frm-ready-made-solution .frmsvg { - width: 14px; - height: 14px; -} - -.frm-hover-icons .frm-create-form svg, -.frm-ready-made-solution .frm-hover-icons svg { - color: #fff; -} - -.frm-hover-icons .frm-create-form:hover, -.frm-ready-made-solution .frm-hover-icons a:hover, -.frm-hover-icons > .frm-unlock-form:hover, -.frm-hover-icons > .frm-unlock-form:hover .frmsvg { - background-color: var(--primary-700) !important; -} - -.frm-hover-icons .frm-preview-form:hover, -.frm-hover-icons .frm-delete-form:hover { - border: 1px solid var(--primary-700) !important; -} - -.frm-hover-icons .frm-preview-form:hover .frmsvg, -.frm-hover-icons .frm-delete-form:hover .frmsvg { - color: var(--primary-700) !important; -} - -.frm-application-card h4 .frmsvg, -.frm-locked-template h3 .frmsvg { - height: var(--text-sm); - width: var(--text-sm); - vertical-align: text-top; - color: var(--grey-500); -} - -/** - * Components - Modal Actions - */ -.frm-modal-back { - cursor: pointer; - margin-right: 4px; -} - -.frm-modal-cancel { - float: left; -} - -/** - * Components - Meta Tag - */ -.frm-meta-tag, -.frm-meta-tag:hover { - padding: var(--gap-2xs) var(--gap-xs); - border-radius: var(--small-radius); - font-weight: 600; - display: inline-flex; - background-color: #d9ebff; - gap: 2px; -} - -.frm-meta-tag.frm-grey-tag, -.frm-meta-tag.frm-grey-tag:hover { - background-color: var(--sidebar-hover); - color: var(--grey-900); -} - -.frm-meta-tag.frm-red-tag, -.frm-meta-tag.frm-red-tag:hover { - background: var(--error-100); - color: var(--error-700); -} - -.frm-meta-tag.frm-orange-tag, -.frm-meta-tag.frm-orange-tag:hover { - background-color: #fef7f4; - color: var(--orange); -} - -.frm-meta-tag.frm-green-tag, -.frm-meta-tag.frm-green-tag:hover { - background-color: var(--success-500); - color: #fff; -} - -.frm-entry-status-0, -.frm-meta-tag.frm-lt-green-tag, -.frm-meta-tag.frm-lt-green-tag:hover { - background-color: var(--success-100); - color: var(--success-800); -} - -.frm-meta-tag.frm-new-pill { - background-color: var(--success-500); - vertical-align: text-bottom; -} - -.frm_add_field span + .frm-meta-tag { - margin-left: 0; -} - -.dropdown-item .frm-meta-tag { - margin-left: 0; -} - -/** - * Components - Upgrade List - */ -/* Start entry statuses */ -.frm-entry-status { - font-weight: 500; -} - -.frm-entry-status-1 { - color: #7a4d05; - background: #fff2d2; -} - -/* End entry statuses */ -#frm-create-footer { - padding: 15px 20px; -} - -li .frm-hover-icons .frm-preview-form, -.frm-hover-icons .frm-unlock-form, -.frm-locked-template .frm-hover-icons .frm-create-form, -.frm-modal-back { - display: none; -} - -.frm-locked-template .frm-hover-icons .frm-unlock-form, -li[data-preview] .frm-hover-icons .frm-preview-form { - display: inline-flex; -} - -.frm-modal-back svg { - color: #7f7f7f; -} - -#frm-upgrade-body-list-wrapper > div { - display: inline-block; - width: 33.3333333333%; - vertical-align: top; - text-align: left; - margin-bottom: 10px; -} - -#frm-upgrade-body-list-wrapper ul { - padding-left: 40px; -} - -#frm-upgrade-body-list-wrapper ul li::before { - content: "\2022"; - color: var(--primary-500); - display: inline-block; - width: 1em; - margin-left: -1em; -} - -/** - * Components - Embed Modal - */ -.frm-embed-modal-content { - padding: var(--gap-md); -} - -.frm-embed-modal-content.frm-loading-page-options { - display: flex; - justify-content: center; -} - -#frm_embed_modal .frm_embed_example { - background: var(--sidebar-color); - border: 1px solid var(--sidebar-hover); - border-radius: var(--small-radius); - color: var(--grey-900); - font-size: var(--text-sm); - padding-right: var(--gap-lg); - width: 100%; - height: auto !important; - resize: none; -} - -#frm_embed_modal textarea.frm_embed_example { - padding-bottom: 0; -} - -.frm-embed-modal-content > div a { - position: absolute; - right: 0; - top: 0; -} - -.frm-embed-modal-content > div { - position: relative; - margin-bottom: var(--gap-sm); -} - -.frm-embed-modal-content > div:last-child { - margin-bottom: 0; -} - -.frm-embed-modal-content svg[id^=frm_copy_embed_] { - position: absolute; - bottom: 10px; /* Input height - SVG height */ - right: 10px; - cursor: pointer; - opacity: 0.5; -} - -.frm-border-info-box, -.frm-embed-modal-option { - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - padding: var(--gap-sm); - cursor: pointer; - display: flex; - gap: var(--gap-sm); - font-size: var(--text-sm); -} - -.frm-embed-modal-option + .frm-embed-modal-option { - margin-top: var(--gap-sm); -} - -.caret.rotate-270, -.frm-embed-modal-option .caret { - align-self: center; - margin-left: auto; - transform: rotate(-90deg); -} - -#frm_embed_modal .frm_modal_footer { - display: none; -} - -#frm_embed_modal.frm-on-page-2 .frm_modal_footer { - display: block; -} - -.frm-embed-modal-content ul { - max-height: 300px; - overflow-y: scroll; -} - -.frm-embed-modal-wrapper.frm-dialog { - overflow: visible; -} - -/** - * Components - Bulk Options - */ -#frm-bulk-modal .frm_grid_container { - grid-template-columns: repeat(12, 8.33%); - grid-gap: 0; -} - -#frm-bulk-modal .frm8 { - border-right: 1px solid var(--grey-300); - padding: 10px 20px 10px var(--gap-lg); -} - -#frm-bulk-modal .frm4 { - padding: 10px 0; -} - -.frm-inline-modal .howto { - margin: 5px 0 10px; - color: var(--grey); -} - -.frm-inline-modal .frm_code_list + .howto { - margin-bottom: 0; -} - -#frm_bulk_options { - height: 240px; - width: 100%; - border: none; - box-shadow: none; - padding: 0; -} - -.frm-bulk-edit-link { - display: flex; - align-items: center; - justify-content: flex-end; - gap: var(--gap-2xs); - font-size: var(--text-sm); - margin: 12px 0 12px auto; -} -.frm-bulk-edit-link .frm-bulk-edit-link { - margin: 0; -} - -/** - * Components - Small Add - */ -.frm-small-add { - font-size: var(--text-sm) !important; -} - -.frm-small-add span { - color: var(--primary-500); - font-size: 12px; - height: 12px; - width: 12px; -} - -/** - * Components - Image From URL - */ -.frm_no_captcha_text { - font-weight: 700; - color: #a00; -} - -.frm_image_from_url { - height: 50px; -} - -/** - * Components - Dropdown - */ -/*Switch form dropdown*/ -h1 .fa-caret-down { - font-size: 18px; -} - -.caret { - display: inline-block; - width: 19px; - height: 9px; - margin-right: -8px; - vertical-align: middle; -} - -.caret, -.wp-admin .frm_wrap select, -.frm_wrap .frm_form_builder select, -.frm_wrap .ui-autocomplete-input { - background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; - padding-right: var(--gap-lg) !important; -} - -.caret { - padding-right: var(--gap-xs) !important; - background-position-x: 5px; -} - -.frm-btn-group .caret { - float: right; - margin-top: calc(var(--text-md) / 2); -} - -.dropdown { - position: relative; -} - -.dropdown-toggle:focus { - outline: 0; -} - -.frm_wrap .ui-autocomplete, -#frm_adv_info.frm-dropdown-menu, -.frm-dropdown-menu { - /* Copied from .dropdown-menu rules from Bootstrap */ - position: absolute; - top: 100%; - left: 0; - z-index: 1000; - display: none; - padding-left: 4px; - padding-right: 4px; - margin: var(--gap-xs) 0 0; - text-align: left; - list-style: none; - background: none; - background-color: #fff; - background-clip: padding-box; - border: 1px solid var(--grey-100); - border-radius: 0.25rem; - box-shadow: var(--box-shadow-lg); - /* Custom rules */ - max-height: 200px; - overflow-y: auto; - overflow-x: hidden; - font-size: var(--text-md); - width: auto; - min-width: 160px; -} - -.frm6 .frm-dropdown-menu { - min-width: 100px; - max-width: 99%; -} - -#frm_bs_dropdown .frm-dropdown-menu { - max-width: 400px; -} - -.field_type_list .frm-dropdown-menu { - min-width: 150px !important; -} - -#frm_field_group_controls .frm-dropdown-menu, -.frm-field-action-icons .frm-dropdown-menu { - min-width: 180px !important; -} - -.frm-field-action-icons .frm-dropdown-toggle svg, -#frm_field_group_controls .frm-dropdown-toggle svg { - color: #9ea9b8; -} - -.multiselect-container.frm-dropdown-menu, -#search-submit .frm-dropdown-menu { - min-width: 200px !important; -} - -.preview .frm-dropdown-menu { - min-width: 230px !important; -} - -.frm-dropdown-menu.dropdown-menu-right { - right: 0; - left: auto; -} - -.frm-dropdown-menu .divider { - height: 1px; - margin: 9px 0; - overflow: hidden; - background-color: #e5e5e5; -} - -.frm-dropdown-menu > .dropdown-item { - margin: 0; -} - -.frm-select-list-item, -.frm_wrap .ui-autocomplete li > div, -.multiselect-container button.multiselect-option, -.frm-dropdown-menu > .dropdown-item > a, -.frm-dropdown-menu .frm_dropdown_li { - clear: both; - font-weight: 400; - white-space: nowrap; - text-decoration: none; - border-radius: var(--small-radius); -} - -.frm-dropdown-menu > .active > a, -.frm-dropdown-menu > .active > a:hover, -.frm-dropdown-menu > .active > a:focus { - text-decoration: none; - outline: 0; -} - -.frm-select-list-item.disabled, -.frm-dropdown-menu > .disabled > a, -.frm-dropdown-menu > .disabled > a:hover, -.frm-dropdown-menu > .disabled > a:focus { - color: #999; -} - -.frm-select-list-item.disabled:hover, -.frm-dropdown-menu > .disabled > a:hover, -.frm-dropdown-menu > .disabled > a:focus { - text-decoration: none; - background-color: transparent; - background-image: none; - cursor: not-allowed; -} - -.open > .frm-dropdown-menu { - display: block; -} - -.open > a { - outline: 0; -} - -.dropdown-header { - display: block; - padding: 3px 10px; - font-size: var(--text-xs); - color: var(--grey-400); -} - -.dropdown-backdrop { - position: fixed; - left: 0; - right: 0; - bottom: 0; - top: 0; - z-index: 990; -} - -.dropdown-menu-right > .frm-dropdown-menu, -.pull-right > .frm-dropdown-menu { - right: 0; - left: auto; -} - -.navbar-fixed-bottom .dropdown .caret { - border-top: 0 dotted; - border-bottom: 4px solid #000; - content: ""; -} - -.navbar-fixed-bottom .dropdown .frm-dropdown-menu { - top: auto; - bottom: 100%; - margin-bottom: 1px; -} - -.btn { - border: 1px solid #ddd; - background: #fff; - height: 28px; - line-height: var(--leading); -} - -a.frm_option_icon::before { - color: var(--primary-500); - font-size: 22px; - width: 22px; - height: 22px; -} - -a.frm_option_icon:focus::before, -a.frm_option_icon:hover::before { - color: var(--primary-700); -} - -.frm_top_left .frm-dropdown-toggle { - color: #999; -} - -.frm-card ol { - margin-left: 15px; -} - -.frm-dropdown-toggle { - text-decoration: none; -} - -.frm-card .frm-dropdown-toggle { - border: 1px solid var(--grey-300); - border-radius: var(--small-radius); - font-size: 13px; - color: var(--grey-700); - padding: 7px 20px; -} - -.frm-dropdown-menu .frm_icon_font { - vertical-align: middle; - color: #5f6c72; - margin-right: 3px; -} - -/* BS Multiselect */ -.multiselect-container.frm-dropdown-menu { - top: auto; - left: auto; - font-size: var(--text-sm); - padding: 4px; - margin-bottom: 3px; -} - -/** - * Accordion - */ -#post-body-content + .frm-right-panel h3.accordion-section-title { - padding: 7px 10px 8px 14px; - font-size: var(--text-md); - color: var(--grey-700); -} - -.frm-with-line, -.accordion-section-content h4 { - font-size: var(--text-md); - font-weight: 400; - margin: 20px -20px 10px; - padding: 0 20px; - color: var(--grey-700); - position: relative; - border: none !important; -} - -.frm-with-line span, -.accordion-section-content h4 span { - background: #fff; - padding: 0 var(--gap-xs); - position: relative; - display: inline-block; - z-index: 2; -} - -.accordion-section-content h4 span { - background: var(--sidebar-color); -} - -.frm-right-panel .frm-with-line span { - background: var(--sidebar-color) !important; - margin-left: -4px; -} - -.frm-right-panel .frm-inline-modal .frm-with-line span { - background: #fff !important; -} - -.frm-with-line::before, -.accordion-section-content h4::before { - content: ""; - display: block; - position: absolute; - border-bottom: 1px solid var(--grey-300); - left: 0; - width: 100%; - top: 50%; -} - -.control-section .accordion-section-title::after, -.customize-pane-child .accordion-section-title::after { - top: 15px; -} - -.accordion-container .frm-dropdown-menu { - min-width: 40px; -} - -.frm-btn-group .multiselect.dropdown-toggle { - box-sizing: border-box; - min-height: unset; - cursor: pointer; -} - -.accordion-container .frm-dropdown-menu::before, -.accordion-container .multiselect.dropdown-toggle::before { - font-family: "s11-fp" !important; -} - -/** - * Components - Multiselect - */ -.multiselect-container { - position: absolute; - list-style-type: none; - margin: 0; - padding: 0; - width: 100%; - max-width: 250px; -} - -.multiselect-container button.multiselect-option { - width: 100%; - text-align: left; - border: none; - margin-bottom: 4px; -} - -.multiselect-container button.multiselect-option label { - margin-left: 5px; -} - -.accordion-container .multiselect-container label { - padding: 3px 19px 3px 7px; -} - -.frm-btn-group.btn-group > .btn-group:nth-child(2) > .multiselect.btn { - border-top-left-radius: 4px; - border-bottom-left-radius: 4px; -} - -.frm-btn-group.btn-group, -.frm-btn-group.btn-group-vertical { - display: block; -} - -.multiselect-option label { - max-width: calc(100% - 22px); - text-overflow: ellipsis; - overflow: hidden; - white-space: nowrap; -} - -/** - * Components - Fields - */ -.frm_scale { - text-align: center; - float: left; - margin-right: 10px; -} - -.frm_scale input { - display: block; - margin: 5px; -} - -.frm_multi_fields_container { - float: left; -} - -.frm_multi_fields_container, -.frm_form_builder .frm_form_fields input[type=tel] .frm_form_builder .frm_form_fields input[type=range], -.frm_form_builder .frm_form_fields input[type=text] { - width: 100%; - height: auto; -} - -.frm_form_builder .frm_time_wrap .frm_time_sep { - vertical-align: sub; - vertical-align: -webkit-baseline-middle; -} - -.frm_form_builder input[type=range]::-webkit-slider-runnable-track { - background-color: var(--blue-border); -} - -.frm_form_builder input[type=range]::-moz-range-track { - background-color: var(--blue-border); -} - -.frm_form_builder input[type=range]::-ms-fill-lower { - background-color: var(--blue-border); -} - -.frm_form_builder input[type=range]::-ms-fill-upper { - background-color: var(--blue-border); -} - -.frm-embed-field-placeholder { - text-align: center; - height: 145px; - display: flex; - align-items: center; - justify-content: center; -} - -.frm-fake-field { - display: block; - height: 25px; - background-color: var(--light-blue); - border: 1px solid var(--grey-300); - margin: 10px 0; - border-radius: var(--small-radius); -} - -.frm-embed-message { - position: absolute; - background: #fff; - border: 1px solid var(--grey-300); - color: var(--grey-700); - padding: var(--gap-md); - font-size: var(--text-lg); - max-width: 200px; - min-width: 50%; - margin: 0 var(--gap-md); - overflow: hidden; - text-overflow: ellipsis; -} - -.frm-summary-message { - top: 50%; - left: 50%; - padding: 15px 0; - font-size: var(--text-md); - transform: translate(-50%, -50%); -} - -.frm-summary-learn-more { - font-size: inherit !important; -} - -.frm-single-settings .frm-embed-message { - width: 100%; - position: static; - border-radius: var(--small-radius); -} - -#new_fields input[type=text], -#new_fields input[type=number], -.frm_field_box .frm_form_fields > textarea, -.frm_form_fields .frm_form_field > textarea, -.frm_form_fields .frm_form_field > input[type=email], -.frm_form_fields .frm_form_field > input[type=url], -.frm_form_fields .frm_form_field > input[type=number], -.frm_form_fields .frm_form_field > input[type=tel], -.frm_form_fields .frm_form_field > input[type=text], -.frm_form_fields .frm_form_field > input[type=range] { - width: 100%; -} - -.frm_form_fields textarea.wp-editor-area { - width: 100%; - border: none; -} - -.frm_form_fields input[type=file], -.frm_form_fields input[type=file]:disabled { - background: transparent; - border: none; - box-shadow: none; - width: auto; -} - -.frm_form_fields select { - width: auto; - max-width: 100%; -} - -input[type=radio], -input[type=checkbox] { - width: 16px; - padding: 0; -} - -.frm_grid_container > p, -.frm_grid_container > p.frm_form_field, -.frm_grid_container > div.frm_form_field, -#new_fields .frm_grid_container > p { - margin-top: 8px; - margin-bottom: 8px; - margin-right: 0; -} -.frm_grid_container > p > label:only-child, -.frm_grid_container > p.frm_form_field > label:only-child, -.frm_grid_container > div.frm_form_field > label:only-child, -#new_fields .frm_grid_container > p > label:only-child { - margin-bottom: 0; -} - -.frm_grid_container > .frm-has-modal > p:only-child { - margin-bottom: var(--gap-xs); -} - -#new_fields div.frm_grid_container > .frm_primary_label { - margin-top: 8px; -} - -#new_fields .frm_primary_label + p, -#new_fields .frm_primary_label + .frm6 + .frm6, -#new_fields .frm_primary_label + .frm6 + .frm-inline-modal + .frm6 { - margin-top: 0; -} - -.frm_catlevel_2, -.frm_catlevel_3, -.frm_catlevel_4, -.frm_catlevel_5 { - margin-left: 18px; -} - -.frm_wrap .frm-fields .auto_width, -.frm_form_fields input.auto_width, -.frm_form_fields select.auto_width, -.frm_form_fields textarea.auto_width { - width: auto !important; -} - -.frm_form_fields select.auto_width { - min-width: 60px; -} - -.frm_form_fields input:focus, -.frm_form_fields select:focus, -.frm_form_fields textarea:focus, -.frm_focus_field input { - background-color: #fff; - border-color: #ddd; -} - -.frm_form_builder .frm_radio, -.frm_form_builder .frm_checkbox { - display: block; - margin-bottom: 2px; -} - -.frm_form_builder .frm_radio label, -.frm_form_builder .frm_checkbox label { - font-size: var(--text-sm); -} - -/** - * Components - Copied Frontend - */ -.horizontal_radio .frm_radio, -.horizontal_radio .frm_checkbox { - margin-right: 5px; - display: inline-block; -} - -.frm_form_builder .frm_opt_container .frm_radio.frm_image_option label, -.frm_form_builder .frm_opt_container .frm_checkbox.frm_image_option label { - display: flex; - align-items: center; - gap: 9px; - white-space: normal; -} - -.frm_form_field.frm_two_col .frm_opt_container, -.frm_form_field.frm_three_col .frm_opt_container, -.frm_form_field.frm_four_col .frm_opt_container { - display: grid; - grid-template-columns: repeat(2, 1fr); - grid-auto-rows: max-content; - grid-gap: 0 2.5%; -} - -.frm_form_field.frm_three_col .frm_opt_container { - grid-template-columns: repeat(3, 1fr); -} - -.frm_form_field.frm_four_col .frm_opt_container { - grid-template-columns: repeat(4, 1fr); -} - -.frm_form_field.frm_two_col .frm_radio, -.frm_form_field.frm_two_col .frm_checkbox, -.frm_form_field.frm_three_col .frm_radio, -.frm_form_field.frm_three_col .frm_checkbox, -.frm_form_field.frm_four_col .frm_radio, -.frm_form_field.frm_four_col .frm_checkbox { - grid-column-end: span 1; -} - -/** - * Components - Fields Part 2 - */ -.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox], -.frm_wrap .with_frm_style .frm_radio input[type=radio], -.frm_wrap input[type=checkbox], -.frm-white-body input[type=checkbox], -.field-group input[type=checkbox], -.frm_scale input[type=radio], -.frm_radio input[type=radio], -.frm_checkbox input[type=checkbox] { - width: 15px; - min-width: 15px; - height: 15px; - border: 1px solid var(--grey-300); - box-shadow: var(--box-shadow-sm); - -webkit-appearance: none; -} - -.frm_wrap input[type=radio] { - border-color: var(--grey-300); - box-shadow: var(--box-shadow-sm); -} -.frm_wrap input[type=radio]:checked::before { - background-color: var(--primary-500); -} - -.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox], -.frm_wrap input[type=checkbox], -.frm-white-body input[type=checkbox], -.field-group input[type=checkbox], -.frm_checkbox input[type=checkbox] { - border-radius: 4px; -} - -.frm-white-body input[type=checkbox]:checked, -.frm_wrap input[type=checkbox]:checked { - background-color: var(--border-color-active, var(--primary-500)) !important; - border-color: var(--border-color-active, var(--primary-500)) !important; -} - -.frm-white-body input[type=checkbox]:checked:focus, -.frm_wrap input[type=checkbox]:checked:focus { - border-color: var(--border-color-active, var(--primary-500)); -} - -.frm-white-body input[type=checkbox]:checked::before, -.frm_wrap input[type=checkbox]:checked::before { - content: ""; - display: block; - width: 100% !important; - height: 100% !important; - background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.6667 1.5L4.25001 7.91667L1.33334 5' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A") !important; - background-size: 8px !important; - background-repeat: no-repeat !important; - background-position: center !important; - margin: 0; -} - -.frm_radio input[type=radio], -.frm_checkbox input[type=checkbox] { - margin-right: 5px; -} - -.frm_inner_field_container { - margin-bottom: 10px; -} - -.frm_conf_inline .frm_inner_field_container, -.frm_conf_inline .frm_inner_conf_container { - width: 49%; - float: left; -} - -.frm_conf_inline .frm_inner_field_container { - margin-right: 2%; - clear: both; -} - -.frm_inner_field_container > label { - text-overflow: ellipsis; - overflow: hidden; - white-space: nowrap; -} - -.frm_field_box:not(.edit_field_type_divider):hover > .frm_inner_field_container > label, -.frm_field_box .divider_section_only:hover > .frm_inner_field_container > label, -li.ui-state-default.selected > .frm_inner_field_container > label { - max-width: calc(100% - 100px); -} - -.frm-drag-fade { - background-color: var(--lightest-grey) !important; - border-radius: 4px; -} - -.frm-drag-fade * { - opacity: 0; -} - -.frm-dragging .divider_section_only, -.frm-dragging .frm_field_box { - pointer-events: none; -} - -.frm_form_settings #op-popup, -.frm_form_settings com-1password-op-button, -.frm_conf_below .frm_conf_field_container .frm_primary_label, -.frm_conf_inline .frm_inner_field_container .frm-show-click a, -.frm_conf_below .frm_conf_field_container .frm-show-click a { - display: none !important; -} - -.frm_conf_inline .frm_inner_field_container .frm-field-action-icons { - position: absolute; - right: 5px; -} - -.frm_conf_below .frm_conf_field_container { - margin-top: 10px; -} - -.frm_calc_dec { - width: 50px; -} - -.frm_ext_sc { - display: none; -} - -.frm_long_input { - width: 100% !important; - box-sizing: border-box; -} - -/** - * Utilities - Text Align - Part 2 - */ -.frmcenter { - text-align: center; -} - -/** - * Components - Image Help - */ -img.frm_help { - margin-left: 2px; - vertical-align: middle; - padding-bottom: 2px; -} - -/** - * Components - Loading - */ -.frm_spinner.frm-wait, -.frm_spinner.spinner { - float: left; - visibility: hidden; - margin: 0 10px; -} - -.frm_visible_spinner.frm-wait, -.frm_visible_spinner.spinner { - visibility: visible; - float: none; -} - -.frm_form_action_settings .frm_spinner.frm-wait, -.frm_form_action_settings .frm_spinner.spinner { - visibility: visible; - float: none; - vertical-align: bottom; -} - -.frm_form_action_settings .frm_loading { - font-size: 15px; - text-align: center; -} - -.frm_ajax_settings_tab .frm-wait, -.frm_ajax_settings_tab .spinner { - visibility: visible; - float: none; - margin-top: 20px; -} - -.wp-core-ui .frm_loading_button.button-primary.frm-button-primary, -.frm_loading_button, -.frm_loading_form.frm_button_submit { - position: relative !important; - opacity: 0.8; - color: transparent !important; - text-shadow: none !important; -} - -.frm_loading_button:hover, -.frm_loading_button:active, -.frm_loading_button:focus, -.frm_loading_form.frm_button_submit:hover, -.frm_loading_form.frm_button_submit:active, -.frm_loading_form.frm_button_submit:focus { - cursor: not-allowed; - color: transparent !important; - outline: none !important; - box-shadow: none; -} - -.frm-wait { - margin: 20px; - width: 20px; - height: 20px; - position: relative; - display: inline-block; -} - -#frm-show-fields .frm-wait:only-child { - position: absolute; - left: 50px; - top: 30px; -} - -.frm-wait::before, -.frm_loading_button::before, -.frm_loading_form.frm_button_submit::before { - content: ""; - display: inline-block; - position: absolute; - background: transparent; - border: 1px solid #fff; - border-top-color: transparent; - border-left-color: transparent; - border-radius: 50%; - box-sizing: border-box; - top: 50%; - left: 50%; - margin-top: -10px; - margin-left: -10px; - width: 20px; - height: 20px; - animation: spin 2s linear infinite; -} - -.frm-wait::before { - border-bottom-color: var(--primary-700); - border-right-color: var(--primary-700); -} - -.frm_loading_button.frm-button-secondary::before { - border-bottom-color: var(--primary-500); - border-right-color: var(--primary-500); -} - -input[type=submit]:focus { - outline: none !important; -} - -/* Effects */ -@keyframes spin { - 0% { - transform: rotate(0deg); - } - 100% { - transform: rotate(360deg); - } -} -/** - * Components - Fields Part 3 - */ -label input[type=checkbox], -label input[type=radio] { - vertical-align: inherit; -} - -#editorcontainer #dyncontent { - margin: 0; - width: 100%; - padding: 6px; - line-height: var(--leading); - border: 0 none; - outline: none; - box-sizing: border-box; -} - -/*ICONS*/ -.frm_postbox_icon { - margin: -6px 0 0 -10px; -} - -.frm_form_builder a:hover { - text-decoration: underline; -} - -.frm_form_builder .widget-title h4 { - padding: 10px 15px; -} - -.frm_form_builder .widget-top a.widget-action::after { - margin: 7px 12px 0; -} - -.frmbutton.frm_tgateway { - display: none !important; -} - -.frm_html_legend pre { - display: inline; -} - -#ed_fullscreen { - display: none !important; -} - -.frm_posttax_opt_list { - overflow: auto; - max-height: 200px; - background-color: #fff; -} - -.frm_posttax_opt_list p.howto { - font-size: 12px; -} - -.frm_border_bottom { - border-bottom: 1px solid var(--grey-300); - margin-bottom: 10px; - padding-bottom: 10px; -} - -.frm_posttax_opt_list .frm_border_bottom span.howto { - padding-right: 10px; -} - -.frm_posttax_opt_list .frm_border_bottom input { - margin-right: 1px; -} - -.frm_add_remove div.frm_form_field { - padding-bottom: 5px; -} - -.frm_field_opts_list { - max-height: 260px; - overflow: auto; -} - -/** - * Utilities - Background - */ -.frm_white_bg, -.frm-bg-white { - background-color: #fff; -} - -.frm-bg-grey-50 { - background-color: var(--grey-50); -} - -.frm-bg-grey-200 { - background-color: var(--grey-200); -} - -.frm-bg-grey-800 { - background-color: var(--grey-800); -} - -.frm-bg-primary-500 { - background-color: var(--primary-500); -} - -/** - * Utilities - Border - Light - */ -.frm_border_light { - border: solid 1px #ddd; -} - -/** - * Components - Form Input Styles - */ -#new_fields .form-table input[type=text], -#new_fields .form-table select, -.form-table .form-field input, -.form-table .form-field .quicktags-toolbar input, -.form-field input, -.form-field .quicktags-toolbar input { - width: auto; -} - -/** - * Components - Affiliate Link - */ -.frm_aff_link { - float: right; -} - -/** - * Component: Select Box - */ -.frm_select_box { - text-align: center; - font-weight: 700; - width: 100%; - background-color: transparent !important; -} - -.wp-list-table input.frm_select_box { - text-align: left; - font-weight: 400; - font-size: inherit !important; - border: none; - padding: 0 !important; - background-color: transparent !important; -} - -.wp-list-table input.frm_select_box:focus { - outline: none; - box-shadow: none; -} - -.wp-list-table .frm_no_items.frm_select_box { - text-align: center; - font-weight: 700; - width: 500px; - max-width: 100%; - font-size: inherit; -} - -/** - * Component: Options Panel - */ -#frm-options-panel { - padding: 0 var(--gap-sm); - color: var(--grey-900); - overflow: hidden; -} - -.frm-right-panel a.frm_add_logic_link, -#frm-options-panel h3, -.frm-collapsible { - font-size: var(--text-md); - font-weight: 500; - background-color: #fff; - border-radius: var(--small-radius); - padding: 18px var(--gap-sm); - margin: 2px calc(-1 * var(--gap-sm)); - transition: background-color 200ms ease-out, box-shadow 200ms ease-out, color 200ms ease-out; -} -.frm-right-panel a.frm_add_logic_link .frmsvg, -#frm-options-panel h3 .frmsvg, -.frm-collapsible .frmsvg { - width: 13px; - height: 13px; - color: var(--grey-500); - transition: transform 300ms ease-in; -} -.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type), .frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child, -#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type), -#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child, -.frm-collapsible:not(.frm-collapsed):not(:first-of-type), -.frm-collapsible:not(.frm-collapsed):first-of-type:first-child { - color: var(--grey-700); - box-shadow: var(--box-shadow-sm); -} -.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type) .frmsvg, .frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child .frmsvg, -#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type) .frmsvg, -#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child .frmsvg, -.frm-collapsible:not(.frm-collapsed):not(:first-of-type) .frmsvg, -.frm-collapsible:not(.frm-collapsed):first-of-type:first-child .frmsvg { - transform: rotate(-180deg); -} -.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div, -#frm-options-panel h3:not(.frm-collapsed) + div, -.frm-collapsible:not(.frm-collapsed) + div { - padding-top: 6px; - padding-bottom: 6px; -} -.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div.frm_grid_container, -#frm-options-panel h3:not(.frm-collapsed) + div.frm_grid_container, -.frm-collapsible:not(.frm-collapsed) + div.frm_grid_container { - padding-bottom: 14px; -} -.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div.frm_grid_container > p:first-child, -#frm-options-panel h3:not(.frm-collapsed) + div.frm_grid_container > p:first-child, -.frm-collapsible:not(.frm-collapsed) + div.frm_grid_container > p:first-child { - margin-top: var(--gap-sm); -} -.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed) + div.frm_grid_container > p:first-child.frm6 + .frm6, -#frm-options-panel h3:not(.frm-collapsed) + div.frm_grid_container > p:first-child.frm6 + .frm6, -.frm-collapsible:not(.frm-collapsed) + div.frm_grid_container > p:first-child.frm6 + .frm6 { - margin-top: var(--gap-sm); -} -.frm-right-panel a.frm_add_logic_link.frm-collapsed, -#frm-options-panel h3.frm-collapsed, -.frm-collapsible.frm-collapsed { - color: var(--grey-500); - background-color: transparent; -} -.frm-right-panel a.frm_add_logic_link:hover, -#frm-options-panel h3:hover, -.frm-collapsible:hover { - color: var(--grey-700); - background-color: #fff; - box-shadow: var(--box-shadow-sm); -} -.frm-right-panel a.frm_add_logic_link:focus-visible, -#frm-options-panel h3:focus-visible, -.frm-collapsible:focus-visible { - outline: 1px solid var(--primary-500) !important; - outline-offset: -1px; -} - -h4.frm-collapsible:hover { - box-shadow: none; -} - -.frm-right-panel a.frm_add_logic_link:focus { - outline: auto; -} - -/** - * Component: Field Key - */ -.frm_field_key { - background-color: #f7f7f7; -} - -/** - * Component: Form Editor - */ -#frm_form_editor_container #edit-slug-box { - padding: 0; -} - -/** - * Component: Alt Table - */ -.frm-alt-table { - position: relative; - width: 100%; - border-collapse: collapse; - margin-top: 0.5em; - font-size: 15px; -} - -/* Before `applyZebraStriping` is executed, an empty space is displayed */ -#form_show_entry_page .frm-alt-table:not(.frm-zebra-striping)::before { - content: ""; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - background-color: #fff; -} - -.frm-alt-table th { - width: 200px; -} - -.frm-alt-table tr, -.frm-alt-table tr.frm-odd { - background-color: transparent; -} - -.frm-alt-table tr.frm-even { - background-color: var(--sidebar-color); -} - -.frm-alt-table th, -.frm-alt-table td { - background-color: transparent; - vertical-align: top; - text-align: left; - padding: 20px; -} - -.frm-alt-table h3 { - margin-bottom: 0; -} - -/** - * Component: Checkbox Button - */ -.form-field .frm_cb_button { - height: 22px; - line-height: 20px; - margin-bottom: 10px; - margin-right: 5px; -} - -/** - * Option Label - */ -.edit_field_type_select .frm_option_val_label { - margin-left: 12px; -} - -/** - * Components - Rich Text Editor - */ -.frm_rte { - background: url(../images/rte.png) no-repeat; -} - -.frm_rte .howto { - margin: 10px 0 46px; -} - -/** - * Component: Subform Section - */ -.subform_section { - margin: 25px; -} - -.subform_section, -.subform_section label, -.subform_section input { - opacity: 80; -} - -.subform_section .frm_sortable_field_opts { - display: none; -} - -#frm_form_editor_container .subform_section .frm_primary_label { - display: block; -} - -.subform_section.subform_break { - border-top: 1px dashed #ccc; -} - -/** - * Component: HTML Field - */ -.button-secondary.frm_html_field { - background-color: #ededed; - padding: 10px 20px; - line-height: inherit; - width: auto; - height: auto !important; - border-radius: 0; - box-sizing: content-box; -} - -.frm_html_field_placeholder { - margin-bottom: 10px; - text-align: center; -} - -.recaptcha_placeholder { - border: 1px solid #d3d3d3; - width: 300px; -} - -.turnstile_placeholder { - width: 300px; -} - -/** - * Component: RTE Textarea - */ -.frm_sorting .frm_rte textarea { - width: 653px; - background: #fff; - margin: 1px 0 0; - border: 1px solid #dfdfdf; - border-top: none; - border-radius: 0; - float: none !important; -} - -.frm_full_rte textarea { - width: 98%; - padding: 0; -} - -/** - * Component: Field Box - */ -.frm_field_box { - padding: 5px; - min-height: 20px; - margin: 10px 0; -} - -/** - * Components - Indent Options - */ -.frm_indent_opt, -td.frm_indent_opt { - padding-left: 25px; -} - -/** - * Components - Charts - */ -.frm_charts object { - background: transparent; -} - -.frm_charts h2 { - height: 34px; -} - -/** - * Component: Sortable Placeholder - */ -.frm_single_option.ui-sortable-placeholder, -li.sortable-placeholder { - border: none; - margin: 0; - visibility: visible !important; - box-shadow: 2px -10px 0 2px var(--primary-500); -} - -#frm_form_editor_container > ul > .frm_single_option.ui-sortable-placeholder, -#frm_form_editor_container > ul > li.sortable-placeholder { - width: calc(100% - 5px) !important; - height: 0 !important; -} - -#frm_form_editor_container > ul > li > ul { - position: relative; -} - -#frm_form_editor_container > ul > li > ul > li.sortable-placeholder, -#frm_form_editor_container ul.start_divider > li > ul > li.sortable-placeholder { - position: absolute; - top: 20px; - bottom: 0; -} - -.edit_field_type_divider + li.sortable-placeholder { - box-shadow: 2px 5px 0 2px var(--primary-500); -} - -.start_divider li.sortable-placeholder { - box-shadow: 2px -5px 0 2px var(--primary-500); -} - -.frm-is-collapsed + .sortable-placeholder { - box-shadow: 2px 15px 0 2px var(--primary-500); -} - -.frm_single_option.ui-sortable-placeholder { - box-shadow: 0 0 1px 1px var(--primary-500); -} - -/** - * Component: Sorting Display - */ -.frm_sorting > li.edit_field_type_end_divider:first-child, -.frm-show-click, -li.ui-state-default.edit_field_type_divider .frm-show-click { - display: none; -} - -.frm_form_field.ui-sortable-helper .frm-field-action-icons, -.frm_form_field.ui-sortable-helper .frm_form_fields, -.frm_form_field.ui-sortable-helper .frm_description, -.frm_form_field.ui-sortable-helper .description { - display: none; -} - -.frm_form_field.ui-sortable-helper .frm_primary_label, -.frm_form_field.ui-sortable-helper .frm_inner_field_container { - margin: 0 !important; -} - -.frm-single-settings .frm-show-click { - display: block !important; -} - -.frm-show-hover, -.frm_single_visible_hover, -li.ui-state-default.edit_field_type_divider .frm-show-hover { - opacity: 0; - transition: opacity 0.15s ease-in-out; -} - -#frm-show-fields .frm-field-settings-open .frm-show-hover { - opacity: 1; -} - -.frm_sortable_field_opts { - margin-top: 5px; -} - -/** - * Component: Single Option - */ -.frm_single_option { - clear: both; - margin: 0 !important; - padding-bottom: 5px; -} -.frm_single_option input[type=radio], -.frm_single_option input[type=checkbox] { - margin-top: 0; -} -.frm_single_option .frm-with-right-icon input[type=text] + .frmsvg { - position: relative; - right: 27px; - width: 14px; - height: 14px; - padding: 0; - margin: var(--gap-2xs) 0 0; -} - -.frm_product_price_wrapper, -.frm_image_preview_wrapper, -#new_fields .frm_single_option select, -#new_fields .frm_single_option input[type=text] { - width: calc(100% - 106px) !important; - flex-grow: 1; -} - -.frm-right-panel .frm_single_option a.frm_remove_tag, -.frm_single_option a { - padding-left: 7px; -} - -.frm_single_option:hover .frm_single_visible_hover { - opacity: 100; -} - -.frm_single_option .frm-drag { - font-size: 23px; - width: 24px; - height: 24px; - margin-left: -6px; - margin-right: var(--gap-xs); - color: var(--grey-500); -} - -.frm_single_option .frm-drag::before { - vertical-align: middle; -} - -.frm-drag, -.frm_single_option.ui-sortable-helper { - cursor: move; -} - -.frm_single_option .frm_option_key.frm_image_preview_wrapper, -.frm-type-ranking .frm_single_option .frm_option_key { - margin-left: 21px !important; -} - -.frm_option_key input[type=text] { - margin-top: var(--gap-xs) !important; - margin-left: 11px !important; -} -.frm_option_key input[type=checkbox] + input[type=text], -.frm_option_key input[type=radio] + input[type=text] { - margin-left: 30px !important; -} - -.frm-type-ranking .frm_option_key input[id*=field_key_] { - margin-left: 30px !important; -} - -li.ui-state-default.selected .frm-show-click, -li.ui-state-default.selected.edit_field_type_divider .frm-show-click { - display: inline; - vertical-align: top; -} - -.frm_field_box:not(.edit_field_type_divider):hover > .frm_inner_field_container > .frm-show-hover, -.frm_field_box .divider_section_only:hover > .frm_inner_field_container > .frm-show-hover, -li.ui-state-default.selected > .frm_inner_field_container > .frm-show-hover, -li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover { - opacity: 100; -} - -li.frm_field_box > ul.frm_grid_container { - position: relative; -} - -/** - * Component: UI Icon - */ -.frm_sorting span.ui-icon { - width: 16px; -} - -/** - * Component: Entry Page - */ -body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) .frm_image_options .frm_image_option_container { - --field-border-width: 1px; - --border-color: var(--grey-300); - --border-color-active: var(--primary-500); - --border-radius: var(--small-radius); -} - -#form_show_entry_page .frm_file_link, -#form_show_entry_page .frm_image_option_container { - display: inline-flex; - flex-wrap: nowrap; - flex-direction: column; - text-align: center; - align-items: center; - width: 150px; - margin-right: 10px; - margin-bottom: 10px; -} - -#form_show_entry_page .frm_image_option_container img { - width: 150px; - height: 150px; - object-fit: cover; -} - -#form_show_entry_page .frm_file_link img { - max-width: 150px; - height: auto; -} - -#form_show_entry_page .frm_file_link ~ br { - display: none; -} - -#form_show_entry_page .frm_upload_label { - padding: 10px; -} - -#form_show_entry_page.frm_wrap .postbox { - overflow: hidden; -} - -.frm_image_option_container .frm_image_placeholder_icon svg { - height: 150px; -} - -.frm_list_entry_page .frm_file_link, -.frm_list_entry_page .frm_image_option_container.frm_label_with_image { - display: block; - text-align: center; -} - -.frm_list_entry_page .frm_image_option_container img { - width: 75px; - height: 75px; - object-fit: cover; -} - -.frm_list_entry_page img { - max-width: 100%; - height: auto; -} - -.frm_image_option_container .frm_empty_url { - background-color: var(--sidebar-color); -} - -.frm_list_entry_page .frm_image_option_container .frm_text_label_for_image { - display: block; - padding: 5px 0 10px; -} - -.frm_list_entry_page .frm_upload_label, -.frm-summary-page-wrapper .frm_text_label_for_image { - display: block; -} - -/** - * Welcome and Global Settings Image Options - */ -#frm-welcome .frm_image_options .frm_image_option_container, -#form_global_settings .frm_image_options .frm_image_option_container { - background: var(--sidebar-color); -} - -#frm-welcome .frm_image_option_container svg, -#form_global_settings .frm_image_option_container svg { - max-width: calc(100% - 20px); -} - -/** - * Component: Option Templates - */ -/* Style image option container for Directory add on. */ -#frm-new-template .frm_image_option_container svg { - height: 50px; - margin: 10px auto 0; -} - -/* Show an icon on top */ -.frm_image_option_container { - position: relative; -} - -.frm_text_label_for_image > svg { - width: 30px; - position: absolute; - top: 5px; - right: calc(50% - 15px); -} - -/* End show an icon on top */ -.frm_single_option .frm_option_key { - margin-top: 17px; -} -.frm_single_option .frm_option_key.frm_image_preview_wrapper { - margin-top: var(--gap-xs); -} - -/** - * Component: Image - */ -.frm_image_data { - margin-left: var(--gap-sm); - display: flex; - flex-direction: column; - font-size: var(--text-sm); - justify-content: space-around; - min-width: 0; /* Allows flex items to shrink below content size */ -} - -.frm_image_styling_frame { - display: flex; - align-items: stretch; - margin-left: 36px; - margin-bottom: var(--gap-xs); - width: 100%; -} -.frm_image_styling_frame img { - height: 54px; - width: 54px; - min-width: auto; - min-height: auto; - border-radius: 3px; - object-fit: cover; - object-position: center; -} -.frm_image_styling_frame .frm_email_attachment_icon img { - height: auto; - width: auto; - max-width: 54px; -} - -.frm_image_preview_title { - color: var(--grey-500); - overflow: hidden; - white-space: nowrap; - text-overflow: ellipsis; - min-width: 0; /* Critical for text truncation in flex */ - flex: 1 1 auto; /* Better flex behavior */ -} - -.frm_wrap .frm_choose_image_box { - cursor: pointer; - color: var(--primary-500); - background-color: #fff; - margin-left: 32px; - text-align: center; - width: 100%; -} - -.frm-type-ranking .frm_option_key .frm_choose_image_box { - margin-left: 11px !important; -} - -.frm_wrap .frm_choose_image_box:hover { - background: #fff; -} - -a.frm_remove_image_option, -.frm_remove_image_option { - color: var(--grey-400); - cursor: pointer; -} - -a.frm_remove_image_option:hover .frmsvg, -a.frm_remove_image_option:hover, -.frm_remove_image_option:hover { - color: rgba(40, 47, 54, 0.8); -} - -/** - * Component: Settings and Panel - */ -/* Form Settings Tabs */ -.frm-form-setting-tabs { - margin-top: var(--gap-sm) !important; -} - -.frm-right-panel > .postbox { - background-color: transparent; - border: none; - box-shadow: none; - margin: 0; -} - -.frm-right-panel .postbox.frm_with_icons .inside, -.frm-right-panel .postbox .inside, -.frm-right-panel .inside { - font-size: var(--text-md); - padding: 15px 20px 20px; - color: var(--grey-700); -} - -.frm-right-panel .misc-pub-section { - padding: var(--gap-xs) 0; - position: relative; -} - -.frm-right-panel .inside a, -.frm-form-setting-tabs a { - font-size: var(--text-md); - color: var(--grey-700); - padding: var(--gap-sm); - display: block; -} - -.frm-form-setting-tabs a { - color: var(--grey-900); - padding: var(--gap-sm) var(--gap-md); -} - -.frm-right-panel .inside a { - padding: 0; - color: var(--primary-500); - display: inline-block; -} - -.frm-right-panel .inside a:hover { - color: var(--primary-700); -} - -.frm-form-setting-tabs a:hover { - background: var(--sidebar-hover); - color: var(--grey-900); -} - -.frm-right-panel .inside i, -.frm-form-setting-tabs a i, -.frm-form-setting-tabs a .frmsvg { - margin: 0 5px; - display: inline-block; - width: 20px; - height: 20px; - color: var(--grey-500); -} - -.frm-form-setting-tabs a .frmsvg { - margin: 0; -} - -.frm-right-panel .inside a:hover i, -.frm-right-panel .inside a:hover .frmsvg, -.frm-form-setting-tabs a:hover .frmsvg, -.frm-form-setting-tabs a:hover span { - color: var(--grey-700); -} - -.frm_settings_form .tabs-panel { - padding: 0 25px; -} - -#form_settings_page .tabs-panel, -.frm_settings_form .tabs-panel { - max-height: initial !important; - min-height: 50px !important; -} - -#frm_adv_info .tabs-panel { - min-height: 0 !important; - overflow-x: hidden; - padding: 0; - border: none; - background: transparent; -} - -select.frm_cancelnew, -input.frm_enternew { - width: 175px; -} - -.frm_posttax_opt_list { - border: 1px solid var(--grey-300); - padding: var(--gap-md); - border-radius: var(--small-radius); - margin: 5px 0 5px var(--gap-md); -} - -/* Color picker CSS */ -.frm_settings_form .wp-picker-open + .wp-picker-input-wrap, -.frm-right-panel .wp-picker-open + .wp-picker-input-wrap { - position: absolute; - margin-left: calc((100% - 35px) * -1); - margin-top: 1px; - width: calc(100% - 36px); -} -.frm_settings_form .wp-picker-container input[type=text].wp-color-picker, -.frm-right-panel .wp-picker-container input[type=text].wp-color-picker { - border: none; - padding: 5px 8px; - font-family: inherit; - color: var(--grey-700); - font-size: var(--text-md); - width: 100%; - line-height: var(--leading); -} -.frm_settings_form .wp-picker-input-wrap .wp-picker-clear, -.frm-right-panel .wp-picker-input-wrap .wp-picker-clear { - display: none !important; -} -.frm_settings_form .wp-picker-holder, -.frm-right-panel .wp-picker-holder { - position: absolute; - z-index: 999; -} -.frm_settings_form .wp-picker-input-wrap label, -.frm-right-panel .wp-picker-input-wrap label { - margin-bottom: 0; -} -.frm_settings_form .wp-picker-container .wp-color-result.button, -.frm-right-panel .wp-picker-container .wp-color-result.button { - width: 100%; - overflow: hidden; - margin: 0 !important; - height: var(--h-md) !important; - padding: 0 0 0 var(--gap-lg) !important; - border-radius: var(--small-radius); - border-color: var(--grey-300); -} -.frm_settings_form .wp-color-result-text, -.frm-right-panel .wp-color-result-text { - line-height: var(--leading) !important; - font-size: var(--text-md); - background: #fff !important; - color: var(--grey-900); - padding: 5px 8px; - border-color: var(--grey-300); - text-align: left; -} -.frm_settings_form .color-alpha, -.frm-right-panel .color-alpha { - width: var(--gap-lg) !important; -} - -.frm_grid_container .wp-picker-container { - width: 100%; - position: relative; -} - -.wp-picker-container button.wp-color-result { - border: 1px solid var(--grey-300) !important; -} - -.wp-picker-container .wp-picker-input-wrap input.hex.wp-color-picker { - max-width: 100%; - position: relative; -} - -.frm_end .wp-picker-holder { - margin-left: -145px; -} - -.frm_end.frm6 .wp-picker-holder { - margin-left: -86px; -} - -/* End of color picker CSS */ -/** - * Toggle Components - * - * These are the styles for the "Enable Formidable styling" toggle in the visual styler. - * To use this element, you can call the FrmHtmlHelper::toggle function. - */ -.frm_toggle_opt { - padding: 0; - white-space: normal; - display: inline; - vertical-align: middle; - font-weight: 400; -} - -.frm_on_label, -.frm_off_label { - color: var(--grey-700); -} - -.frm_toggle { - position: relative; - display: inline-block; - width: 40px; - height: var(--h-xs); - vertical-align: middle; -} - -.frm_toggle_block { - display: inline-flex !important; - gap: var(--gap-xs); - align-items: center; -} - -.frm_toggle input, -.frm_toggle_block input { - display: none !important; -} - -.frm_toggle_slider { - position: absolute; - cursor: pointer; - top: 0; - left: 0; - right: 0; - bottom: 0; - background-color: var(--grey-200); - transition: 0.4s; - border-radius: 30px; -} - -.frm_toggle_slider::before { - box-sizing: border-box; - content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E"); - position: absolute; - left: 2px; - bottom: 2px; - display: flex; - align-items: center; - justify-content: center; - width: 20px; - height: 20px; - font-size: 20px; - line-height: 20px; - background-color: #fff; - border-radius: 50%; - transition: 0.4s; - box-shadow: var(--box-shadow-md); -} - -input:checked + .frm_toggle .frm_toggle_slider { - background-color: var(--primary-500); -} - -input:focus + .frm_toggle .frm_toggle_slider { - box-shadow: var(--box-shadow-md); -} - -input:checked + .frm_toggle .frm_toggle_slider::before { - transform: translateX(16px); - content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E"); -} - -input[disabled] + .frm_toggle_slider, -input[disabled] + .frm_toggle .frm_toggle_slider { - pointer-events: none; - cursor: text; - opacity: 0.5; -} - -.frm_toggle_opt ~ .frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before { - content: "" !important; /* Don't show x/check if off label included or on builder page */ -} - -.rtl .frm_toggle_opt { - padding: 0 8px; -} - -.rtl .frm_toggle_slider::before { - left: 17px; -} - -.rtl input:checked + .frm_toggle .frm_toggle_slider::before { - transform: none !important; - left: 1px; -} - -/* Deprecated admin toggle */ -.frm_toggle_off, -.frm_toggle_on { - display: none; - color: #fff; - z-index: 999; - position: absolute; - font-size: 10px; - line-height: 20px; - left: 6px; -} - -.frm_toggle_off { - display: inline; - left: auto; - right: 5px; - color: var(--dark-grey); -} - -.frm_toggle_long { - width: 80% !important; - height: 28px; - display: inline-block !important; -} - -.frm_toggle_long .frm_toggle_slider { - background: var(--primary-700); - box-shadow: 0 0 0 2px var(--primary-700); -} - -.frm_toggle_long .frm_toggle_off, -.frm_toggle_long .frm_toggle_on { - width: 50%; - text-align: center; - font-size: 13px; - line-height: 28px; -} - -.frm_toggle_long .frm_toggle_on { - left: 0; -} - -.frm_toggle_long .frm_toggle_off { - right: 0; -} - -.frm_toggle_long .frm_toggle_slider::before { - width: 50%; - left: 0; - top: 0; - border-radius: var(--border-radius) 0 0 var(--border-radius); - height: 100%; - background-color: #fff; - color: var(--primary-color); - content: "" !important; -} - -.frm_toggle_long input:checked + .frm_toggle_slider::before { - transform: translateX(101%); - border-radius: 0 var(--border-radius) var(--border-radius) 0; -} - -input:checked + .frm_toggle_slider + .frm_toggle_on { - display: inline; -} - -input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { - display: none; -} - -.frm_toggle_long .frm_toggle_on, -.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { - display: inline; - color: var(--primary-500); - font-weight: 400; -} - -.frm_toggle_long .frm_toggle_off, -.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on { - color: #fff; - font-weight: 700; -} - -/* End toggle styling */ -/** - * Global Settings - */ -.tabs-panel { - height: auto !important; - min-height: 260px; -} - -.tabs-panel.panel_secondary { - min-height: 20px; - margin-top: 10px; - margin-left: 150px; -} - -label.frm-example-icon { - margin-right: 20px !important; - display: inline-block !important; -} - -#frm_stripe_icon { - border-radius: 5px; -} - -#captcha_settings .frm_primary_label { - margin-top: var(--gap-sm); -} - -.frm-long-icon-buttons { - display: flex; - gap: var(--gap-md); -} - -.frm-long-icon-buttons > label { - border: 1px solid var(--grey-300); - color: var(--grey-700); - border-radius: var(--small-radius); - display: flex; - padding: var(--gap-sm); - gap: var(--gap-sm); - justify-content: center; - align-items: center; - width: calc(33% - var(--gap-sm)); - box-sizing: border-box; -} - -.frm-long-icon-buttons > label:hover { - color: var(--primary-500); -} - -.frm-long-icon-buttons input[type=radio] { - display: none; -} - -.frm-long-icon-buttons input[type=radio]:checked + label { - border-color: var(--primary-500); - box-shadow: 0 0 0 1px var(--primary-color); -} - -.frm-long-icon-buttons label > svg { - height: 21px; -} - -.frm-example-icon .frmsvg, -.frm-example-icon i { - height: 20px; - width: 20px; - font-size: 20px; - color: var(--grey-700); -} - -.frm_license_msg { - margin-top: 0; -} - -.frm_authorized_box .frm-show-unauthorized, -.frm_unauthorized_box .frm-show-authorized { - display: none; -} - -.edd_frm_status_icon.frmsvg { - margin: 0 5px; -} - -.edd_frm_license_row .frm_action_success .frmsvg { - color: green; -} - -.edd_frm_license_row .frm_action_error .frmsvg { - color: #d54e21; -} - -/* Hide the install steps for solutions */ -#form_global_settings .tabs-panel .num svg { - display: none; -} - -/* Empty List */ -.frm_no_items { - margin: 0 auto 50px; - text-align: center; - color: var(--grey-700); - max-width: 500px; -} - -.frm-subscribe { - margin: var(--gap-lg) 0; -} - -.frm_inbox_count { - color: #fff; - border-radius: 50%; - display: inline-block; - margin-right: 8px; - font-size: 11px; - text-align: center; - min-width: 18px; - height: 18px; - margin-left: 2px; - vertical-align: text-bottom; -} - -/** - * Global Payment Settings - */ -#payments_settings .frm_payments_section .form-table td { - padding-left: 0; - padding-right: 0; -} - -#payments_settings .frm_payments_section .form-table { - margin-top: 0; -} - -#frm_authnet_general_settings > tr:first-of-type > td:first-of-type { - padding-top: 0; -} - -#frm_authnet_general_settings h3 { - margin-bottom: 0; -} - -.frm_payment_settings_tab .frmsvg { - height: 22px; -} - -.frm_payment_settings_tab[for=frm_toggle_paypal_settings] .frmsvg { - width: 83px; -} - -.frm_payment_settings_tab[for=frm_toggle_authorize_net_settings] .frmsvg { - width: 99px; -} - -.frm_payment_settings_tab[for=frm_toggle_square_settings] .frmsvg { - width: 89px; -} - -.frm_payment_settings_tab[for=frm_toggle_stripe_settings] .frmsvg { - width: 53px; -} - -.frm-email-style { - float: left; - margin-right: var(--gap-md); -} -.frm-email-style:last-of-type { - margin-right: 0; -} -.frm-email-style__card { - position: relative; -} -.frm-email-style__name { - margin-top: var(--gap-xs); - padding-top: var(--gap-2xs); - text-align: center; -} -.frm-email-style__name .frmsvg { - vertical-align: sub; -} -.frm-email-style__click { - display: block; - border-radius: 12px; - border: 1px solid var(--grey-200); - box-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.0588235294); -} -.frm-email-style__click:focus, .frm-email-style--selected .frm-email-style__click { - border-color: var(--primary-500); - outline: 1px solid var(--primary-500); -} -.frm-email-style__click img { - width: 160px; - display: block; -} -.frm-email-style--disabled .frm-email-style__click::after { - content: ""; - display: block; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - background-color: var(--grey-100); - opacity: 0.5; -} -.frm-email-style__buttons { - position: absolute; - top: 0; - left: 0; - width: 100%; - height: 100%; - z-index: 100; - display: none; - flex-direction: column; - justify-content: center; - align-items: center; - gap: 12px; -} -.frm-email-style__button { - cursor: pointer; - display: block; -} -.frm-email-style__button:disabled { - cursor: not-allowed; - display: none; - background: var(--primary-700) !important; - border-color: var(--primary-700) !important; -} -.frm-email-style--selected .frm-email-style__button:disabled { - display: block; -} -.frm-email-style--selected .frm-email-style__button[data-action=choose] { - display: none; -} -.frm-email-style--disabled .frm-email-style__button[data-action=choose] { - display: none; -} -.frm-email-style:hover .frm-email-style__buttons, .frm-email-style__click:focus + .frm-email-style__buttons, .frm-email-style:focus-within .frm-email-style__buttons { - display: flex; -} - -#frm-send-test-email, -.frm-upload-image-btn, -.frm-remove-image-btn, -.frm-reset-colors-btn { - cursor: pointer; -} - -#frm-send-test-email-modal .postbox { - padding: var(--gap-sm) var(--gap-md); -} -#frm-send-test-email-modal .postbox * { - box-sizing: border-box; -} -#frm-send-test-email-modal .inside { - margin: 0; - padding: 0; -} - -/** - * Import/Export - */ -.frm-lite .xml_opts .frm-export-xml-items { - display: none; -} - -.csv_opts #frm_csv_col_sep { - width: 45px; -} - -#frm_advanced td.frm_left_label { - width: 20%; - padding-right: 2px; -} - -/** - * Component: Where Options - */ -#frm_where_options select { - max-width: 200px; -} - -#frm_where_options select.frm_insert_where_options { - width: 30%; -} - -#frm_where_options select.frm_where_is_options { - width: 20%; -} - -#frm_where_options span.frm_where_val { - width: 32%; - display: inline-block; - position: relative; -} - -#frm_where_options span.frm_where_val .frm_tooltip_icon, -#frm_where_options span.frm_where_val .frm_help { - left: -4px; - position: absolute; -} - -#frm_where_options span.frm_where_val.frm_hidden { - display: none; -} - -#frm_where_options span.frm_where_val input, -#frm_where_options span.frm_where_val select { - width: 90%; - margin-left: 10px; -} - -#frm_where_options { - min-height: 31px; -} - -/** - * Component: Tabs Panel - */ -.tabs-panel.active .tabs-panel, -.frm_settings_form .tabs-panel .tabs-panel { - border: none; - padding: 0; -} - -/** - * Component: Feature Banner - */ -.frm-feature-banner { - background: var(--grey-700); - color: #fff; - border-radius: var(--small-radius); - padding: 20px; - margin: 10px 0; -} - -.frm-feature-banner p { - font-size: var(--text-sm); -} - -.frm-feature-banner .dismiss { - margin-top: -10px; - margin-right: -10px; -} - -.frm-feature-banner .dismiss svg { - color: #fff; -} - -.frm-feature-banner .frm-big-icon { - padding-right: 20px; - float: left; - min-height: 60px; -} - -.frm-big-icon svg { - height: 60px; - width: 60px; -} - -.frm-feature-banner p { - margin-top: 0; -} - -/** - * Add-on Backward Compatibility - */ -/*for add-on reverse compatibility */ -.frm_98_width { - width: 100% !important; -} - -/** - * Form Settings Tab styles - */ -h2.frm-h2, -.frm_form_settings h2 { - border-bottom: 1px solid var(--grey-300); - color: var(--grey-900); - font-weight: 400 !important; - padding: 9px 0 5px; - margin: 0; -} - -.frm_settings_form h3, -.frm_form_settings h3, -.frm_form_settings span.frm_add_logic_link { - font-size: var(--text-md); - border-top: 1px solid var(--grey-300); - padding-top: var(--gap-sm); - margin: var(--gap-sm) 0; - font-weight: 400; - text-transform: uppercase; - color: var(--medium-grey); - display: block; -} - -.frm_form_settings .howto { - color: var(--grey-500); - font-size: var(--text-sm); - margin-top: 8px; -} - -.frm_form_settings .advanced_settings .form-table { - margin-top: 0; -} - -.frm_form_settings td.frm_175_width { - width: 175px; -} - -.frm_form_settings #success_url { - width: 95%; -} - -.frm_wrap .ui-autocomplete { - padding: 3px 0; - max-height: 310px; -} - -.frm_wrap .ui-widget { - font-family: inherit; -} - -.frm_wrap .ui-autocomplete li { - padding: 2px 4px; - background: none; - color: var(--grey-700); - border: none; - font-weight: 400; -} - -.frm_wrap .ui-autocomplete .ui-menu-item-wrapper.ui-state-active { - border: none; - font-weight: inherit; -} - -.frm_select_with_label { - margin: 7px 0 0; -} - -/** - * Customization Panel styles - */ -/* Customization Panel */ -#frm-insert-fields-box, -#frm-conditionals { - max-height: none; -} - -#frm-conditionals, -#frm-adv-info-tab { - display: none; - max-height: 355px; -} - -#frm-insert-fields-box ul.subsubsub, -#frm-conditionals ul.subsubsub { - float: right; - margin: 0; -} - -#frm-insert-fields-box ul.alignleft, -#frm-conditionals ul.alignleft { - margin: 4px 0 0; -} - -#frm_adv_info ul.frm_code_list.frm-full-hover { - clear: both; - max-height: 215px; - overflow: auto; -} - -#frm-insert-fields-box ul.frm_code_list li.clear.frm_block { - height: 10px; -} - -#frm_adv_info .frm_noallow { - display: none; -} - -#frm_adv_info #frm-conditionals .frm_noallow { - display: block; -} - -/** - * Customize HTML Tab styles - */ -/* Customize HTML Tab */ -#frm_html_tab.frm_hidden { - display: none; -} - -#frm_html_tab.active { - display: inline; -} - -/** - * Form Actions Tab styles - */ -.frm_email_reply_container select, -.frm_email_reply_container input, -.form-table td.frm_150_width { - width: 170px; -} - -#frm_notification_settings .frm_no_top_padding { - padding-top: 0; -} - -.frm_email_settings.frm_email_settings.widgets-holder-wrap { - overflow: auto; - box-shadow: none; -} - -#frm_notification_settings .widget-top .widget-action, -#frm_form_editor_container .widget-top .widget-action { - border: 0; - margin: 0; - padding: 8px; - background: 0 0; - cursor: pointer; - outline: 0; -} - -#frm_notification_settings .widget-top .widget-action { - padding-top: 13.5px; -} - -#frm_email_addon_menu { - border: 1px solid var(--grey-300); - padding: var(--gap-sm); - border-radius: 4px; - margin: var(--gap-md) 0 var(--gap-sm); -} - -#frm_email_addon_menu .frm-search { - float: right; - margin: 0; -} - -#frm_email_addon_menu h3.frm-no-border { - clear: none; - padding-top: 7px; -} - -.frm_email_settings .widget .widget-top { - background-color: var(--sidebar-color); -} - -.frm_email_settings .widget .widget-top, -.frm_email_settings .widget .widget-top h3 { - cursor: pointer !important; -} - -.frm_email_settings .widget { - margin-bottom: var(--gap-sm); -} - -.frm_form_action_settings .widget-top { - box-shadow: none; - border-color: var(--grey-300); - border-radius: var(--small-radius); - background: var(--lightest-grey); - color: var(--grey-700); -} - -.frm_form_action_settings:hover .widget-top { - border-color: var(--grey); -} - -.frm_form_action_settings.open .widget-top { - border-bottom-left-radius: 0; - border-bottom-right-radius: 0; - border-bottom: none; -} - -.frm_form_action_settings.open:hover .widget-top { - border-color: var(--grey-300); -} - -.frm_form_action_settings > .widget-inside { - display: none; -} - -.frm_form_action_settings.open > .widget-inside { - display: block; -} - -.frm_form_action_settings .widget-inside { - min-height: 25px; - padding: 15px; - border-color: var(--grey-300); - border-bottom-left-radius: 4px; - border-bottom-right-radius: 4px; -} - -.frm_form_action_settings .widget-title h4, -.frm_form_action_settings .widget-title h3 { - display: inline-block; - border-bottom: none; - padding: 10px 10px 5px; - font-size: var(--text-md); - font-weight: 500; -} - -#frm_email_addon_menu h3 { - margin: 0 0 var(--gap-sm); - clear: both; -} - -.frm_single_api_settings p > label { - display: inline; -} - -.frm_form_action_icon { - margin-right: 5px; -} - -.frm_actions_list { - margin: 0; - display: inline; -} - -.frm_actions_list li { - float: left; - width: 15.6%; - margin: 10px 0.5% 15px; - height: 100px; - text-align: center; -} - -.frm-limited-actions .frm-group-heading, -.frm-limited-actions #frm-hide-groups, -.frm-all-actions #frm-show-groups, -.frm-limited-actions .frm-not-installed:not(.frm-search-result):not(.frm-default-show) { - display: none; -} - -label.frm_action_events { - padding-left: 15px; -} - -#frm-hide-groups, -#frm-show-groups { - font-size: var(--text-md); - float: right; -} - -.frm_actions_list a:active, -.frm_actions_list a:focus { - outline: none; -} - -.frm_actions_list a { - font-size: var(--text-sm); - color: var(--grey-700); - word-break: break-word; -} - -.frm_actions_list span.frm-outer-circle { - /* 50px total with 30px content */ - background-color: var(--grey-100); - padding: 10px; - text-align: center; - border-radius: 50%; - display: block; - width: 30px; - height: 30px; - margin: 0 auto 15px; - line-height: 1; - box-sizing: content-box; -} - -.frm_email_settings .widget-title h4 { - color: var(--grey-700); -} - -.frm_disabled_action .widget-title h4 { - color: var(--grey); -} - -.frm_actions_list a .frmsvg, -.frm_actions_list a i { - height: 18px; - width: 18px; - font-size: 18px; - padding: 2px; - color: var(--lightest-grey); - box-sizing: content-box; -} - -span.frm-inner-circle, -.frm_email_settings .widget-title .frm_form_action_icon { - background-color: var(--grey-400); - border-radius: 50%; - display: inline-block; - text-align: center; - line-height: 1; -} - -span.frm-inner-circle { - background-color: var(--primary-700); - height: 22px; - width: 22px; - padding: 4px; - color: #fff; - box-sizing: content-box; -} - -.frm-inner-circle svg { - fill: currentColor; -} - -.frm_email_settings .widget-title .frm_form_action_icon { - height: 15px; - width: 15px; - padding: 5px; - color: #fff; - vertical-align: middle; -} - -.frm_actions_list .frmsvg, -.frm_actions_list i::before, -.frm_email_settings .widget-title .frm_form_action_icon i, -.frm_email_settings .widget-title .frm_form_action_icon .frmsvg { - height: 15px; - width: 15px; - vertical-align: text-top; -} - -.frm_actions_list i::before { - vertical-align: middle; -} - -.frm_email_settings .widget-title:hover .frm_form_action_icon { - background-color: var(--grey); -} - -span.frm-inner-circle.frm-inverse { - background-color: transparent; - color: var(--primary-700); - padding: 0; - height: 30px; - width: 100%; -} - -.frm_actions_list span.frm-inverse i, -.frm_actions_list span.frm-inverse .frmsvg { - color: var(--primary-700); - height: 30px; - width: 30px; - font-size: 30px; - padding: 0; -} - -.frm_actions_list i.frm-inverse::before { - height: 30px; - width: 100%; - font-size: 30px; -} - -.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse { - background: #fff; - padding: 0; - height: 24px; - width: 24px; -} - -.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse .frmsvg, -.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse i::before { - color: var(--grey-400); - height: 24px; - width: 24px; - font-size: 24px; -} - -.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse .frmsvg, -.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse i::before { - color: var(--grey-500); -} - -.frm_email_icons { - padding: 10px 0 5px 6px; - font-size: 20px; -} - -.frm_email_icons a { - margin-left: 8px; - color: var(--grey); - opacity: 0; - transition: all 0.2s ease; -} - -.frm_email_icons a .frmsvg { - color: var(--grey); -} - -.frm_email_icons a:hover, -.widget-top:hover .frm_email_icons a { - opacity: 1; -} - -.frm_actions_list a.frm_inactive_action { - color: var(--grey); -} - -.frm_inactive_action .frm-inner-circle, -.frm_actions_list .frm_inactive_action i { - opacity: 0.4; -} - -/** - * Component: Notification Settings - */ -table td, -.form-table tr td { - vertical-align: top; -} - -#new_fields .form-table tr td { - display: block; - padding: 7px 0 0; -} - -#new_fields .form-table tr td:first-child { - margin: 0; -} - -#new_fields .form-table tr td:last-child { - margin-bottom: 9px; -} - -.form-table #list-table th { - text-align: center; -} - -#form_settings_page th, -#form_settings_page td, -.frm_settings_form td, -#frm_notification_settings .frm_form_action_settings td p { - padding: 7px 0; -} - -#permissions_settings_settings .frm_grid_container { - align-items: center; -} - -#frm_notification_settings .form-table > tbody > tr > th { - width: 150px; - font-weight: 400; - padding-right: 10px; -} - -#frm_notification_settings .frm_single_email_settings .form-table > tbody > tr > th { - width: 80px; -} - -#frm_notification_settings table tr td:first-child { - padding-left: 0; -} - -#frm_notification_settings table tr td:last-child { - padding-right: 0; -} - -#frm_notification_settings .frm_left_label { - float: none; /* For add-ons that haven't been updated for 4.0 */ - width: auto !important; -} - -.frm-fields .frm_autoresponder_rows select { - width: auto; -} - -#frm_notification_settings .frm_with_left_label, -#frm_notification_settings .frm_left_label + textarea, -#frm_notification_settings .frm_left_label + select, -#frm_notification_settings .frm_left_label + input[type=text] { - width: 100%; -} - -#frm_notification_settings .frm_email_buttons { - padding: var(--gap-2xs); - background: var(--light-blue); - color: var(--primary-700); - border-radius: var(--small-radius); - border-color: var(--blue-border); - line-height: 1; - height: auto; - min-height: 12px; - font-size: var(--text-xs); - box-shadow: none; -} - -p.frm_bcc_cc_container, -p.frm_reply_to_container { - position: relative; - float: right; - margin: -4px 0 0; - z-index: 1; -} - -.frm_email_row .frm_cancel1_icon::before { - vertical-align: bottom; -} - -.frm_cc_row.frm_email_row .frm-with-right-icon, -.frm_bcc_row.frm_email_row .frm-with-right-icon, -.frm_reply_to_row.frm_email_row .frm-with-right-icon { - width: calc(100% - 20px); - display: inline-block; -} - -.frm_email_row .frm_remove_field .frm_close_icon { - position: relative; - fill: var(--grey-500); - vertical-align: middle; -} - -/** - * Component: Logic Fields - */ -.frm-inline-select, -p.frm-inline-select, -.frm_logic_rows .frm-collapse-me { - line-height: var(--h-md) !important; -} - -.frm_logic_row { - padding: var(--gap-xs) 0 0; -} - -.frm-single-settings ul.frm_sortable_field_opts { - border-bottom: 1px solid var(--grey-200); - padding-bottom: var(--gap-xs); - margin-bottom: var(--gap-xs); -} - -.frm-single-settings .frm-add-other svg.frm_add_tag { - position: relative; - top: 5px; - margin-right: 4px; -} - -.frm-single-settings .frm_single_option .frm_remove_tag::before { - content: ""; -} - -.frm-single-settings input[type=checkbox][readonly] { - opacity: 0.5; - pointer-events: none; -} - -.advanced_settings .frm_logic_row { - margin: 14px 0; -} - -.advanced_settings .frm_logic_row select, -.advanced_settings .frm_logic_row input { - max-width: 30% !important; -} - -.frm_form_action_settings .frm_logic_row p { - margin-top: 0; - margin-bottom: 0; - padding: 0; -} - -/** - * Component: Form Settings Widget - */ -#poststuff .widgets-holder-wrap .frm_form_action_settings .widget-inside { - padding-bottom: 0; -} - -#poststuff .frm_form_settings .widgets-holder-wrap .widget-inside { - padding-left: 15px; - padding-right: 15px; -} - -#form_global_settings h3 { - font-size: var(--text-sm); - margin-top: 25px; -} - -#form_global_settings .tabs-panel + h3 { - margin-top: 0; - border: none; -} - -#poststuff .frm_form_settings .widget-inside h3, -#poststuff .frm_form_settings .advanced_settings h3, -#poststuff .frm_settings_form h3, -#frm_advanced .inside h3 { - border-top: 1px solid #eee; - border-bottom: none; - margin: 15px -15px 0; - padding: 8px 15px; - font-size: var(--text-sm); -} - -#poststuff .frm_form_settings h3.frm_first_h3, -#poststuff h3.frm_first_h3 { - border: none; - margin-top: 0; -} - -h3.frm_add_logic_link { - margin-bottom: 0 !important; -} - -a.frm_add_logic_link.frm_hidden { - display: none; -} -a.frm_add_logic_link.frm_hidden + .frm_logic_rows { - height: auto; -} - -/** - * Icon Font styles - */ -.frm_icon_font { - color: #a0a0a0; - color: var(--grey); -} - -.frm-fields label .frm_icon_font { - font-size: inherit; -} - -.misc-pub-revisions.frm_icon_font, -.misc-pub-revisions.frm_icon_font:hover { - color: inherit; -} - -.postbox.frm_with_icons .inside { - padding: 0; - margin: 0; -} - -.frm_add_tag::before { - content: "\e602"; -} - -.frm_remove_tag::before { - content: "\e600"; -} - -.frm_logic_row .frm1 > .frm_remove_tag { - padding: 0; -} - -.frm_tooltip_icon::before { - font-size: 13px; - vertical-align: top; -} - -.frm_help svg, -.frm_help .frmsvg { - height: 13px; - width: 13px; - vertical-align: top; - color: var(--grey-400); -} - -.form-field input[type=text].frm_other_input { - width: 30%; - margin-left: 10px; -} - -.frm-add-other { - text-align: right; -} - -.frm-add-other .frm_add_tag { - vertical-align: 20%; -} - -.frm_action_icon { - margin: 5px 0 0 5px; -} - -span.frm_action_icon { - margin: 0 4px 0 0; -} - -.frm_action_icon:active { - outline: none; -} - -a.frm_action_icon:hover { - text-decoration: none; -} - -.frm_action_icon.frm_error_icon::before { - content: "\e608"; -} - -.frm_inactive_icon.frm_action_icon.frm_error_icon::before { - content: "\e606"; -} - -.frm-field-action-icons { - text-align: right; - position: absolute; - top: 2px; - right: 2px; - max-width: 100%; -} - -.frm-field-action-icons .frm-field-id { - display: inline-block; - overflow: hidden; - text-overflow: ellipsis; - white-space: nowrap; - width: 80px; - max-width: calc(100% - 50px); - position: relative; - top: 2px; -} - -.frm-field-action-icons > a { - font-size: var(--text-md); - width: 17px; -} - -.frm-field-action-icons a:hover { - text-decoration: none; -} - -.frm-field-action-icons .dropdown { - display: inline-block; -} - -.frm-field-action-icons > a .frmsvg { - color: var(--grey-500) !important; - font-size: 17px; - width: 17px; - height: 17px; -} - -.frm-field-action-icons > a .frmsvg, -.frm-field-action-icons > div > a .frmsvg { - vertical-align: baseline; -} - -.edit_field_type_end_divider .frm-field-action-icons { - display: none !important; -} - -.frm-move { - cursor: grab; -} - -/** - * Extended Howto styles - */ -span.howto { - display: inline; -} - -.frm_import_message { - margin: 15px 0; - line-height: 2.5; -} - -/** - * Form Widget styles - */ -.frm_sorting .form-field .widget input[type=text], -.frm_sorting .form-field .widget input[type=number], -.frm_sorting .form-field .widget select, -#wpcontent .frm_sorting .form-field .widget select, -.frm_sorting .form-field .widget textarea { - width: auto; -} - -/** - * Tag Checklist styles - */ -.tagchecklist span.no_taglist { - display: inline; - float: none; - line-height: 15px; - margin-right: 0; - font-size: inherit; -} - -.tagchecklist .frm_exclude_cat_list span { - display: inline; -} - -.tagchecklist span a::before { - line-height: 23px; - text-align: start; -} - -.frm_form_action_settings .frm_email_row .frm_tooltip_icon { - position: relative; - bottom: 2px; -} - -/** - * No Entries Page styles - */ -.frm_no_entries_form { - padding: 60px 0; -} - -.frm_no_entries_form .frm_no_entries_header { - font-size: 20px; - margin-bottom: 10px; -} - -.frm_no_entries_form .frm_no_entries_text { - line-height: var(--leading); -} - -#form_entries_page #the-list .no-items { - height: 240px; /* Equals to the max height of search dropdown */ -} - -/** - * Reports Page styles - */ -#form_reports_page img.frm_no_reports { - max-width: 100%; -} - -.frm_wrap .google-visualization-table .gradient, -.frm_wrap .google-visualization-table-tr-head, -.frm_wrap .google-visualization-table-tr-odd, -.frm_wrap .google-visualization-table-tr-odd.google-visualization-table-tr-over { - background: var(--lightest-grey); -} - -.frm_wrap .google-visualization-table-tr-over { - background: #fff; -} - -.frm_wrap .google-visualization-table-table th, -.frm_wrap .google-visualization-table-table td { - border-right-width: 0; - padding: 10px !important; -} - -.frm_wrap .google-visualization-table-tr-head, -.frm_wrap .google-visualization-table-tr-head th { - white-space: pre-wrap; - font-size: var(--text-md); - font-weight: 400 !important; - text-align: left; -} - -.frm_wrap .google-visualization-table-td-number { - text-align: inherit; -} - -#form_reports_page .postbox { - text-align: center; - float: none; - display: inline-block; - margin-right: 2%; - width: 20%; - min-width: 175px; -} - -/** - * Views Page styles - */ -#form_views_page img.frm_no_views { - max-width: 100%; -} - -/** - * Component: Field Options Popup - */ -.frm_field_opts_popup { - min-width: 300px; - background-color: #fff; -} - -.frm_field_opts_popup #wpadminbar { - display: none; -} - -.frm_prepop { - width: 100%; - list-style: none; - overflow: auto; - margin: 0; - max-height: 295px; -} - -.frm_prepop li { - margin: 0; -} - -.frm_prepop li a { - display: block; - text-decoration: none; - cursor: pointer; - padding: 5px 20px; -} - -.frm_prepop li a:hover { - background: var(--sidebar-color); -} - -/** - * Form Editor Container - */ -#frm_form_editor_container #frm_form_key_box { - width: 13em; - max-width: 30%; -} - -#frm_form_editor_container #frm_form_desc { - width: 70%; -} - -#frm_form_editor_container .ui-widget-content { - display: none; - padding: 15px; -} - -#frm_form_editor_container .ui-widget-content label { - float: left; - width: 170px; - text-align: right; - padding-right: 5px; - clear: both; -} - -#frm_form_editor_container .ui-widget-content label.nofloat { - clear: none; - float: none; - margin-left: 10px; -} - -#frm_form_editor_container .ui-state-default { - color: #333 !important; -} - -.frm_green { - color: var(--green) !important; -} - -#frm_form_editor_container .ui-state-default a.frm_orange, -.frm-right-panel a.frm_orange, -#postbox-container-1 a.frm_orange { - color: #d54e21; -} - -#styling_settings input[type=checkbox], -#styling_settings input[type=radio] { - border: solid 1px #bbb; -} - -#styling_settings .widget .widget-top, -#frm_form_editor_container .widget .widget-top { - cursor: pointer; -} - -/** - * Widget Sorting - */ -.frm_sorting .widget, -.frm_settings_page .widget { - background: #fff; -} - -.frm_sorting .widget-title h4 { - font-weight: 400; -} - -.frm_sorting .widget, -#postbox-container-1 .widget, -.frm-right-panel .widget, -.frm_settings_page .widget { - margin-bottom: 0; -} - -.frm_settings_page .widget-inside { - padding: 0 5px 5px; -} - -.frm_sorting .widget, -.widget-inside, -.frm_sorting .form-field .widget { - display: none; -} - -#frm-show-fields { - min-height: 350px; - padding: 0 0 35px; - margin: 0; - position: relative; -} - -.frm-has-fields #frm-show-fields { - min-height: 50px; -} - -#frm_builder_page .frm-lite-credit-card-element, -body.frm-admin-page-styles .frm-lite-credit-card-element { - position: relative; -} - -#frm_builder_page .frm-lite-credit-card-element > div, -body.frm-admin-page-styles .frm-lite-credit-card-element > div { - position: absolute; - top: calc(50% - 1px); - transform: translateY(-50%); - right: 10px; - color: #d0d4dd; -} - -#frm_builder_page #frm_field_group_controls { - position: absolute; - padding: 5px; - border-radius: 4px 4px 0 0; - text-align: right; - box-sizing: border-box; - right: 0; - top: -28px; - height: 28px; - z-index: 3; /* section dividers use z-index: 2; position above that to avoid it taking over hover control. */ -} - -.frm-field-group-hover-target, -.frm-has-open-field-group-popup, -#frm_builder_page #frm_field_group_controls, -.frm-selected-field-group { - background: rgba(65, 153, 253, 0.04); -} - -.frm-selected-field-group { - position: relative; -} - -#frm_builder_page #frm_field_group_controls > span:first-child { - margin-right: 5px; -} - -#frm_builder_page #frm_field_group_controls svg { - pointer-events: none; -} - -#frm_field_group_controls { - visibility: hidden; -} - -.frm-field-group-hover-target #frm_field_group_controls { - visibility: visible; -} - -#frm_field_group_controls .dropdown-item a span { - color: var(--grey-700); -} - -#frm_field_group_controls .dropdown-item a:hover { - text-decoration: none; -} - -/** - * Field Sorting - */ -.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider { - display: none !important; -} - -.frm-right-panel .ui-state-default, -#postbox-container-1 .ui-state-default, -.frm_sorting > li.ui-state-default, -.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover { - border: 1px solid transparent; - font-weight: 400 !important; - background-color: transparent; - background-image: none; - padding: 5px; - margin: 0; - box-shadow: none; - display: block; - text-align: inherit !important; - overflow: visible; - position: relative; -} - -#frm-show-fields li.frm_cancel_sort { - /* If a section gets dropped into a section, hide it */ - display: none; -} - -.divider_drop { - text-align: center; -} - -.divider_drop .howto .frm_icon_font { - font-style: normal; -} - -.show_repeat_sec { - display: none; -} - -.repeat_section .show_repeat_sec { - display: inline-block; - margin: 5px 0 0; -} - -.repeat_section tr.show_repeat_sec { - display: table-row; -} - -.repeat_format .frm_repeat_label, -.repeat_formattext .frmsvg, -.repeat_formattext i { - display: none; -} - -/** - * Frm Button - */ -.frm_button { - text-decoration: none; - border: 1px solid #eee; - padding: 5px; - color: #444; - vertical-align: middle; - box-shadow: none !important; -} - -a.frm_button:hover { - text-decoration: none !important; -} - -.frm_button, -.frm_button .frm_icon_font::before { - font-size: 13px; - vertical-align: middle; -} - -.frm_button .frmsvg { - width: 13px; - height: 13px; -} - -/** - * Components - Divider - */ -.frm-right-panel .ui-state-default, -#postbox-container-1 .ui-state-default { - padding: 0; - margin: 0; -} - -ul.start_divider { - padding: 8px 13px 0 8px; - min-height: 115px; - transition: all 0.4s linear; -} - -.frm-section-collapsed .frm_no_section_fields, -.frm-section-collapsed ul.start_divider { - height: 0; - min-height: 0 !important; -} - -.frm-section-collapsed ul.start_divider { - overflow: hidden; -} - -.frm-section-collapsed .frm_no_section_fields { - overflow: hidden; - padding: 0; - opacity: 0; -} - -.frm-section-collapsed .divider_section_only .frm-collapsed-label { - display: inline; -} - -.frm-page-collapsed .frm_clone_icon, -.frm-page-collapsed .frm_delete_field, -.frm-page-collapsed .frm_clone_field, -.frm-section-collapsed .frm_clone_icon { - opacity: 0.5; - cursor: not-allowed; -} - -/* Hide the Duplicate summary option because we are missing the logic that also adds a new page */ -.edit_field_type_summary .frm_more_options_li:nth-child(2) { - display: none !important; -} - -.edit_field_type_submit .frm_more_options_li:not(:last-child) { - display: none !important; -} - -.frm_no_section_fields:not(.frm_block) + ul.start_divider { - padding: 0; - min-height: 132px; -} - -.frm_sorting li.ui-state-default .divider_section_only { - padding: 6px; - margin-top: -10px; - border: 2px solid transparent; - border-radius: var(--small-radius); - z-index: 2; - position: relative; -} - -.divider_section_only > .frm_inner_field_container { - padding: 5px 0; - margin: 0; -} - -.frm-collapsed-label, -.divider_section_only > .frm_inner_field_container .frm_form_fields { - display: none; -} - -.frm-section-collapsed .divider_section_only::after, -.divider_section_only::before { - content: ""; - display: block; - padding: 2px 0; - line-height: 1px; - border-top: 2px solid var(--grey-300); - top: -2px; - position: absolute; - width: 100%; - transition: 0.5s border-color ease-in-out; -} - -.frm-section-collapsed .divider_section_only::after { - top: auto; - bottom: -6px; -} - -.frm-section-collapsed .divider_section_only:hover::after, -li.selected.frm-section-collapsed .divider_section_only::before, -li.selected.frm-section-collapsed .divider_section_only::after, -.divider_section_only:hover::before, -li.selected .divider_section_only::before { - border-color: transparent; -} - -.frm_sorting li.ui-state-default.edit_field_type_divider { - overflow: visible; - position: relative; - padding: 0 0 0 20px; - margin: 25px 0 0 -5px; - border-left: 1px solid var(--primary-700); - transition: border 0.7s ease-out; -} - -.frm-section-collapsed { - border-left-color: transparent !important; -} - -.frm_sorting li.edit_field_type_end_divider, -.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover { - margin: 0 0 var(--gap-sm); -} - -.frm-first-page .frm_prev_page { - display: none; -} - -/** - * Components - Form Rows - */ -#frm_builder_page .frm_remove_form_row.frm_button, -#frm_builder_page .frm_add_form_row.frm_button { - border-radius: var(--small-radius); - border: 1px solid var(--blue-border); -} - -#frm_builder_page .frm_remove_form_row .frmsvg, -#frm_builder_page .frm_remove_form_row i::before, -#frm_builder_page .frm_add_form_row .frmsvg, -#frm_builder_page .frm_add_form_row i::before { - color: var(--primary-700); -} - -.frm-preview-buttons .frm_button_submit { - margin: 0 5px; -} - -.frm-page-break { - border-top: 1px dashed var(--primary-700); - margin-top: var(--gap-lg); - position: relative; -} - -.frm-page-break::before, -.frm-page-break::after { - content: ""; - position: absolute; - background-color: #fff; - border-radius: 50%; - border: 1px solid var(--primary-700); - text-rendering: auto; - -webkit-font-smoothing: antialiased; -} - -/** - * Components - Divider Icons - */ -.edit_field_type_divider .frm-divider-icon.frmsvg { - padding: 2px; - position: absolute; - left: -12px; - color: #fff; - background-color: var(--primary-700); - border-radius: 50%; -} - -.edit_field_type_divider .start_divider .frm-divider-icon.frmsvg { - height: 8px; - width: 8px; - padding: 0; - bottom: -4px; - left: -24.5px; - color: var(--primary-700); - background-color: #fff; -} - -.edit_field_type_divider.selected .frm-divider-icon.frmsvg, -.edit_field_type_divider:hover .frm-divider-icon.frmsvg { - background: var(--primary-500); -} - -.edit_field_type_divider.selected .start_divider .frm-divider-icon.frmsvg, -.edit_field_type_divider:hover .start_divider .frm-divider-icon.frmsvg { - background-color: #fff; - color: var(--primary-500); -} - -.frm-page-break::before, -.frm-page-break::after { - width: 8px; - height: 8px; - top: -6px; - border-color: var(--grey); -} - -.frm-page-break::after { - right: 0; -} - -#frm-fake-page .frm-page-break { - border-color: var(--grey); -} - -#frm-fake-page { - padding: 0 5px; -} - -.frm_sorting li.edit_field_type_divider:hover, -.frm_sorting li.edit_field_type_divider.selected { - border-left-color: var(--primary-500); -} - -/** - * Component: Page Collapsed - */ -.frm-section-collapsed::after { - border-color: transparent !important; - color: transparent; -} - -.frm-page-break .frm-collapse-page.button { - margin-left: 46%; - margin-top: -16px; - padding: 6px 12px !important; -} - -#frm-fake-page.frm-page-collapsed { - margin-bottom: 0; -} - -.frm-page-collapsed { - position: relative; - overflow: visible !important; - margin-bottom: var(--gap-lg); -} - -.frm-collapse-page .frmsvg, -.frm-collapse-page .frm_arrowdown6_icon { - width: var(--text-sm); - height: var(--text-sm); - font-size: var(--text-sm); - text-align: center; - margin-left: 2px; - color: currentColor; - transition: transform 300ms ease-in-out; -} - -.frm-page-collapsed .frm-collapse-page .frmsvg { - transform: rotate(180deg); -} - -#frm-fake-page .frm_arrowdown6_icon { - color: currentColor; -} - -.frm-collapsed i::before, -.frm-page-collapsed .frm_arrowdown6_icon::before { - content: "\e913"; -} - -.frm-collapse-section svg { - fill: var(--primary-color); - transition: transform 0.2s ease-out, fill 0.2s ease-out; -} - -.frm-collapse-section:hover svg { - fill: var(--primary-700); -} - -.frm-section-collapsed .frm-collapse-section svg { - transform: rotate(-90deg); -} - -.open .widget-top .widget-title-action button .frmsvg { - transform: rotate(90deg); -} - -.widget-top .widget-title-action button .frmsvg use { - color: var(--grey); -} - -.frm-collapsed + .frm-collapse-me { - overflow: hidden !important; -} - -.frm-collapse-me { - padding-bottom: 10px; -} - -.frm-collapse-me.frm_grid_container:has(.dropdown-toggle.multiselect) { - position: relative; - z-index: 1; -} - -.frm-collapsed + div { - height: 0; - padding: 0; -} -.frm-collapsed + div.frm-collapse-me { - display: none; -} - -.frm-collapsible { - display: flex; - justify-content: space-between; - align-items: center; - font-weight: 700; - padding: var(--gap-xs) 0; - margin: 0; - cursor: pointer; - /* prevent text selection */ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} -.frm-collapsible.frm-collapsed { - font-weight: 400; -} -.frm-collapsible:not(.frm-collapsed) .frmsvg { - transform: rotate(-180deg); -} -h4.frm-collapsible { - font-size: var(--text-md); -} - -.frm-collapsible + .frm-collapse-me { - padding-bottom: 0; -} -.frm-collapsible:focus-visible { - outline: 1px solid var(--primary-500); -} - -/** - * Divider Labels - */ -.frm_sorting .divider_section_only > .frm_ipe_field_label { - font-size: 116%; -} - -#frm_form_editor_container .edit_field_type_break .frm_primary_label.frm_ipe_field_label.button { - width: 150px; - text-align: center; - margin-bottom: 3px; - display: block; -} - -tr.frm_options_heading td { - padding-bottom: 0; -} - -.frm_sorting .widget-inside .form-table td p, -.frm_sorting .widget-inside .form-wrap label { - padding: 10px 0; -} - -/** - * Empty Fields - */ -.frm_no_fields, -.frm_no_section_fields { - text-align: center; - position: absolute; - color: var(--medium-grey); - font-size: var(--text-md); - box-sizing: border-box; - border: 1px dashed var(--grey-300); - outline: 2px solid transparent; -} - -.frm-over-droppable + .frm_no_fields { - border-style: solid; - border-color: var(--primary-500); - outline-color: var(--primary-500); -} - -.frm_no_section_fields { - display: none; - margin: 0; - padding: 20px 0 0; - width: calc(100% - 20px); - height: 121px; - transition: all 0.4s linear; -} - -.frm-empty-fields .frm_updated_message ~ .frm_no_fields { - top: 60px; -} - -#frm_form_editor_container:not(.frm-has-fields) #frm-show-fields > .frm_field_box:last-child { - visibility: hidden; -} - -.frm-has-fields .frm_no_fields { - display: none; -} - -#frm_form_editor_container:not(.frm-has-fields) #frm_drag_placeholder { - display: none; -} - -#frm-form-button { - display: none; - margin: 0 7px 25px; -} - -.frm-has-fields #frm-form-button { - display: block; -} - -.frm-large-plus.frmsvg { - color: var(--primary-700); - height: 45px; - width: 45px; -} - -.frm_no_section_fields p { - color: var(--grey); - font-size: 15px; -} - -.frm_no_fields { - top: 0; - width: calc(100% - 24px); - min-height: 320px; - display: flex; - flex-direction: column; - justify-content: center; - align-items: center; - gap: var(--gap-md); - padding: var(--gap-md); - border: 0; - background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Crect width='99%25' height='99%25' fill='none' stroke='%23D0D5DD' stroke-width='1' stroke-dasharray='8,8' rx='8' ry='8' x='0.5%25' y='0.5%25' stroke-linecap='square' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E"); - border-radius: var(--medium-radius); - margin: var(--gap-sm) 12px; -} -.frm_no_fields img { - margin-left: calc(-1 * var(--gap-lg)); -} -.frm_no_fields .frm_drag_inst { - font-size: 20px; - font-weight: 600; - margin: 0 0 12px; -} -.frm_no_fields p { - color: var(--grey-600); - font-size: var(--text-md); - margin: 0; -} - -/** - * Product Fields - */ -.frm_product_price_wrapper { - display: inline-block; - vertical-align: middle; -} - -.frm_prod_type_single .frm_product_price_wrapper { - width: 100%; -} - -#new_fields .frm_product_price_wrapper input:first-child { - width: 60% !important; - float: left; -} - -#new_fields .frm_product_price_wrapper input:nth-child(2) { - width: 37% !important; - float: right; -} - -/** - * Field Choices - */ -li.frm_single_option { - padding-bottom: var(--gap-sm); - border-bottom: 0; -} - -.frm_prod_type_single input[type=radio], -.frm_prod_type_single .frm_drag_icon, -.frm_prod_type_single .frm_sortable_field_opts li:nth-child(n+3), -.frm_prod_type_single .frm_sortable_field_opts .frm_remove_tag, -.frm_prod_type_single .frm_form_field:not(.frm_product_type):not(.frm_sep_val_product), -.frm_prod_type_single .frm-bulk-edit-link, -.frm_prod_type_user_def.frm_grid_container, -.frm_prod_options_heading.frm_prod_user_def { - display: none; -} - -.frm_prod_type_single .frm-ai-generate-options-modal-trigger { - display: none !important; -} - -.frm_prod_type_single .frm_option_key { - margin-left: 0 !important; -} -.frm_prod_type_single .frm_option_key input[type=checkbox] + input[type=text], -.frm_prod_type_single .frm_option_key input[type=radio] + input[type=text] { - margin-left: 0 !important; -} - -.plugin-card-bottom .frm-trash { - color: #a00; -} - -/** - * Field Labels - */ -.frm-fields p > .frm_inline_label, -.frm_inline_label { - padding-left: 3px; - margin-right: 12px; - display: inline-block; -} - -.frm_left_label { - clear: both; - float: left; - width: 32% !important; - margin-right: 2% !important; - line-height: 2em; -} - -table td.frm_left_label { - float: none; - line-height: inherit; - padding: 5px 0 5px 2%; -} - -.frm_left_label.frm_alignright { - padding-right: 10px; - text-align: right; -} - -.frm-fields .frm_left_label + textarea, -.frm-fields .frm_left_label + select, -.frm-fields .frm_left_label + input[type=text], -.frm_with_left_label { - width: 66%; -} - -td.frm_left_label + td { - width: 66%; - padding-top: 0; -} - -#html_settings label { - display: block; -} - -#html_settings .frm_field_html_box { - width: 100%; -} - -.frm-has-required .frm-required { - color: var(--error-500); -} - -/** - * Category Tabs - */ -ul.frm-category-tabs { - margin-top: 2px; -} - -.frm-category-tabs > li a, -.frm-category-tabs > li a:active { - outline: none; - box-shadow: none; - display: flex; - gap: var(--gap-xs); - align-items: center; -} - -.frm-category-tabs > li.active .frmsvg, -.frm-category-tabs > li.active i, -.frm-category-tabs > li.active span, -.frm-category-tabs > li.active a { - color: var(--primary-500); -} - -.frm_wrap .manage-menus { - margin-top: 0; - border: none; - border-bottom: 1px solid var(--grey-300); - background: var(--lightest-grey); -} - -.general_settings .postbox .manage-menus { - border-top: none; - border-left: none; - border-right: none; -} - -.frm-postbox-no-h3 { - padding-top: 10px; -} - -/** - * Components : UI State Defaults - */ -.frm-right-panel .ui-state-default, -#postbox-container-1 .ui-state-default { - color: var(--grey-900); -} - -.no_repeat_section .frm_sorting > li.ui-state-default.edit_field_type_end_divider:hover { - box-shadow: none; -} - -.frm-selected-field-group li.ui-state-default, -.start_divider.frm_sorting li.ui-state-default.frm_not_divider.selected, -.start_divider.frm_sorting li.ui-state-default.frm_not_divider:hover, -.frm_sorting li.ui-state-default.frm_not_divider:hover, -.frm_sorting li.ui-state-default.ui-sortable-helper, -.frm_sorting li.ui-state-default.edit_field_type_divider .divider_section_only:hover, -.frm_sorting .repeat_section li.ui-state-default.edit_field_type_end_divider:hover, -.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only, -.frm_update_msg, -.frm_sorting li.ui-state-default.frm_not_divider.selected, -.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only { - border-color: var(--primary-500); - transition: 0.5s border-color ease-in-out; -} - -.frm_sorting li.ui-state-default.frm_not_divider.selected { - box-shadow: 0 0 1px 0 var(--primary-500); -} - -.frm_sorting li.ui-state-default { - transition: 0.7s box-shadow ease-in-out, 0.7s height linear; -} - -.frm_sorting li.ui-state-default.frm-newly-added { - box-shadow: inset 0 0 2px 1px var(--blue-border); -} - -.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover { - visibility: visible !important; - display: inline !important; -} - -.edit_field_type_end_divider > label { - display: none !important; -} - -/** - * Update Message - */ -.frm_email_actions.feature-filter { - font-weight: 700; - border: 1px solid #dfdfdf; - background-color: #eee; - padding: 3px 5px 2px; - font-size: var(--text-md); - line-height: 20px; -} - -.frm_update_msg { - border-style: solid; - margin: 10px 0; - color: #21759b; - padding: 8px 15px; - border-radius: 4px; -} - -.frm_update_msg.wrap { - margin: 10px 20px 0 2px; -} - -#frm-insert-fields-box .frm_update_msg { - margin-right: 0.9em; -} - -.frm_update_msg a { - font-weight: 700; -} - -.widefat td { - width: auto; -} - -.widefat .column-id { - width: 3.7em; -} - -.widefat .column-show_count { - width: 5em; -} - -.widefat .column-shortcode { - width: 9em; -} - -/** - * Admin Columns - */ -.toplevel_page_formidable .column-shortcode div { - display: flex; - gap: var(--gap-xs); -} - -.widefat .column-entries, -.widefat .column-link { - width: 10%; - text-align: center; -} - -.widefat .column-form_key, -.widefat .column-created_at { - width: 10%; -} - -.frm-white-body .search-box, -.frm_wrap .frm-search { - float: right; - margin: 0; - clear: right; -} - -.frm-white-body .search-box, -.frm-search { - min-width: 32%; - position: relative; - display: flex; - gap: var(--gap-sm); - align-items: center; -} - -.frm-inline-modal .frm-search, -#frm_adv_info .frm-search { - float: none; - width: 100%; - clear: both; - margin: var(--gap-xs) 0; -} - -/** - * Button Group - */ -.frm-button-group a { - margin: 0 7px !important; -} - -/** - * Input Icons - */ -.frm_has_textarea .frm-with-right-icon { - display: block; -} - -.frm-with-left-icon, -.frm-with-right-icon { - position: relative; -} - -i.frm-show-box, -i.frm-show-inline-modal, -.frm-with-left-icon i, -.frm-with-right-icon i:not([class*=mce-]), -.frmsvg.frm-show-box, -.frmsvg.frm-show-inline-modal, -.frm-with-left-icon .frmsvg, -.frm-with-right-icon .frmsvg, -.frm-search > .frmsvg, -.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select) { - position: absolute; - padding: 0 14px; - pointer-events: none; - left: 0; - color: var(--grey-400); - font-size: var(--text-xs); -} - -.frm-search > .frmsvg, -.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select) { - padding-left: var(--gap-xs); - padding-right: var(--gap-xs); -} - -.frm-search > .frmsvg { - box-sizing: unset; -} - -.frm-with-right-icon .frmsvg, -.frm-with-right-icon i:not([class*=mce-]) { - right: 0; - top: -3px; - left: auto; - padding: 0 10px 0 5px; -} - -.frm_form_settings .frm-with-right-icon .frmsvg { - top: 0; -} - -.frm_form_settings .wp-editor-container .frm-with-right-icon .frmsvg, -#frm_builder_page .wp-editor-container .frm-with-right-icon .frmsvg { - top: auto; - bottom: var(--gap-sm); -} -.frm_form_settings .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg, -#frm_builder_page .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg { - bottom: var(--gap-lg); -} - -.frm_form_settings .frm_has_textarea .frm-with-right-icon .frmsvg { - top: auto; - bottom: 6px; -} - -.frmsvg.frm-show-box, -.frmsvg.frm-show-inline-modal, -i.frm-show-box, -i.frm-show-inline-modal { - top: auto; - background-color: var(--primary-50); - color: var(--primary-500); - border-radius: 6px; - padding: var(--gap-2xs); - margin: 5px; /* input height - svg / 2 */ - margin-bottom: 0; - z-index: 1; - cursor: pointer; - pointer-events: initial; -} -.frmsvg.frm-show-box:focus, -.frmsvg.frm-show-inline-modal:focus, -i.frm-show-box:focus, -i.frm-show-inline-modal:focus { - outline: 1px solid var(--primary-500); -} - -.frm_form_settings .frmsvg.frm-show-box, -.frm_form_settings .frmsvg.frm-show-inline-modal, -.frm_form_settings i.frm-show-box, -.frm_form_settings i.frm-show-inline-modal { - margin: 4px 4px 0; -} - -/** - * Inline Modals - */ -.frm-open + .frm-inline-modal { - top: -10px; - margin-bottom: 0; -} -.frm-open + .frm-inline-modal.frm-modal-no-dismiss .inside > .frm-search:first-child { - margin-top: var(--gap-sm); -} - -.frm_grid_container > .frm-open + .frm-inline-modal { - top: -4px; -} -.frm_grid_container > .frm-open + .frm-inline-modal.frm-modal-no-dismiss { - top: 0 !important; -} - -/** - * Input Positioning - */ -.frm-with-left-icon input { - padding-left: 37px !important; -} - -.frm_wrap .frm-with-right-icon textarea, -.frm_wrap .frm-with-right-icon input, -.frm_wrap .frm-with-right-icon input[type=text] { - padding-right: var(--gap-md); -} - -#frm-show-fields .frm-with-left-icon .frmsvg, -#frm-show-fields .frm-with-left-icon i { - padding-top: 10px; -} - -/** - * Search Inputs - */ -.frm-search input[name=s], -.frm-search .dropdown-toggle, -.frm-search input.frm-search-input { - color: var(--grey-800); - border-color: var(--grey-300); - border-radius: var(--small-radius); - box-shadow: var(--box-shadow-xs); -} -.frm-search input[type=search], -.frm-search input[type=text] { - padding-left: var(--gap-lg) !important; -} -.frm-search .dropdown-toggle { - width: 100%; - float: none; - max-width: 200px; - background: transparent; - padding: 7px; - padding-left: 33px !important; - min-height: 32px; - text-align: inherit; - overflow: hidden; - text-overflow: ellipsis; -} -.frm-search #search-submit a { - color: var(--grey-800); -} -.frm-search #search-submit .caret { - opacity: 0.7; -} - -.frm-white-body .search-box input[name=s], -#wpwrap .frm-search input[type=search] { - flex: 1; - font-size: var(--text-md); - line-height: var(--text-xl); - padding: var(--gap-xs); -} - -span.multiselect-selected-text { - white-space: nowrap; - display: inline-block; - max-width: calc(90% - var(--gap-xs)); - text-overflow: ellipsis; - overflow: hidden; -} - -/** - * Not Set Fields - */ -.frm-not-set input { - color: var(--primary-500) !important; - font-size: 13px; -} - -.frm-not-set .frmsvg, -.frm-not-set i { - color: var(--primary-700); - opacity: 1; -} - -/** - * Shortcode Select - */ -.post-type-frm_display select[name=m] + #post-query-submit, -select[name=m] { - display: none; -} - -.frm_shortcode_select optgroup option { - margin-left: 1em; -} - -.frm_shortcode_select optgroup { - padding-top: 5px; -} - -.frm_shortcode_select .frm_subopt { - margin-left: 2em; -} - -.misc-pub-section a.edit-frm_shortcode, -.misc-pub-section a.edit-form-status { - float: none; - font-size: 13px; -} - -.frm-grid { - border-collapse: collapse; - border: none; - margin-right: 10px; -} - -.frm-grid td, -.frm-grid th { - padding: 5px; - border: 1px solid black; -} - -/** - * View Page Admin - */ -.post-type-frm_display #poststuff #post-body.columns-2 { - margin-right: var(--big-sidebar); -} - -.post-type-frm_display #post-body.columns-2 #postbox-container-1 { - margin-right: calc(var(--big-sidebar) * -1); - width: calc(var(--big-sidebar) - 40px); -} - -.post-type-frm_display #poststuff #post-body.columns-2 #side-sortables { - width: 100%; -} - -#frm_dyncontent .hndle, -#frm_dyncontent .handlediv { - display: none !important; -} - -.post-type-frm_display .meta-box-sortables .frm_form_nav > li > a, -.post-type-frm_display .frm_form_nav .nav-tab-active { - padding: 0 2px 5px; - line-height: 1.4; -} - -.post-type-frm_display #advanced-sortables h2.hndle, -.post-type-frm_display #side-sortables h2.hndle, -.post-type-frm_display #normal-sortables h2.hndle { - border-bottom: 1px solid var(--grey-300); - margin: 10px 0 0 !important; - padding: 0 25px 8px; -} - -.post-type-frm_display #side-sortables h2.hndle { - margin-top: 0 !important; - padding-top: 10px; -} - -.post-type-frm_display #post-body-content { - margin-top: var(--gap-lg); -} - -.post-type-frm_display.edit-php #wpbody-content > .wrap { - margin: 0; -} - -.post-type-frm_display .postbox .hndle, -.post-type-frm_display .postbox { - border-color: var(--grey-300); -} - -.post-type-frm_display #postbox-container-1 .postbox, -.post-type-frm_display #postbox-container-2 .postbox { - border-radius: var(--small-radius); - border-color: var(--grey-300); - box-shadow: none; -} - -.post-type-frm_display #side-sortables .postbox { - border-radius: 0; - border-top-width: 0; - margin-bottom: 0; -} - -.post-type-frm_display #side-sortables .misc-pub-section { - padding: 15px 20px 10px; -} - -/** - * View Page Admin Icons - */ -.post-type-frm_display .misc-pub-section .frmsvg, -.post-type-frm_display #post-body .misc-pub-post-status::before, -.post-type-frm_display #post-body #visibility::before, -.post-type-frm_display .curtime #timestamp::before, -.post-type-frm_display #post-body .misc-pub-revisions::before, -.post-type-frm_display span.wp-media-buttons-icon::before { - color: var(--grey); -} - -.post-type-frm_display #frm_top_bar + #poststuff #submitdiv #publishing-action, -.post-type-frm_display #frm_top_bar + #poststuff #submitdiv #minor-publishing-actions, -.post-type-frm_display #frm_top_bar + #poststuff #edit-slug-box, -.post-type-frm_display .wrap h1.wp-heading-inline, -.post-type-frm_display .wrap > .page-title-action { - display: none; -} - -/** - * View Page Admin Tabs - */ -.post-type-frm_display #poststuff h2.nav-tab-wrapper { - padding-left: 10px; - margin-bottom: 0; - padding-bottom: 0; -} - -.post-type-frm_display .nav-menus-php .wrap { - margin: 10px 0 0; -} - -.post-type-frm_display .nav-menus-php .wrap p { - padding-left: 12px; - padding-right: 12px; -} - -.post-type-frm_display .nav-tab { - display: inline-block; - background-color: #f4f4f4; -} - -.post-type-frm_display .nav-tab.frm_hidden { - display: none; -} - -.post-type-frm_display .nav-tab:hover { - background-color: #e4e4e4; -} - -/** - * Order/Where Rows - */ -.frm_order_row, -.frm_where_row { - margin-bottom: 7px; - line-height: 30px; -} - -.frm-single-settings .frm_prod_field_opt_cont { - margin-top: initial; - margin-bottom: 20px; -} - -/** - * Editor Elements - */ -/*hide elements if js is avail*/ -select.texture { - display: none; -} - -.post-type-frm_display #wp-content-editor-tools, -#wp-content-editor-tools { - background-color: transparent; -} - -.post-type-frm_display #major-publishing-actions { - border-color: var(--grey-300); - background: var(--sidebar-color); -} - -/** - * Advanced Info Panel - */ -.post-type-frm_display #frm_adv_info { - width: calc(var(--big-sidebar) - 40px); - height: calc(100vh - 32px); - overflow: hidden; -} - -.post-type-frm_display #frm_adv_info:not(.frm_fixed) { - top: 0 !important; -} - -.post-type-frm_display #frm_adv_info.frm_fixed { - position: fixed; - z-index: 9999; - top: 32px; -} - -.post-type-frm_display #frm_adv_info ul.frm_code_list.frm-full-hover { - max-height: calc(100vh - 180px); -} - -/** - * Column Layout - */ -.frm_col_one { - margin-right: 4%; - clear: both; -} - -ul .frm_col_one { - float: left; -} - -ul .frm_col_two { - float: right; -} - -ul.frm_two_col { - display: grid; - grid-template-columns: repeat(2, minmax(0, 1fr)); - gap: var(--gap-sm); -} - -.frm_two_col li { - margin-bottom: 0; -} - -/** - * Component: Info Modals - */ -.frm-info-modal a, -.frm-info-modal ul, -.frm-info-modal p, -.frm-info-modal, -.settings-lite-cta a, -.settings-lite-cta ul, -.settings-lite-cta { - color: var(--grey-500); - font-size: var(--text-md); - box-shadow: none !important; -} - -.frm-info-modal h3, -.settings-lite-cta h3 { - font-size: 17px !important; -} - -.frm-green-icons .frmsvg { - color: var(--green); -} - -.frm-info-modal .postbox .inside, -.settings-lite-cta .postbox .inside { - padding: var(--gap-md); - margin: 0; -} - -.cta-inside a { - color: var(--orange); -} - -.info-modal-inside a.frm-standard-link { - color: var(--primary-500); -} - -.info-modal-inside a.frm-standard-link:hover { - color: var(--primary-700); -} - -.frm_no_p_margin > p { - margin: 0; -} - -/** - * Component: Code List - */ -.frm_code_list a.button { - display: block; - text-align: center; - font-size: 11px; - overflow: hidden; -} - -#frm-navbarDrop + .frm_code_list.frm-full-hover { - margin: var(--gap-xs) 0 0; - min-width: 300px; - max-height: 256px; -} - -.frm_code_list.frm-full-hover li { - margin: 0; -} - -.frm-select-list-item, -.frm_wrap .ui-autocomplete li > div, -.multiselect-container button.multiselect-option, -.frm-dropdown-menu > .dropdown-item > a, -.frm-dropdown-menu > .dropdown-item > a:visited, -.frm-dropdown-menu > .dropdown-item > a:link, -.frm-dropdown-menu .frm_dropdown_li, -.frm_code_list.frm-full-hover a { - display: flex; - color: var(--grey-700); - padding: 5px 10px; - font-size: var(--text-md); - gap: var(--gap-xs); - align-items: center; -} - -.multiselect-container button.multiselect-option.disabled { - opacity: 0.5; -} - -.frm_code_list.frm-full-hover a span { - max-width: 83px; - margin-right: var(--gap-xs); - margin-left: auto; -} - -.frm_code_list.frm-full-hover a { - border-radius: var(--small-radius); -} -.frm_code_list.frm-full-hover a:not(#frm-insert-condition), -.frm_code_list.frm-full-hover a span { - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; -} -.frm_code_list.frm-full-hover a:focus span:last-child { - outline: 1px solid var(--primary-500); - outline-offset: var(--gap-2xs); -} - -.frm_code_list.frm-full-hover.frmcenter a { - display: block; -} - -#frm-layout-classes frm-full-hover a span { - max-width: 45%; -} - -.frm-select-list-item.active, -.frm-select-list-item:hover, -.frm_wrap .ui-autocomplete li div.ui-state-active, -.frm_wrap .ui-autocomplete li.ui-state-focus, -.multiselect-container button.multiselect-option.active, -.multiselect-container button.multiselect-option:hover, -.frm-dropdown-menu > .dropdown-item > a:hover, -.frm_code_list.frm-full-hover a:hover span, -.frm_code_list.frm-full-hover a:hover { - background: var(--primary-25); - color: var(--primary-500); -} - -.frm-select-list-item .frmsvg, -.frm-dropdown-menu > .dropdown-item > a .frmsvg { - opacity: 0.8; -} - -.frm-select-list-item:hover .frmsvg, -.frm-dropdown-menu > .dropdown-item > a:hover .frmsvg { - opacity: 1; -} - -.frm-dropdown-menu.frm_code_list > li > a { - padding: 3px 15px; - width: 300px; -} - -#frm_edit_box_content_modal .frm-with-search, -.frm-dropdown-menu .frm-with-search { - padding: var(--gap-xs) 10px 0; -} - -.frm-dropdown-menu .subsubsub { - padding: 0 10px; -} - -.frm_grid_container { - overflow: visible; -} - -.frm_code_list.frm_grid_container { - grid-gap: var(--gap-xs); -} - -.frm_code_list.frm_grid_container li { - width: auto; - margin: 0; -} - -.frm_code_list.frm_grid_container a { - display: block; - font-size: var(--text-md) !important; - font-weight: 500; - text-align: center; - color: var(--primary-500); - background-color: var(--light-blue); - border: 1px solid var(--primary-300); - border-radius: var(--small-radius); - padding: 10px 0; - box-shadow: var(--box-shadow-sm); -} -.frm_code_list.frm_grid_container a:hover { - background-color: var(--primary-500); - color: #fff; -} -.frm_code_list.frm_grid_container a:focus-visible { - outline: 2px solid var(--primary-500); - outline-offset: -1px; -} - -.frm-single-settings .frm_code_list.frm-full-hover, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { - padding: 0; - margin: var(--gap-xs) -10px 0; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a { - font-size: var(--text-md); - color: var(--grey-900); - padding: var(--gap-xs) 12px; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a span, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span { - margin: 0; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a span:first-child, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:first-child { - max-width: 130px; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a span:last-child, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:last-child { - max-width: 120px; - margin-left: auto; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover { - font-weight: 500; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover .frmsvg, -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover span, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover .frmsvg, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover span { - color: var(--primary-500); -} - -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { - margin: var(--gap-xs) 0 0; -} -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg { - width: 20px; - height: 20px; -} - -/** - * Component: Insert Fields - */ -.frm_field_list #frm-insert-fields { - max-height: none; - font-size: var(--text-sm); -} -.frm_field_list #frm-insert-fields .button a { - display: block; - max-width: 95%; - overflow: hidden; -} - -#frm-insert-fields { - padding: 0 var(--gap-xs); - overflow: hidden; -} -#frm-insert-fields .frm-search { - float: none; - margin: 0 0 var(--gap-md); - width: auto; -} -#frm-insert-fields li { - /* Prevents advanced fields from always appearing in search results */ -} -#frm-insert-fields li, -#frm-insert-fields li a { - text-decoration: none; - font-weight: 500; - font-size: var(--text-md) !important; - color: var(--grey-900); -} -#frm-insert-fields li.frm_show_upgrade { - cursor: pointer; - opacity: 0.5; -} -#frm-insert-fields li.frm_show_update { - cursor: pointer; -} -#frm-insert-fields li span:not(.frm-new-pill) { - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; - text-align: left; -} -#frm-insert-fields li a.disabled:hover { - cursor: not-allowed; -} -#frm-insert-fields li.ui-draggable-disabled { - opacity: 0.5; -} -#frm-insert-fields li a:not(.disabled):hover .frmsvg, -#frm-insert-fields li a:not(.disabled):hover i { - color: var(--grey-600); -} -#frm-insert-fields li.frm_show_upgrade, #frm-insert-fields li.frm_show_update, -#frm-insert-fields li a { - text-decoration: none; - display: inline-flex !important; - gap: var(--gap-xs); - align-items: center; - border-radius: var(--small-radius) !important; - padding: 11px var(--gap-md) 11px var(--gap-xs) !important; - color: var(--grey-900) !important; -} -#frm-insert-fields li a { - display: flex !important; - transition: background-color 0.2s ease-out, box-shadow 0.2s ease-out; -} -#frm-insert-fields li a:not(.disabled):hover { - background: #fff; - box-shadow: var(--box-shadow-md); -} -#frm-insert-fields li a:focus-visible { - outline: 1px solid var(--primary-500); -} -#frm-insert-fields li.frm_show_upgrade.frm_hidden, #frm-insert-fields li.frm_show_update.frm_hidden { - display: none !important; -} -#frm-insert-fields .frm-with-line { - padding: 12px var(--gap-md); - font-weight: 500; - font-size: var(--text-sm); -} -#frm-insert-fields .frm-with-line::before { - margin-left: calc(-1 * var(--gap-sm)); - width: calc(100% + var(--gap-md)); -} - -.frm_code_list { - clear: both; -} -.frm_code_list.frm-full-hover a.frm_hidden, -.frm_code_list .frmkeys { - display: none; -} - -.frmsvg { - fill: currentColor; - width: 18px; - height: 18px; - vertical-align: middle; -} -.frmsvg svg { - pointer-events: none; -} -.frmsvg.frm_svg40 { - width: 40px; - height: 40px; -} -.frmsvg.frm_svg24 { - width: 24px; - height: 24px; -} -.frmsvg.frm_svg20 { - width: 20px; - height: 20px; -} -.frmsvg.frm_svg15 { - width: 15px; - height: 15px; -} -.frmsvg.frm_svg14 { - width: 14px !important; - height: 14px !important; -} -.frmsvg.frm_svg13 { - width: 13px; - height: 13px; -} -.frmsvg.frm_svg12 { - width: 12px; - height: 12px; -} -.frmsvg.frm_svg9 { - width: 9px; - height: 9px; -} -.frmsvg.frm_svg7 { - width: 7px; - height: 7px; -} - -input[disabled] { - pointer-events: none; -} - -.frmbutton.ui-sortable-helper .frmsvg, -.field_type_list li.frmbutton .frmsvg, -.frmbutton.ui-sortable-helper i, -.field_type_list li.frmbutton i, -.frm_code_list a .frmsvg, -.frm_code_list a i { - color: var(--grey-500); - display: inline-block; - vertical-align: middle; - width: var(--text-md); - font-size: var(--text-md); -} - -.field_type_list.frm_grid_container { - gap: 10px; - margin: 13px 0; -} -.field_type_list li { - margin: 0; - padding: 0; -} -.field_type_list li.frmbutton .frmsvg { - width: 24px; - height: 24px; - font-size: 24px; -} - -.frm_code_list i::before { - font-size: inherit; -} - -/* Icon while dragging */ -.frmbutton.ui-draggable-dragging { - pointer-events: none; -} -.frmbutton.ui-draggable-dragging a { - color: var(--grey-900) !important; - background: var(--grey-100); - text-decoration: none; - display: inline-flex !important; - gap: var(--gap-xs); - align-items: center; - border-radius: var(--small-radius) !important; - padding: 11px var(--gap-md) 11px var(--gap-xs) !important; - box-shadow: var(--box-shadow-md); -} - -.frmbutton.frm_at_limit { - opacity: 0.5; -} - -/** - * Component: Field Dragging - */ -.frmbutton.ui-draggable-dragging a { - border: 1px solid var(--grey-300); - box-shadow: var(--box-shadow-md); -} - -.frmbutton.ui-draggable-dragging span { - font-size: 15px; -} - -#frm-show-fields .frmbutton.ui-sortable-helper i, -.frmbutton.ui-draggable-dragging i, -.frmbutton.ui-draggable-dragging .frmsvg { - color: #fff !important; -} - -.frmbutton.ui-draggable-dragging i, -.frmbutton.ui-draggable-dragging .frmsvg { - color: var(--grey-700) !important; -} - -.frm_sorting li.ui-state-default.ui-sortable-helper, -.frmbutton.ui-sortable-helper { - transition: opacity 0.2s; - opacity: 1; - position: fixed; - z-index: 99999; -} - -#frm-insert-fields .frmbutton.ui-sortable-helper a, -#frm-show-fields .frmbutton.ui-sortable-helper a { - min-width: 100px; -} - -.ui-draggable-dragging .frm-meta-tag.frm-new-pill { - display: none; -} - -/* End dragging */ -li.frm_noallow.button, -.frm_noallow { - opacity: 0.5; -} - -.frm_actions_list a.frm_show_upgrade.frm_inactive_action::before, -li.frm_noallow.button.frm_show_upgrade, -li.frm_noallow.button.frm_show_update { - cursor: pointer; -} - -.field_type_list li.frm_noallow.button.frm_show_upgrade:hover, -.field_type_list li.frm_noallow.button.frm_show_update:hover { - border-color: inherit; -} - -.frm_noallow a { - color: inherit; -} - -/** - * Component: Upgrade Modal - */ -#frm_upgrade_modal_image { - max-width: 200px; -} - -#frm_upgrade_modal .cta-inside { - display: flex; - flex-direction: column; - gap: var(--gap-sm); -} -#frm_upgrade_modal .frm-upgrade-message img { - width: 100%; - margin: var(--gap-sm) 0 10px; -} -#frm_upgrade_modal .frm-oneclick.frm_hidden { - display: none !important; -} -#frm_upgrade_modal .frm-oneclick-button { - margin-left: auto; -} -#frm_upgrade_modal .frm-upgrade-modal-actions { - flex-direction: row-reverse; - justify-content: flex-start; - margin: 0 !important; -} -#frm_upgrade_modal .frm-upgrade-link { - align-self: end; -} -#frm_upgrade_modal.frm-success .frm-circled-icon svg { - width: 24px; - height: 24px; -} -#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-prefix, -#frm_upgrade_modal.frm-success .frm_are_not_installed { - display: none !important; -} -#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-suffix { - display: inline !important; -} -#frm_upgrade_modal.frm-success .frm-addon-status { - margin: 0; -} -#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options { - display: flex; - gap: var(--gap-xs); - flex-direction: row-reverse; - margin: 0; -} -#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options .frm-save-and-reload { - margin: 0; -} - -.frm-dialog[aria-describedby=frm_upgrade_modal] { - position: fixed !important; - top: 50% !important; - left: 50% !important; - transform: translate(-50%, -50%) !important; -} - -/** - * Layout: Reports Info - */ -.frm-tab-message { - max-width: 600px; - margin: 20px auto; - color: rgba(63, 75, 91, 0.8); -} - -.frm-settings-screenshot-toolbar { - min-height: 39px; - display: flex; -} - -.frm-settings-screenshot-toolbar .frm-minmax-icon { - height: 8px; - width: 8px; - border-radius: 50%; - align-self: center; - margin-left: 10px; -} - -.frm-settings-screenshot-toolbar .frm-minmax-icon:first-of-type { - margin-left: 20px; -} - -.frm-settings-screenshot-toolbar img { - object-fit: contain; - align-self: flex-end; - margin-left: 25px; -} - -.frm-settings-screenshot-toolbar + div { - background: #fff; - padding-top: 25px; - border-radius: 0 0 16px 16px; -} - -.frm-settings-screenshot-toolbar + div img { - max-width: calc(100% - 40px); -} - -.frm-settings-screenshot-wrapper { - max-width: 700px; - margin: 50px auto 0; - box-shadow: 0 4px 4px rgba(189, 196, 205, 0.25), 0 12px 56px rgba(42, 57, 75, 0.25); - border-radius: 16px; - background: #ebecf1; -} - -/** - * Component: Dialog - */ -.frm-dialog { - z-index: 100; - padding: 0 !important; - border-radius: 16px; - border: none; - background-color: #fff; - max-width: 100% !important; -} - -.frm-dialog .postbox { - background: transparent; - box-shadow: none; - border: none; - line-height: var(--leading); -} - -.frm-dialog input[type=text], -.frm-dialog textarea { - font-size: var(--text-md); -} - -.frm-dialog textarea { - height: 75px; -} - -.frm-dialog button.frm-button-primary { - margin-right: 10px; -} - -.frm-dialog .frm-sub-label, -.frm-sub-label { - color: var(--grey); - text-transform: none; - padding-left: 8px; -} - -h2 .frm-sub-label { - font-size: var(--text-md); -} - -.frm-views-editor-body .ui-widget-overlay, -.frm-white-body .ui-widget-overlay, -.toplevel_page_formidable .ui-widget-overlay, -body[class*=formidable-payments] .ui-widget-overlay, -body.plugins-php .ui-widget-overlay { - position: fixed; - width: 100%; - height: 100%; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: var(--grey-500); - opacity: 0.5; - z-index: 2; -} - -/** - * Component: Circled Icons - */ -.frm-circled-icon { - width: 60px; - height: 60px; - border-radius: 50%; - background-color: var(--primary-25); -} - -.frm-circled-icon-large { - width: 80px; - height: 80px; -} - -.frm-circled-icon-green { - background-color: var(--success-50); -} - -.frm-circled-icon .frmsvg { - width: 21px; - height: 24px; -} -.frm-circled-icon .frmsvg.frm_svg32 { - width: 32px !important; - height: 32px !important; -} - -.frm-circled-icon-large .frmsvg { - width: 24px; -} - -.frm-circled-icon .frmsvg use { - color: var(--primary-500); -} - -.frm-circled-icon-green .frmsvg use { - color: var(--success-500); -} - -.frm-border-icon { - display: flex; - align-items: center; - justify-content: center; - width: 40px; - height: 40px; - border: 1px solid var(--grey-300); - border-radius: var(--small-radius); -} - -.frm-upgrade-message img { - max-width: 100%; -} - -/** - * Component: Link Styles - */ -a.frm-link-secondary { - color: #c4c4c4; - font-size: var(--text-sm); - text-decoration: underline; -} - -.field_type_list li.button.frm_noallow, -.field_type_list li.button.frm_noallow:hover, -.button.frm_noallow, -.button.frm_noallow:hover { - color: inherit; - border-color: #ccc; - background: inherit; -} - -iframe#dyncontent_ifr { - min-height: 150px; -} - -/*! +@font-face{font-family:"s11-fp";src:url("../fonts/s11-fp.woff?v=7") format("woff");font-weight:400;font-style:normal}.frm-submenu-highlight{background:#1da867}.frm-submenu-highlight a span{color:#fff;font-weight:600}.frmfont,.frm_icon_font{text-decoration:none;text-shadow:none;font-weight:400;display:inline-block;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:auto;line-height:1.5;transition:color .1s ease-in-out,opacity .1s ease-in-out;font-size:18px}i.frmfont,i.frm_icon_font{font-style:normal;font-variant:normal;speak:none}.frmfont::before,select.frmfont,.frm_icon_font::before,select.frm_icon_font{font-family:"s11-fp" !important;text-align:center}.frmfont,a.frmfont,.frmfont:hover,a.frmfont:hover .frm_icon_font,a.frm_icon_font,.frm_icon_font:hover,a.frm_icon_font:hover{text-decoration:none !important;box-shadow:none}.frmfont:focus,.frm_icon_font:focus{box-shadow:none}.frmfont:active,.frm_icon_font:active{outline:none}.frm_trigger .frm_icon_font{padding:0 5px}.frm_tooltip_icon::before{content:"\e611"}.frm_delete_icon::before{content:"\e610" !important}.frm_arrowdown6_icon::before{content:"\e62a"}:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}@font-face{font-family:"Inter";src:url("../fonts/Inter-VariableFont_slnt,wght.ttf?v=1") format("truetype")}.with_frm_style,.frm-white-body .wpbody-content,.frm_wrap{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen-Sans,Ubuntu,Cantarell,"Helvetica Neue",sans-serif}@media not all and (min-resolution: 0.001dpcm){@supports(-webkit-appearance: none) and (stroke-color: transparent){.with_frm_style,.frm-white-body .wpbody-content,.frm_wrap{-webkit-font-smoothing:antialiased}}}.frm-sm-z-index{z-index:1}.frm-md-z-index{z-index:5}.frm-white-body,.frm-white-body p,.frm_wrap,.frm_wrap p,.frm-modal,.frm-white-body .postbox .inside{font-size:var(--text-sm);color:var(--grey-500);line-height:var(--leading)}.frm-white-body p,.frm_wrap p{margin:var(--gap-sm) 0}body:not(.frm-admin-page-styles):not(.frm-admin-page-style) .with_frm_style .frm_form_fields>fieldset{--fieldset-padding: 15px 0}a,.widget .widget-top,.stuffbox h3,.frm-collapsed{cursor:pointer;text-decoration:none}.post-type-frm_display .wrap>#posts-filter,.wrap.frm-with-margin,.frm_wrap>.wrap{margin:var(--gap-sm) var(--gap-md) var(--gap-md)}#frm_top_bar+.wrap{margin:var(--gap-xl)}.frm-full-screen #wpbody-content>.wrap{margin:0}.post-type-frm_display .wrap{margin:0}.toplevel_page_formidable #post-body-content{overflow-x:visible}.frm-full-screen{height:100%;overflow:hidden}.frm-full-screen.frm-admin-page-reports,.frm-full-screen.frm-admin-page-entries,.frm-full-screen.post-type-frm_display{overflow:auto}.frm-full-screen #wpadminbar,.frm-full-screen #adminmenumain,.frm-full-screen .wp-header-end{display:none}body.frm-white-body:not(.frm-full-screen) .mce-fullscreen{top:32px;left:160px}.frm-full-screen #wpbody-content,.frm-full-screen #wpbody,.frm-full-screen #wpcontent{padding:0;overflow:hidden;margin:0 !important}.frm-white-body #wpbody-content{position:relative;padding-bottom:0}.post-new-php.post-type-frm_display #screen-meta-links,.post-php.post-type-frm_display #screen-meta-links{display:none}.frm-white-body #screen-meta-links{position:fixed;bottom:0;right:20px}.frm-full-screen #screen-meta-links .screen-meta-toggle{right:55px}.frm-white-body #screen-meta-links .show-settings{border-radius:var(--small-radius) var(--small-radius) 0 0;border:1px solid var(--grey-300);border-bottom:none}.frm-white-body.frm-lite #screen-meta-links .screen-meta-toggle{right:125px}.frm-white-body #screen-meta{margin:0}.frm-white-body #screen-meta-links .show-settings::after{color:var(--grey)}.frm-white-body .columns-2{border-bottom:1px solid var(--grey-300)}.frm-full-screen .columns-2{border:none}body.post-type-frm_display.edit-php,body.frm-white-body{background:#fff}body.frm-white-body ul#adminmenu a.wp-has-current-submenu::after,body.frm-white-body ul#adminmenu>li.current>a.current::after{border-right-color:#fff}.frm-white-body #wpcontent{padding-left:0;padding-right:0}.frm-white-body .wrap #post-body{padding:0 20px}.frm-grey-body #wpbody{background:var(--grey-100)}.frm-grey-body #frm_top_bar{background:#fff}.post-type-frm_display .tablenav,.frm_wrap .tablenav{margin-bottom:10px}.frm-white-body .tablenav .actions select,.wp-admin .frm_wrap .tablenav select{margin-right:var(--gap-xs)}.tablenav .actions .button{margin-top:1px}.frm-white-body table.widefat{background:var(--lightest-grey);border-width:0;box-shadow:none;margin:20px 0}.frm-white-body table.widefat tfoot,.frm-white-body table.widefat thead{background:#fff}.frm-white-body table.widefat th{font-size:var(--text-md)}.frm-white-body table.widefat th a{color:var(--grey-700)}.frm-white-body table.widefat strong a{color:var(--primary-700)}.frm-scroll-box{clear:both;overflow:auto;max-height:405px;border:1px solid var(--grey-300);border-radius:var(--small-radius)}.frm_form_field.frm_scroll_box .frm_opt_container{height:100px;overflow:auto;border:1px solid var(--grey-300)}.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden)+p,.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden)+div,.frm_form_field.frm6_followed:not(.frm_hidden):not(.frm-force-hidden)+span{grid-column:span 6/span 6;align-content:center}.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden)+p,.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden)+div,.frm_form_field.frm12_followed:not(.frm_hidden):not(.frm-force-hidden)+span{grid-column:span 12/span 12 !important;align-content:center}.frm_form_field.frm-phone-type~[id*=frm-field-format-custom-]>label,.frm_form_field.frm-format-dropdown~[id*=frm-field-format-custom-]>label{opacity:0}.frm_form_field.frm-format-dropdown~[id*=frm-field-format-custom-]{grid-column:span 6/span 6}.frm-single-settings.frm-type-textarea>.frm_grid_container [id*=frm-field-format-custom-]+p{grid-column:span 12/span 12}.frm-single-settings .frm_grid_container{column-gap:var(--gap-sm)}.frm-content-center{align-content:center}.frm-self-end{align-self:end}.frm-short-list{overflow:auto;max-height:190px}.frm-white-body table.frm-border td{font-size:var(--text-sm)}.frm-white-body .striped>tbody>:nth-child(odd){background-color:#fff}.frm_wrap td.column-title strong{display:inline}#frm_top_bar{display:flex;gap:var(--gap-sm);width:100%;height:72px;margin:0;box-sizing:border-box;text-align:center;padding:0 var(--gap-md)}#frm_top_bar>.frm-full-close:last-child,#frm_top_bar>#frm-publishing:last-child{margin-left:auto}#frm_top_bar{border-bottom:1px solid var(--grey-300);padding:0 var(--gap-md);overflow:visible}.frm-white-body h1,.frm-white-body h2,.frm-white-body h3,.frm-white-body h4{color:var(--grey-900);font-weight:400;line-height:var(--leading) !important}.frm-white-body .wrap h1,.frm-white-body h1{font-size:var(--text-xl)}.frm-white-body .wrap h2,.frm-white-body h2{font-size:var(--text-lg);font-weight:500}.frm-white-body .wrap h3,.frm-white-body h3{font-size:var(--text-md)}.frm-white-body .wrap h4,.frm-white-body h4{font-size:var(--text-sm);font-weight:500}#frm_error_modal .frm_lock_simple{padding:20px;border-radius:50%;background-color:var(--primary-25);display:inline-block}#frm_error_modal #frm_lock_simple{color:var(--primary-500)}#frm_error_modal .frm-modal-title{display:block}#frm_error_modal .frm-modal-title h2{font-weight:600;font-size:var(--text-xl);margin:0}#frm_error_modal .frm_modal_content{padding:var(--gap-md);color:var(--grey-900)}.frm-views-editor-body .frm_page_container #frm_top_bar h1{padding:0 !important;color:var(--grey-900);font-size:var(--text-xl) !important}.post-type-frm_display .frm_top_left{padding-bottom:0 !important}.frm-new-table-view-option.frm-selected-table-view-option{border-radius:var(--small-radius);background:var(--primary-25)}.frm-views-editor-body #frm_adv_info .tabs-panel{padding-left:4px;padding-right:4px}#frm_edit_box_content_modal .frm_modal_footer{padding-top:var(--gap-sm);border-top:1px solid var(--grey-300)}#frm_edit_box_content_modal .frm_modal_footer>div{display:flex;justify-content:space-between}#frm_edit_box_content_modal #frm_modal_box_select_area,#frm_edit_box_content_modal #frm_box_content_wysiwyg_wrapper,#frm_edit_box_content_modal .frm_modal_content{max-height:calc(100vh - 176px) !important}#frm_edit_box_content_modal #frm_modal_box_select_area{height:calc(100vh - 176px) !important}#frm_edit_box_content_modal #wp-content-editor-tools{padding-top:0}#frm_edit_box_content_modal.frm-modal .postbox .frm-modal-title+div:last-child{right:var(--gap-md)}.frm_code_list.frm-full-hover .frm-dropdown-view a{flex-direction:row-reverse}#frm_view_editor_left.frm-right-panel .accordion-section-title::before{content:"" !important;margin:0}.frm-gradient,.frm-upgrade-bar{background:linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important;color:#fff !important;border:0 !important}.frm-gradient.frm-button-primary:not([disabled]),.frm-gradient.frm-button-primary:not([disabled]):hover,.frm-gradient.frm-button-primary:not([disabled]):focus{background:linear-gradient(90deg, #1961d5, #816cfa) !important}.frm-upgrade-bar,.frm-gradient{position:relative}.frm-upgrade-bar::before,.frm-gradient::before{content:"";display:none;position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgba(255,255,255,.1);z-index:0}.frm-upgrade-bar:hover::before,.frm-gradient:hover::before,.frm-gradient:focus::before{display:block}.frm-upgrade-bar-inner,.frm-gradient>*{position:relative;z-index:1}.frm-upgrade-bar{border-bottom:1px solid var(--sidebar-hover);padding:9px 0;font-size:12px;text-align:center}.frm-upgrade-bar a{color:currentColor !important;text-decoration:underline}.frm-upgrade-bar a:focus{outline:1px dotted var(--sidebar-hover)}.frm-upgrade-bar span{opacity:.9}a h1 .frmsvg{color:var(--grey-400);vertical-align:middle;min-width:var(--text-sm)}a .frmsvg{color:currentColor}.frm_wrap .view-switch a.current::before,.frm-white-body a,.frm_wrap a,.frm_wrap a i{color:var(--primary-color)}.frm_wrap a:active,.frm_wrap a:hover{color:var(--primary-700);box-shadow:none}.post-type-frm_display a:focus,.frm_wrap a:focus{box-shadow:none}.frm_top_left{text-align:left;float:left;white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis;align-self:center}.post-type-frm_display .frm_top_left,.frm_top_left.frm_top_wide{max-width:100%}.post-type-frm_display .frm_nav_bar .frm-header-logo,.frm_nav_bar .frm-header-logo{margin:18px 0 10px}#frm_top_bar .frm_form_nav{flex:1}ul.frm_form_nav{margin:0 auto;padding-top:18px;display:block;min-width:240px}.nav-tab-wrapper.frm_form_nav{padding:0 25px}ul.frm_form_nav>li{margin:0 min(3.5%,32px) 0 0;display:inline-block}.post-type-frm_display #advanced-sortables h2.hndle,.post-type-frm_display #side-sortables h2.hndle,.post-type-frm_display #normal-sortables h2.hndle,.post-type-frm_display .frm_form_nav .nav-tab-active,.frm_form_nav>li>a{font-size:1.3em;text-decoration:none;display:block;padding:6px 2px 4px;font-weight:500;color:var(--grey-700);border-bottom:2px solid rgba(0,0,0,0)}.post-type-frm_display.js .postbox .handlediv .toggle-indicator::before{margin-top:10px}.frm-nav-tabs a:focus,.frm-nav-tabs a:active,.frm_form_nav a:active,.frm_form_nav a:focus{outline:none;box-shadow:none}.frm_form_nav>li>a{font-size:var(--text-md);font-weight:400;color:var(--grey-500)}.frm_form_nav>li>a:hover{border-color:var(--primary-700)}.frm_form_nav .frm-dropdown-menu a:hover{background-color:#eaf2fa}.post-type-frm_display .frm_form_nav .nav-tab-active,.post-type-frm_display .frm_form_nav .nav-tab-active:hover,.frm_form_nav>li a.current_page{color:var(--primary-500);border-color:var(--primary-500);background:rgba(0,0,0,0);opacity:1;font-weight:600}.frm-full-close{display:none;padding-left:var(--gap-md);border:0 solid var(--grey-300);border-left-width:1px;height:100%;box-sizing:border-box}.frm-full-screen .frm-full-close{display:flex;align-items:center}.frm-full-close a{display:block}.frm-full-close .frmsvg{font-size:20px;width:20px;height:20px;color:var(--grey-500)}#frm_top_bar h1{font-weight:400;padding:0;margin:0;color:var(--grey-900);display:inline-flex;gap:var(--gap-sm);align-items:center;text-align:left;min-width:200px}#frm_top_bar h1 span{max-width:175px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:inline-block;vertical-align:bottom}#frm_top_bar ul.frm_form_nav,#frm_top_bar .frm-header-logo,#frm_top_bar #frm_bs_dropdown{align-self:center;margin-top:0;margin-bottom:0;padding-top:0}#frm_top_bar .frm-header-logo{display:flex}#frm_top_bar h2{float:left;margin:0 0 0 var(--gap-sm);padding:2px 0 2px var(--gap-sm);font-weight:400;border-left:2px solid var(--grey)}.frm_wrap>#frm_top_bar #frm-publishing{margin-top:0}#frm-publishing{min-width:225px;align-self:center;align-items:center;display:flex;flex-direction:row-reverse;gap:0 var(--gap-sm);flex-wrap:wrap}.frm_wrap .postbox{border-color:var(--grey-300);border-radius:6px;box-shadow:none}.frm_wrap .postbox h3.hndle{cursor:default;padding:10px 20px;margin:0;line-height:1.4em;border-color:var(--grey-300)}.frm-pre-hndle{font-size:15px;padding:5px;margin:9px 15px}.frm-empty-row{display:none}.frm-child-row{box-shadow:5px 0 0 0 inset var(--sidebar-hover)}.frm_animate_bg{transition:background 200ms linear,color 200ms linear}.wrap>.subsubsub{clear:both;margin:0}.frm_wrap .subsubsub a{line-height:var(--leading);font-size:var(--text-sm)}.frm-admin-page-styles .frm_page_container,.frm_wrap .frm_page_container{height:calc(100vh - 32px);display:flex;flex-direction:column;overflow:hidden;padding-top:0;position:fixed;top:32px;bottom:0;left:0;right:0}.frm-admin-page-translate .frm_wrap .frm_page_container,.frm-admin-page-update_translations .frm_wrap .frm_page_container{position:static}.auto-fold.frm-admin-page-styles .frm_page_container,.auto-fold .frm_wrap .frm_page_container,.frm-unfold.frm-admin-page-styles .frm_page_container,.frm-unfold .frm_wrap .frm_page_container{left:160px}.folded.frm-admin-page-styles .frm_page_container,.folded .frm_wrap .frm_page_container{left:38px}.frm-full-screen.frm-admin-page-styles .frm_page_container,.frm-full-screen .frm_wrap .frm_page_container{height:100vh;top:0;left:0}.frm-full-screen.frm-admin-page-entries .frm_page_container,.frm-new-entry .frm_page_container,.frm-admin-page-reports .frm_page_container,.frm_list_entry_page .frm_page_container{height:auto;display:block}.frm-new-entry .columns-2{border:none}.frm-white-body #frm_top_bar,.frm-white-body .columns-2{flex:0 0 auto}.columns-2 .frm-right-panel+div{padding-bottom:var(--gap-md);border-left:1px solid var(--grey-300)}.columns-2 .frm-right-panel+div,.frm_wrap #post-body-content{padding-bottom:0;padding-top:var(--gap-sm);margin-bottom:0;background:#fff;width:auto;float:none;flex:2}.frm-white-body .columns-2{flex:1;display:flex;overflow:hidden}.frm-white-body .columns-2>div{overflow-y:auto;box-sizing:border-box}.frm_wrap .columns-2 .frm-right-panel,.frm-right-panel{flex:0 0 var(--biggest-sidebar);float:none;width:var(--biggest-sidebar);min-width:var(--biggest-sidebar);background-color:var(--sidebar-color);margin:0;box-shadow:none;border:none;padding-bottom:25px}.frm-right-panel .frm_field_list,.frm_wrap .frm-right-panel #frm_adv_info,.frm_wrap #postbox-container-1 #frm_adv_info{box-shadow:none;border:none;margin-bottom:26px}#new_fields,.frm-has-modal,p.frm_has_shortcodes{position:relative}.frm-inline-modal.postbox{background:#fff;border-color:var(--grey-100);border-radius:var(--small-radius);box-shadow:var(--box-shadow-lg)}.frm_has_shortcodes .frmsvg:not(.frm_help .frmsvg),.frm_has_shortcodes i:not([class*=mce-]){position:absolute;color:var(--primary-500);border-radius:50%;border:1px solid rgba(0,0,0,0);z-index:100;text-align:center}.frm_has_shortcodes .frmsvg.frm-show-box{border-radius:6px !important}.frm_has_shortcodes input,.frm_has_shortcodes textarea{padding-left:18px;box-sizing:border-box}#form_settings_page #frm_adv_info,#frm_builder_page #frm_adv_info{display:none;top:0;width:310px;max-height:315px;min-height:200px;overflow-y:scroll;z-index:100}#form_global_settings .columns-2>div{overflow:auto;height:calc(100vh - 32px)}#form_global_settings .columns-2 .frm-right-panel,#form_settings_page .columns-2 .frm-right-panel,#wpbody-content .frm-page-skeleton .frm-right-panel{flex:0 0 var(--small-sidebar);width:var(--small-sidebar);min-width:var(--small-sidebar)}#form_global_settings .frm_grid_container{gap:0 var(--gap-md)}.frm-inner-content{padding:var(--gap-md)}.post-type-frm_display #poststuff{padding:0 0 10px 40px}#postbox-container-2 .postbox .inside{padding:15px 25px}#postbox-container-2 #frm_advanced .inside h3{margin:15px -25px;font-weight:600}#form_settings_page .frm-inner-content{padding-top:0;padding-bottom:150px;position:relative}.frm_wrap #submitdiv{margin-bottom:0;border-width:0 0 1px;width:100%;min-width:unset}.frm_wrap #frm_adv_info .handlediv,.frm_wrap #frm_adv_info .hndle{display:none}.frm_wrap .menu-settings{border:none;margin-top:0}.nodrag a{cursor:pointer}.frm_wrap #frm_adv_info .inside{margin:0}#frm_adv_info>.inside{padding:0}#frm_adv_info ul.subsubsub{padding-bottom:var(--gap-xs) !important}#frm_adv_info ul.subsubsub a{font-weight:500}#frm_adv_info ul.subsubsub .frm-vertical-separator{display:inline-block;width:1px;height:8px;background-color:var(--grey-300)}#frm_adv_info #frm-insert-condition{background-color:var(--primary-50)}#frm_adv_info #frm-insert-condition:hover{background-color:var(--primary-25)}#frm_builder_page #frm_adv_info{width:322px;max-height:356px;border-radius:var(--small-radius);overflow:hidden}#frm_builder_page #frm_adv_info #taxonomy-linkcategory{height:356px;overflow:hidden}#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div{max-height:286px;padding:0}#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div>*{padding-bottom:var(--gap-sm);max-height:unset}#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div>*:last-child{padding-bottom:var(--gap-xs)}#frm_builder_page #frm_adv_info #frm-nav-tabs{display:flex;gap:var(--gap-xs);background-color:var(--grey-100);border-radius:var(--small-radius);border:0;padding:var(--gap-xs);margin:var(--gap-xs) var(--gap-2xs) var(--gap-sm)}#frm_builder_page #frm_adv_info #frm-nav-tabs>li{flex:1;text-align:center}#frm_builder_page #frm_adv_info #frm-nav-tabs>li a{font-weight:500;line-height:1;color:var(--grey-500);border-radius:var(--small-radius);border:0;padding:var(--gap-xs);margin:0}#frm_builder_page #frm_adv_info #frm-nav-tabs>li a:hover{background-color:#eaecf0;color:var(--grey-500) !important;box-shadow:var(--box-shadow-sm)}#frm_builder_page #frm_adv_info #frm-nav-tabs>li.frm-tabs a{background-color:#fff;color:var(--grey-900) !important;box-shadow:var(--box-shadow-sm)}#frm_builder_page #frm_adv_info .frm-search,#frm_builder_page #frm_adv_info .frm-with-search{padding-top:0;margin:0}.frm-right-panel .frm-inline-modal.postbox .inside{margin:0;padding:0 14px 14px}.frm-right-panel .frm-inline-modal.postbox .inside .frm-with-line,.frm-right-panel .frm-inline-modal.postbox .inside .accordion-section-content h4{margin-left:-14px;margin-right:-14px}.frm-right-panel .frm-inline-modal .inside p:not(.howto),.frm-right-panel .frm-inline-modal .inside a{font-size:15px}.frm-inline-modal .inside a.frm_icon_font{font-size:18px}.frm-nav-tabs{margin:10px 0 20px;padding:0 var(--gap-sm);display:block;border-bottom:1px solid var(--grey-300)}#frm-nav-tabs{position:-webkit-sticky;position:sticky;top:0;background-color:var(--sidebar-color);z-index:98;margin-top:0;padding-top:5px}.frm_form_settings #frm_adv_info #frm-nav-tabs{background-color:#fff;margin:0 -4px}.frm_form_settings span.frm-with-right-icon,#frm_builder_page .frm_has_shortcodes span.frm-with-right-icon:not(.frm_hidden){display:block}.frm-inline-modal .frm-nav-tabs,#frm_adv_info .frm-nav-tabs{margin:5px 0 0}#frm_adv_info .frm-nav-tabs.frm-compact-nav{padding-right:0;padding-left:20px}.frm-nav-tabs li{display:inline-block;margin:0}.frm-nav-tabs a{color:var(--grey-700);padding:10px 1px;margin:0 9px;border-bottom:2px solid rgba(0,0,0,0)}.frm_form_settings #frm_adv_info .frm-nav-tabs a{padding:5px 1px;color:var(--grey-500)}.frm-nav-tabs.frm-compact-nav a{margin:0 5px}.frm-nav-tabs a{display:block;opacity:.9}#frm_adv_info .frm-nav-tabs a{color:var(--grey-700)}.frm-nav-tabs a:hover,.frm-nav-tabs .frm-tabs a{color:var(--primary-500) !important;border-color:var(--primary-500)}.frm_form_settings #frm_adv_info .frm-nav-tabs .frm-tabs a{font-weight:500}.frm-payments-tabs{margin-bottom:var(--gap-md);display:flex}.frm-payments-tabs .frm-payments-tab{font-weight:600;font-size:14px;color:var(--grey-900);display:inline-block;border-width:1px;border-style:solid;border-color:#eaecf0;padding:8px 12px;border-radius:6px 6px 0 0;background-color:#f9fafb}.frm-payments-tabs .frm-payments-tab-filler{border-bottom:1px solid #eaecf0;min-width:var(--gap-xs)}.frm-payments-tabs .frm-payments-tab-filler:last-child{flex:1}.frm-payments-tab.frm-active{background-color:#fff;border-bottom:none}.frm-payments-tab a{text-decoration:none;color:var(--grey-900)}#frm-bulk-modal .howto,#frm-bulk-modal h3{font-size:var(--text-sm);font-weight:400;margin:5px 0 10px;color:var(--grey)}#frm-bulk-modal h3{margin-left:20px}.frm-right-panel a.frm_add_logic_link,.frm-right-panel h3{color:var(--grey-700);font-size:var(--text-lg);font-weight:400;margin:0}.frm-right-panel h3 i{color:var(--grey-700);float:right;width:16px;cursor:pointer}.frm-settings-panel{padding:var(--gap-sm);padding-right:var(--gap-xs)}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-delimiter{top:var(--gap-xs);left:var(--gap-xs);width:calc(100% - var(--gap-sm))}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-navs{padding:var(--gap-xs) var(--gap-xs) 0}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track>div{max-height:0;visibility:hidden}.frm-settings-panel .frm-style-tabs-wrapper .frm-tabs-slide-track>div.frm-active{max-height:unset;visibility:visible}.frm-settings-panel .frm-embed-field-placeholder{height:unset}.frm-settings-panel .frm-embed-field-placeholder img{height:100px}.frm-settings-panel .frm-embed-field-placeholder .frm-embed-message{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--gap-sm);max-width:unset;color:var(--grey-800);padding:var(--gap-lg);border:0;box-shadow:var(--box-shadow-sm);margin:1px}.frm-single-settings .frm-default-value-wrapper>p{margin-bottom:0}.frm-single-settings .frm-default-value-wrapper+p:empty{display:none}.frm-single-settings [class*=frm-lookup-box-] .frm_grid_container p{margin-top:0 !important}.frm-single-settings .frm_single_option[id^=frm_watch_lookup_]{margin-bottom:var(--gap-xs) !important}.frm-single-settings>h3:first-of-type{position:relative;background-color:rgba(0,0,0,0) !important;border-top:none;padding-top:0 !important;margin-top:0 !important}.frm-single-settings>h3:first-of-type::after{content:"";position:absolute;left:var(--gap-sm);right:var(--gap-sm);bottom:0;height:1px;background-color:var(--sidebar-hover)}.frm-flex-justify,.frm-right-panel .frm-single-settings h3{display:flex;justify-content:space-between;align-items:center}#post-body-content+.frm-right-panel{flex:0 0 var(--medium-sidebar);width:var(--medium-sidebar);min-width:var(--medium-sidebar);border-left:1px solid var(--sidebar-hover)}.frm-new-entry #post-body-content+.frm-right-panel,.frm-new-entry .frm-right-panel{background:none;border:none}#post-body-content+.frm-right-panel h3{padding:20px 20px 0;font-size:17px}#post-body-content+.frm-right-panel .frm_with_icons:first-of-type h3{border:none}#frm-insert-fields h3{color:var(--grey);font-size:15px;font-weight:400;border-top:none;border-bottom:1px solid var(--sidebar-hover);margin:0;padding:10px 10px 10px 25px}.frm_wrap #frm_adv_info ul.category-tabs{margin:0;padding:10px 0 9px;font-size:15px;background:rgba(0,0,0,0)}.frm_wrap #frm_adv_info ul.category-tabs li{padding:10px;background-color:rgba(0,0,0,0) !important}.frm_wrap #frm_adv_info ul.category-tabs li:first-child{border:none}.frm_wrap #frm_adv_info .categorydiv div.tabs-panel{border:none;background:rgba(0,0,0,0)}.frm_wrap #frm-categorydiv{border-right:none}#frm_adv_info #frm-conditionals{padding-top:var(--gap-sm)}#postbox-container-1 #taxonomy-linkcategory #frm-html-tags{display:none;max-height:none}#postbox-container-1 .frm_field_list #frm-insert-fields .frmbutton.dropdown{position:relative}.frm-white-body #footer-upgrade{display:none}.frm-admin-footer-links,.frm-admin-footer-links-nav,.frm-admin-footer-links-socials{display:flex;justify-content:center}.frm-admin-footer-links{gap:var(--gap-2xs);flex-direction:column;text-align:center;padding:var(--gap-xl) 0 var(--gap-lg);font-size:var(--text-xs);color:var(--grey-400)}body.frm-hidden-overflow{height:100%;overflow:hidden}.frm-admin-footer-links-nav{gap:var(--gap-2xs);margin-bottom:var(--gap-xs)}.frm-admin-footer-links-socials{gap:var(--gap-xs)}.frm-admin-footer-links-socials a{color:var(--grey-400)}.frm_list_entry_page h2{float:left}.frm_list_entry_page h2+.error{clear:both}.frm_sidebar select{width:100%;margin-left:0;margin-right:0}.frm_sidebar #search-submit{float:right}.frm_single_entry_page #submitdiv{margin:0}.frm_single_entry_page .hndle a{font-size:13px}.frm-right-panel #publishing-action{float:none}.frm-right-panel #major-publishing-actions{border-top:none;height:32px;background:rgba(0,0,0,0)}#major-publishing-actions .frm_submit_form{float:right;margin-left:5px}.frm_orange_button,.frm_reverse_button{font-size:12px;border:1px solid var(--orange);color:var(--orange);font-weight:600;padding:1px 4px;border-radius:4px;background:rgba(0,0,0,0)}.frm_reverse_button:hover,.frm_reverse_button:active,.frm_reverse_button:focus{color:#fff;background:var(--orange);border:1px solid var(--orange)}.frm_reverse_button{font-size:1em;transition:all .2s ease}.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.wp-core-ui .button.frm-button-primary,.frm-button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-search .button,.frm-white-body .search-box .button,.frm-white-body .tablenav .button,.frm_orange_button,.toplevel_page_formidable #frm_upgrade_modal .button-primary,.wp-core-ui.frm-white-body .button-primary,.wp-core-ui.frm-white-body .button-secondary,.frm-white-body .button-primary,.frm-white-body .button-secondary,#frm-form-button button,.frm-form-button button,.frm-preview-buttons button,.frm-button-red,.frm-button-tertiary{text-shadow:none;box-shadow:none;border-radius:30px;border:1px solid var(--primary-500);font-size:var(--text-sm);transition:all .2s ease;padding:7px 16px;height:auto;min-height:28px;outline:none;line-height:var(--leading);box-sizing:border-box;font-weight:500;margin-bottom:0;display:inline-block}.frm-button-primary.frm-sharp,.frm-button-secondary.frm-sharp{border-radius:12px !important}#wpcontent .frm-button-secondary.frm-button-gradient{position:relative;border-color:rgba(0,0,0,0) !important;background-clip:padding-box !important}#wpcontent .frm-button-secondary.frm-button-gradient::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;margin:-1px;border-radius:inherit;background:linear-gradient(90deg, #129efd 0%, #a334fd 100%);transition:opacity 150ms ease-out}#wpcontent .frm-button-secondary:hover::before{opacity:.5}.no-js.wp-core-ui .frm-search .button.hide-if-no-js,.js.wp-core-ui .frm-search .button.hide-if-js{display:none}.frm-button-tertiary{border-color:rgba(0,0,0,0);color:var(--primary-500)}.frm-button-tertiary:focus{outline:none}.frm-button-tertiary.frm_loading_button::before{border-right-color:var(--grey);border-bottom-color:var(--grey)}.frm-button-red,.frm-button-red:focus{--primary-color: var(--error-500);--primary-500: var(--error-500);--primary-700: var(--error-700)}.frm-button-red:not(.frm-button-tertiary),.frm-button-red:not(.frm-button-tertiary):focus{color:#fff !important}.frm-white-body h2 .button,.post-type-frm_display h2 .frm-button-primary,.frm-white-body .tablenav .button,.frm-button-primary.frm-button-sm,.frm-button-secondary.frm-button-sm,.frm-button-tertiary.frm-button-sm,.frm-button-red.frm-button-sm{padding:4px 12px !important;font-size:var(--text-xs) !important}.frm_no_style_button{background:rgba(0,0,0,0)}.frm-with-icon{display:flex;gap:var(--gap-xs);align-items:center}.frm-with-icon svg{opacity:.65}.frm-with-icon.button svg{height:var(--text-sm);width:var(--text-sm)}.frm-with-icon.frm-button-sm svg{height:var(--text-xs);width:var(--text-xs)}.frm-white-body .button.add_media{padding-left:12px !important;padding-right:12px !important;font-size:var(--text-xs);border-radius:var(--border-radius)}.wp-core-ui.frm-white-body #post-query-submit.button,.wp-core-ui.frm-white-body .button.tablenav-pages-navspan,.wp-core-ui.frm-white-body .button.first-page,.wp-core-ui.frm-white-body .button.prev-page,.wp-core-ui.frm-white-body .button.next-page,.wp-core-ui.frm-white-body .button.last-page,.wp-core-ui.frm-white-body .button.action{background-color:rgba(0,0,0,0);border-color:var(--grey-300);color:var(--grey-700);border-radius:var(--border-radius)}.post-type-frm_display.wp-core-ui .button-primary,.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.frm_single_entry_page #frm-publishing .button-primary{background-color:var(--primary-500) !important;color:#fff !important}.frm-button-primary.frm_large,.frm-button-secondary.frm_large{height:auto !important;padding:12px 16px !important}.frm-button-secondary.frm-small,.frm-button-primary.frm-small{font-size:var(--text-xs) !important;height:auto !important;padding:var(--gap-2xs) 12px !important}.frm-button-primary i::before{color:#fff}.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover,.frm-button-primary:not([disabled]):hover{background:var(--primary-700) !important;border-color:var(--primary-700) !important}.wp-core-ui .button-primary.frm-button-primary:active{vertical-align:inherit}.frm-white-body #search-submit,#frm-form-button .frm_button_submit,.frm-form-button .frm_button_submit,.frm-white-body .frm-preview-buttons button,.frm-white-body .button:not(.frm-button-primary),.wp-core-ui.frm-white-body .button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-button-secondary,.frm-button-secondary{color:var(--grey-800);border-color:var(--grey-300);background-color:#fff}#wp-content-media-buttons button,#wp-content-media-buttons a.button{border-color:var(--grey-300)}.frm_orange_button{border-color:#da791d !important;background:var(--orange);color:#fff}.frm-white-body .button:not(.frm-button-primary):focus,.frm-white-body .button:not(.frm-button-primary):active,.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:focus,.wp-core-ui.frm-white-body .tablenav .button:hover,.frm_wrap .preview>.button:hover,.frm-white-body #search-submit:hover{border-color:var(--grey-300) !important;color:var(--grey-800);background:var(--grey-50) !important;box-shadow:none !important;outline:none !important}.frm-button-primary .frmsvg{color:#fff}.frm_wrap .preview i{font-size:inherit}.frm-white-body .frm-button-primary:focus,.frm-white-body .frm-button-primary:active,#frm-addons-page .button-primary:focus,#form_global_settings .button-primary:focus,#frm_upgrade_modal .button-primary:focus{border-color:var(--primary-700) !important;background-color:var(--primary-700) !important;box-shadow:none !important;outline:none !important}.frm_wrap .preview>.button:focus,.frm_orange_button:hover,.frm_orange_button:focus,.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover,.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus,.toplevel_page_formidable .frm_wrap button.button-primary:hover,.toplevel_page_formidable .frm_wrap button.button-primary:focus{outline:none}.frm_orange_button:hover,.frm_orange_button:focus{border-color:var(--orange) !important;background:rgba(0,0,0,0);color:var(--orange);opacity:1}.major-publishing-actions.frm_create_form_header{padding:8px 0}.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner{font-size:15px;background:rgba(0,0,0,0)}.frm-menu-boxes .frm_blank_form_text{padding-bottom:26px}input.frm_insert_in_template{font-size:10px;width:98%;font-weight:400}.frm-dismissible a.dismiss:focus{box-shadow:none}.frm-dismissible a.dismiss{top:10px;right:10px;position:absolute}.frm-dismissible a.dismiss svg{color:var(--grey-800)}.frm-btn-unstyled{font:inherit;background:none;border:none;padding:0;cursor:pointer;outline:inherit}.frm-btn-unstyled:hover,.frm-btn-unstyled:focus,.frm-btn-unstyled:active{text-decoration:none;background:none;border:none;box-shadow:none}.frm-btn-unstyled:disabled,.frm-btn-unstyled[disabled]{pointer-events:none;opacity:.65}.wp-admin .frm-review-notice{position:fixed !important;bottom:var(--gap-2xl);right:var(--gap-lg);width:380px;text-align:center;border-color:var(--grey-100);padding:var(--gap-lg);border-radius:var(--medium-radius);box-shadow:var(--box-shadow-lg) !important;z-index:999;box-sizing:border-box;--gap-sm: 16px;--gap-md: 24px;--gap-2xl: 48px}.wp-admin .frm-review-notice *{box-sizing:border-box}.frm-review-notice-icon{display:inline-flex;margin-bottom:var(--gap-sm)}.wp-admin .frm-review-notice-title{font-weight:600;margin-top:0;margin-bottom:var(--gap-xs)}.wp-admin .frm-review-notice-text{margin-top:0;margin-bottom:var(--gap-md)}.frm-review-notice-signature{text-align:left;margin:var(--gap-md) 0}.frm-review-notice-signature img{width:40px;height:40px;padding:3px;box-shadow:var(--box-shadow-md);border-radius:100%}#wpwrap .frm-dismiss-review-notice{top:16px;right:19px}.frm-review-notice #frmapi-feedback [class^=frm__]{display:none}.frm-review-notice #frmapi-feedback input,.frm-review-notice #frmapi-feedback textarea{border-color:var(--grey-300);border-radius:var(--small-radius)}.frm-review-notice #frmapi-feedback input{min-height:unset;max-height:36px}.frm-review-notice #frmapi-feedback textarea{max-height:80px;padding-top:var(--gap-xs)}.frm-review-notice #frmapi-feedback .frm_message{color:var(--success-900);background-color:var(--success-25);border:1px solid var(--success-200);padding:var(--gap-sm) var(--gap-md);margin:0}.frm-review-notice #frmapi-feedback .frm_message p{margin:0}.frm-review-notice #frmapi-feedback .frm_button_submit{background-color:var(--primary-500);border-color:var(--primary-500) !important;cursor:pointer}.frm-review-notice #frmapi-feedback .frm_button_submit:hover,.frm-review-notice #frmapi-feedback .frm_button_submit:focus{color:#fff;background-color:var(--primary-700);border-color:var(--primary-700) !important}.frm-review-notice .frm_error,.frm-review-notice label{color:#444;text-align:left}.frm-review-notice label{font-size:var(--text-sm)}.frm-floating-success-message{position:fixed;z-index:999;border-radius:4px;right:10px;bottom:10px}.frm-box-shadow-xxl{box-shadow:var(--box-shadow-xxl) !important}.frm-text-white{color:#fff !important}.frm-text-primary-500{color:var(--primary-500)}.frm-text-grey-400{color:var(--grey-400) !important}.frm-text-grey-500{color:var(--grey-500) !important}.frm-text-grey-600{color:var(--grey-600) !important}.frm-text-grey-700{color:var(--grey-700)}.frm-text-grey-800{color:var(--grey-800)}.frm-text-grey-900{color:var(--grey-900)}.frm-text-success-500{color:var(--success-500)}.frm-text-warning-500{color:var(--warning-500)}.frm-underline{text-decoration:underline}.frm_no_margin,.frm-m-0{margin:0 !important}.frm-m-12{margin:var(--gap-2xl)}.frm-m-2xs{margin:var(--gap-2xs) !important}.frm_no_top_margin,.frm-mt-0{margin-top:0 !important}.frm-mt-2xs{margin-top:var(--gap-2xs) !important}.-frm-mt-2xs{margin-top:calc(-1*var(--gap-2xs)) !important}.frm-mt-xs{margin-top:var(--gap-xs) !important}.frm-mt-sm{margin-top:var(--gap-sm) !important}.frm-mt-md{margin-top:var(--gap-md) !important}.frm-mt-lg{margin-top:var(--gap-lg) !important}.frm-mt-2xl{margin-top:var(--gap-2xl) !important}.frm-mt-auto{margin-top:auto !important}.frm_no_bottom_margin,.frm-mb-0{margin-bottom:0 !important}.frm-mb-2xs{margin-bottom:var(--gap-2xs) !important}.frm-mb-6{margin-bottom:6px !important}.frm-mb-sm{margin-bottom:var(--gap-sm) !important}.frm-mb-12{margin-bottom:12px !important}.frm-mb-xs{margin-bottom:var(--gap-xs) !important}.frm-mb-md{margin-bottom:var(--gap-md) !important}.frm-mb-lg{margin-bottom:var(--gap-lg) !important}.frm-ml-2xs{margin-left:var(--gap-2xs) !important}.frm-ml-xs{margin-left:var(--gap-xs) !important}.frm-ml-auto{margin-left:auto}.-frm-ml-2xs{margin-left:calc(-1*var(--gap-2xs)) !important}.frm-mr-auto{margin-right:auto}.frm-force-mr-auto{margin-right:auto !important}.frm-mr-2xs{margin-right:var(--gap-2xs) !important}.frm-mr-xs{margin-right:var(--gap-xs) !important}.frm-mr-2{margin-right:2px !important}.frm-mx-0{margin-left:0 !important;margin-right:0 !important}.frm-mx-xs{margin-left:var(--gap-xs) !important;margin-right:var(--gap-xs) !important}.frm-mx-sm{margin-left:var(--gap-sm) !important;margin-right:var(--gap-sm) !important}.frm-my-sm{margin-top:var(--gap-sm) !important;margin-bottom:var(--gap-sm) !important}.frm-my-xs{margin-top:var(--gap-xs) !important;margin-bottom:var(--gap-xs) !important}.frm-p-0{padding:0 !important}.frm-p-1,.frm-p-2xs{padding:var(--gap-2xs)}.frm-p-sm,.frm-p-4{padding:var(--gap-sm) !important}.frm-p-xs{padding:var(--gap-xs) !important}.frm-p-sm{padding:var(--gap-sm) !important}.frm-p-6,.frm-p-md{padding:var(--gap-md) !important}.frm-p-xl{padding:var(--gap-xl) !important}.frm-px-0{padding-left:0 !important;padding-right:0 !important}.frm-py-0{padding-top:0 !important;padding-bottom:0 !important}.frm-py-2xs{padding-top:var(--gap-2xs) !important;padding-bottom:var(--gap-2xs) !important}.frm-py-sm{padding-top:var(--gap-sm) !important;padding-bottom:var(--gap-sm) !important}.frm-pt-0{padding-top:0 !important}.frm-pt-2xs{padding-top:var(--gap-2xs) !important}.frm-pt-xs{padding-top:var(--gap-xs) !important}.frm-pt-sm{padding-top:var(--gap-sm) !important}.frm-pt-md{padding-top:var(--gap-md) !important}.frm-pt-xl{padding-top:var(--gap-xl) !important}.frm-pr-lg{padding-right:var(--gap-lg) !important}.frm-pb-md{padding-bottom:var(--gap-md) !important}.frm-pb-sm{padding-bottom:var(--gap-sm) !important}.frm-pb-xs{padding-bottom:var(--gap-xs) !important}.frm-pb-2xs{padding-bottom:var(--gap-2xs) !important}.frm-pb-0{padding-bottom:0 !important}.frm-px-sm{padding-right:var(--gap-sm) !important;padding-left:var(--gap-sm) !important}.frm-px-xs{padding-right:var(--gap-xs) !important;padding-left:var(--gap-xs) !important}.frm-px-md{padding-right:var(--gap-md) !important;padding-left:var(--gap-md) !important}.frm-text-xs{font-size:var(--text-xs) !important}.frm-text-sm{font-size:var(--text-sm) !important}.frm-text-md{font-size:var(--text-md) !important}.frm-text-lg{font-size:var(--text-lg) !important}.frm-text-xl{font-size:var(--text-xl) !important}.frm-leading-none{line-height:1}.frm-italic{font-style:italic}.frm-no-italic{font-style:normal}.frm-capitalize{text-transform:capitalize}.frm-font-normal{font-weight:400 !important}.frm-font-medium{font-weight:500 !important}.frm-font-semibold{font-weight:600 !important}.frm-font-bold{font-weight:700 !important}.frm-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[class*=frm-line-clamp-]{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical}.frm-line-clamp-2{-webkit-line-clamp:2}.frm-white-space-nowrap{white-space:nowrap}.frm-rounded-6{border-radius:6px !important}.frm-rounded-sm{border-radius:var(--small-radius) !important}.frm-rounded-12{border-radius:12px !important}.frm-rounded-md{border-radius:var(--medium-radius) !important}.frm-w-auto{width:auto !important}.frm-w-full{width:100% !important}.frm-w-half{width:50% !important}.frm-w-fit{width:fit-content !important}.frm-max-w-fit{max-width:fit-content}.frm-h-auto{height:auto !important}#wpwrap .frm-force-hidden,.frm-force-hidden{display:none !important}.frm_block,.frm-block{display:block}.frm_inline{display:inline}.frm-force-inline{display:inline !important}.frm_inline_block{display:inline-block !important}.frm-inline-flex,#wpbody-content .frm-inline-flex{display:inline-flex}.frm-flex{display:flex}.frm-force-flex{display:flex !important}.frm_hidden,.js .frm-hide-js{display:none}.frm-flex-box{display:flex;gap:var(--gap-sm)}.frm-flex-col{display:flex;flex-direction:column}.frm-flex-full{flex:1}.frm-force-flex-center,.frm-flex-center{justify-content:center;align-items:center}.frm-flex-center{display:flex}.frm-force-flex-center{display:flex !important}.frm-shrink-0{flex-shrink:0}.frm-gap-0{gap:0 !important}.frm-gap-2xs{gap:var(--gap-2xs)}.frm-gap-xs{gap:var(--gap-xs)}.frm-gap-sm{gap:var(--gap-sm)}.frm-gap-md{gap:var(--gap-md)}.frm-gap-xl{gap:var(--gap-xl)}.frm-justify-start{justify-content:start !important}.frm-justify-center{justify-content:center !important}.frm-justify-between{justify-content:space-between}.frm-justify-end{justify-content:end}.frm-items-start{align-items:flex-start}.frm-items-center{align-items:center}.frm-items-stretch{align-items:stretch}.frm-self-normal{align-self:normal}#wpbody-content .frm-flex-wrap{flex-wrap:wrap}.frm-grow{flex-grow:1}.frm-order-first{order:-9999}.frm-order-last{order:9999}.frm-order-none{order:0}.frm-h-stack-sm,.frm-h-stack-xs,.frm-h-stack{display:flex !important;align-items:center}.frm-h-stack-sm>input[type=checkbox],.frm-h-stack-xs>input[type=checkbox],.frm-h-stack>input[type=checkbox],.frm-h-stack-sm>input[type=radio],.frm-h-stack-xs>input[type=radio],.frm-h-stack>input[type=radio]{margin:0 !important}.frm-h-stack{gap:var(--gap-2xs)}.frm-h-stack-xs{gap:var(--gap-xs)}.frm-h-stack-sm{gap:var(--gap-sm)}.frm-flex-row-reverse{flex-direction:row-reverse}.frm-transition-ease{transition:all .2s ease}.frm_invisible{visibility:hidden;transition:all .2s ease}.frm_disabled{opacity:.5;cursor:default;pointer-events:none}.frm_disabled .frm-show-inline-modal{pointer-events:none !important}.frm_no_float{float:none}.frm-text-right{text-align:right}.frm-text-left{text-align:left}.frm-border-b{border-bottom:1px solid var(--grey-300)}.frm-no-border{border:none !important}.frm-hr{display:block;height:1px;background-color:var(--grey-200);margin:var(--gap-xs) 0}.frm-opacity-100{opacity:1}.frm-on-bottom{z-index:-1}.frm-rotate-90{transform:rotate(90deg)}.frm-cursor-pointer{cursor:pointer}.frm-align-baseline{vertical-align:baseline !important}.frm-fields p>label.frm_hidden,#wpbody-content label.frm_hidden,.frm-lookup-modal .dismiss,.frm-right-panel .inside a.frm_hidden,#form_global_settings .frm_hidden,ul.frm_form_nav>li.frm_hidden,a.frm_hidden,.button.frm_hidden,.wp-core-ui .button.frm_hidden{display:none}.postbox .inside>p.frm_no_bottom_margin:last-child{margin-bottom:0 !important}.frm_no_section_fields.frm_block{display:block}.actions.frm_visible_overflow{overflow:visible !important}.frm_full_opacity,.frm_submit .frm_full_opacity,.frm_submit .frm-opacity-100{opacity:1}.frm-dropdown-menu.frm-on-top{z-index:99999}.frm-vertical-line{display:inline-block;width:1px;height:12px;background-color:var(--grey-300)}.frm-admin-full-screen #adminmenumain,.frm-admin-full-screen #wpadminbar,.frm-admin-full-screen #adminmenuback,.frm-admin-full-screen #adminmenuwrap,.frm-admin-full-screen #wpfooter{display:none}.frm-admin-full-screen #wpcontent,.frm-admin-full-screen.auto-fold #wpcontent{margin:0;padding:0}.frm-admin-full-screen.appearance_page_starter-templates #wpbody-content{padding:0}.frm_forms.with_frm_style{max-width:100%}.post-type-frm_display .wrap>.subsubsub,.post-type-frm_display .wrap>.icl_subsubsub,.frm_form_settings>p{margin:6px var(--gap-md);padding:0}.frm-entry-container{margin:0 40px 40px;padding:0}#form_reports_page .frm-inner-content{width:calc(100% - 40px);max-width:900px;margin:20px auto;padding:20px}.frm_inner_field_container>.frm_form_fields{clear:both}.post-type-frm_display h2,.frm_wrap h2{margin-top:0 !important;font-size:var(--text-lg);line-height:var(--leading)}.post-type-frm_display .wrap>h2:first-child,.frm_wrap .wrap>h2:first-child{padding-top:0;margin-top:0 !important;font-size:var(--text-lg)}#frm_form_editor_container{position:relative;margin-top:28px}.form-field p{background:none;border:none}.form-field label.frm_primary_label{display:block;float:none;width:auto}#frm_view_editor_left label,#frm_view_editor_left .frm_primary_label,.frm-dialog .frm-sub-label,.frm-dialog label,.dropdown .frm_primary_label,.accordion-container label,.frm-fields td>label,.frm-fields td>div>label,.frm_form_field>label:first-child,.frm-fields p>label,.frm_on_submit_type>label,.post-type-frm_display .frm_form_field>label,#new_fields .frm_primary_label,#form_global_settings .frm_primary_label,#frm_form_editor_container .frm_primary_label,#permissions_settings_settings .frm_primary_label{color:var(--grey-700);margin:0 0 6px;padding:0;width:auto;font-size:var(--text-sm);display:block;line-height:var(--leading)}#frm_form_editor_container #frm-show-fields .frm_primary_label{min-height:21px}.frm-fields td input+label{display:inline}#frm_form_editor_container .edit_field_type_end_divider .frm_primary_label,#frm_form_editor_container .edit_field_type_break .frm_primary_label{display:none}form .frm_primary_label input{font-size:12px}.with_frm_style form .form-field{margin-bottom:20px}#frm_builder_page .with_frm_style form .frm_combo_inputs_container>.form-field{margin-bottom:0}.frm_description,.with_frm_style form div.description,.frm_error,.with_frm_style form div.description textarea{padding:0;font-size:11px}.with_frm_style .description{color:inherit}#frm_form_editor_container .divider_section_only .frm_primary_label{display:flex;align-items:center;gap:var(--gap-xs);font-size:20px}#frm_form_editor_container .divider_section_only .frm_primary_label .frm-sub-label{padding:0}#frm-show-fields ul:has(>li:nth-child(7)) .frm-sub-label.frm-field-id{display:none}.frm-token-container{position:relative;display:block;direction:ltr}.frm-token-container .frm-tokens{position:absolute;top:0;left:0;max-width:calc(100% - var(--gap-xl));display:flex;align-items:center;flex-wrap:wrap;gap:var(--gap-2xs);padding:6px var(--gap-xs);margin:0}.frm-token-container .frm-token{position:relative;display:flex;align-items:center;gap:var(--gap-xs);min-height:24px;height:auto;color:var(--grey-900);background:var(--grey-100);border-radius:4px;padding:0 var(--gap-xs);font-size:var(--text-md);margin:0;z-index:2}.frm-token-container .frm-token .frm-token-value{line-height:var(--leading);white-space:normal;word-break:break-word}.frm-token-container .frm-token .frm-token-remove{display:flex;flex-shrink:0;cursor:pointer}.frm-token-container .frm-token .frm-token-remove .frmsvg{color:var(--grey-900);position:static;width:12px;height:12px;padding:0}.frm-token-container .frm-token .frm-token-remove:hover .frmsvg{color:var(--error-500)}.frm-token-container .frm-show-inline-modal{z-index:3 !important}.frm-token-container .frm-token-proxy-input{position:relative;z-index:1;padding-right:var(--gap-xl) !important}form .form-field.frm_field_loading{margin-bottom:0;min-height:0;padding:0;text-align:center}.frm_sorting>.frm_field_loading .frm_visible_spinner.frm-wait{margin-bottom:10px}.frm_sorting>.frm_field_loading~.frm_field_loading .frm_visible_spinner.frm-wait{margin-bottom:0;display:none}.frm_description,.with_frm_style form div.description,.frm_error{margin:0}.frm_error{color:#f04438}form .frm_blank_field input,form .frm_blank_field textarea,form .frm_blank_field select,form .frm_blank_field .frm-g-recaptcha iframe,form .frm_blank_field .g-recaptcha iframe{border-color:#f04438}form .frm_blank_field label{color:#f04438}.frm_required{color:#f04438}.with_frm_style .wp-editor-container textarea,.postbox .wp-editor-container textarea,.frm_remove_border{border:none}.with_frm_style .mceIframeContainer,.postbox .mceIframeContainer{background-color:#fff}.frm_pro_license_msg{clear:left;margin-top:10px}.frm-license-input{position:relative}.frm-license-input span{font-size:var(--text-sm)}.frm-license-input .frmsvg{width:20px;height:20px;margin-left:5px;vertical-align:text-top}.frm-license-input .frmsvg,.frm-license-input span,.frm-license-input i{color:#00831a}.upgrade_to_pro{padding:10px 25px 25px;max-width:700px;margin:20px auto !important}.upgrade_to_pro .error{display:none}.toplevel_page_formidable #wpbody-content>.error{margin:1px;padding:5px 12px}.frm_error_style,.frm_warning_style,.frm_note_style2,.frm_note_style,.frm_message,#post-body-content .frm_updated_message,div.frm_updated_message{border-radius:var(--small-radius);background-color:#d5f2dc;color:#1e561f;padding:var(--gap-sm) var(--gap-md);font-size:var(--text-sm);margin:var(--gap-sm) 0;text-align:left}.frm_note_style2{background:linear-gradient(90deg, #e9effa, #fcf6fe) padding-box,linear-gradient(90deg, #1961d5, #e8abef) border-box;border:1px solid rgba(0,0,0,0)}#frm_top_bar+.wrap>.frm_updated_message,#frm_top_bar+.wrap>.frm_warning_style{display:inline-block;width:100%;box-sizing:border-box}#post-body-content>.frm_updated_message{margin:5px 65px}#form_global_settings #post-body-content>.frm_updated_message,#form_global_settings #post-body-content>.frm_warning_style{margin:5px 25px}.frm_error_style{color:#973937;background-color:#ebcccc;clear:both}.frm_error_style a{text-decoration:underline;font-weight:600}.frm_error_style svg{opacity:.7}.frm_warning_style{color:#7a4d05;background-color:#fff2d2}.frm_warning_heading{font-weight:700;margin-bottom:4px}.frm_warning_style{position:relative;padding-right:calc(var(--gap-md) + 15px)}body.rtl .frm_warning_style{padding-right:var(--gap-md);padding-left:calc(var(--gap-md) + 15px)}.frm-warning-dismiss{position:absolute;top:10px;right:10px;display:flex;cursor:pointer;transition:opacity .2s ease-out}body.rtl .frm-warning-dismiss{left:10px;right:auto}.frm-warning-dismiss:hover{opacity:.8}.frm-warning-dismiss.frmsvg,.frm-warning-dismiss.frmsvg svg{width:15px;height:15px}.frm_note_style{background:rgba(188,224,253,.23);color:var(--grey-700)}.frm-banner-alert{text-align:left;margin:0;border-radius:0;padding:10px 0 10px 40px}.frm-banner-alert a{color:var(--primary-500);font-weight:400;text-decoration:none}.frm_updated_message ul,.frm_updated_message li,.frm_warning_style ul,.frm_warning_style li,.frm_error_style ul,.frm_error_style li{margin:0}.frm-inline-message{border:1px solid var(--primary-700);border-radius:var(--small-radius);color:var(--primary-700);background:#fff;text-align:center;padding:20px;font-size:var(--text-sm);line-height:var(--leading)}.frm-inline-message a{text-decoration:underline;font-weight:600;color:var(--primary-700)}.frm_pro_heading span{margin-top:10px}.frm_pro_heading .alignright{text-align:right}.frm-yes{color:var(--green);font-size:var(--text-xl)}.frm-nope{color:var(--grey-400);font-size:var(--text-xl)}.upgrade_to_pro a{color:var(--orange)}.upgrade_to_pro table .frmsvg{height:var(--text-xl);width:var(--text-xl)}.upgrade_to_pro table.widefat{background-color:#fff;border-collapse:collapse}.frm-white-body .upgrade_to_pro table th,.upgrade_to_pro table td{padding:10px 15px;border:1px solid var(--grey-300);line-height:var(--leading);font-size:var(--text-sm)}.upgrade_to_pro table th.frmcenter{text-align:center}.widefat th.frm_table_break{background-color:var(--sidebar-color)}h2.frm-h2+.howto{color:var(--medium-grey);max-width:850px;margin:5px 0 20px}.frm-card{width:100%;border-radius:10px;border:1px solid var(--grey-300);opacity:1;transition:opacity 1s}.frm-card-box{max-width:524px;background-color:#fff;border-radius:var(--medium-radius);padding:var(--gap-xl);border:1px solid var(--grey-200);box-shadow:var(--box-shadow-md)}.frm-card-box.frm-has-progress-bar{position:relative;overflow:hidden;border-radius:var(--medium-radius)}.frm-card-box-progress-bar{position:absolute;top:0;left:0;right:0;height:var(--gap-xs);background-color:var(--primary-25)}.frm-card-box-progress-bar>span{position:absolute;top:0;left:0;bottom:0;width:33%;background-color:var(--primary-500)}.frm-card-box-header{display:flex;justify-content:center;margin-bottom:var(--gap-sm)}.frm-card-box.frm-has-progress-bar .frm-card-box-header{margin-top:var(--gap-xs)}.frm-card-box-content>:last-child{margin-bottom:0}.frm-card-box-footer{display:flex;justify-content:end;gap:var(--gap-sm);margin-top:var(--gap-lg)}.frm-card-box-title{font-size:var(--text-xl) !important;font-weight:600 !important;margin-bottom:var(--gap-xs)}.frm-card-box-text{font-size:var(--text-md) !important;color:var(--grey-600) !important;margin-top:0 !important}.frm-fade{opacity:0;transition:all 1s}.frm-addons .frm-card.frm-addon-not-installed{position:relative}.frm-addons .plugin-card-top{min-height:155px;padding-top:var(--gap-lg);overflow:hidden}.frm-addons .plugin-card-top h2{margin-top:0;font-weight:400}.frm-template-row p,.frm-addons .plugin-card-top p{opacity:.8}.frm-addons .plugin-card-top>:not(p):not(h2){display:none}.frm-addons .plugin-card-bottom{padding:5px 20px 20px;text-align:center;background:rgba(0,0,0,0);border-top:none}.frm-addons .plugin-card-bottom,.frm-addons .plugin-card-bottom .button{font-size:15px}.frm-addons .button,.frm-addons .frm-button-tertiary{float:right}.frm-addons .addon-status{float:left;padding-top:4px}.frm-addon-not-installed .frm-activate-addon,.frm-addon-not-installed .frm-deactivate-addon,.frm-addon-not-installed .frm-uninstall-addon,.frm-addon-installed .frm-install-addon,.frm-addon-installed .frm-deactivate-addon,.frm-addon-active .frm-activate-addon,.frm-addon-active .frm-install-addon,.frm-addon-active .frm-uninstall-addon,.plugin-card-pro.frm-addon-active .button,.plugin-card-pro.frm-addon-active .frm-button-tertiary{display:none !important}.frm-save-and-reload-options{margin-top:10px;font-size:13px}.frm-save-and-reload,.frm-save-and-reload+.frm-button-secondary{visibility:visible !important}.addon-status-label{opacity:.7}.frm-addon-active .addon-status-label{color:var(--green);opacity:1}.frm-addon-error{position:absolute;top:55px;left:10px;right:10px;font-weight:700;text-align:center}.frm-new-template.plugin-card-bottom{overflow:visible}#frm-new-template p:first-child{margin-top:0}.frm-admin-page-formidableedit #wpbody-content>*:not(.frm-review-notice):not(.frm_previous_install):not(.frm-banner-alert):not(#frm-svg-icons-pack),#wpbody-content>.updated,#wpbody-content>#update-nag,#wpbody-content>.update-nag,#wpbody-content>.notice,#wpbody-content>.error:not(.frm_previous_install),.frm-white-body .updated,.frm-white-body .notice,.frm_wrap>.wrap>.notice,.frm-white-body .error:not(.frm_previous_install){display:none}.frm-admin-page-formidableedit #frm_builder_page{display:block !important}.frm-white-body .updated,.frm-white-body .error{margin:0;padding:10px 20px}.frm-modal:not(#frm-dismissable-cta) .postbox{max-height:600px;overflow:hidden;margin-bottom:0}.frm-modal .postbox .frm_modal_top,.frm-dialog .frm_common_modal .postbox>div:first-child,.frm-error-modal .frm_modal_top{padding:var(--gap-md) var(--gap-md) 0;position:relative}.frm-modal h2,.frm-modal .postbox .inside h2,.frm-modal .postbox .frm-modal-title,.frm-dialog .frm_common_modal .postbox>div:first-child>div:first-child,.frm-error-modal .frm-modal-title{display:inline-block;font-size:var(--text-lg);color:var(--grey-900);font-weight:600;margin:0;padding:0}.frm-modal h3{font-weight:500}.frm-inline-modal>a.dismiss,.frm-modal .postbox>a.dismiss,.frm-modal .postbox .frm-modal-title+div:last-child,.frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{position:absolute;top:19px;right:19px;display:flex;z-index:2}body.rtl .frm-inline-modal>a.dismiss,body.rtl .frm-modal .postbox>a.dismiss,body.rtl .frm-modal .postbox .frm-modal-title+div:last-child,body.rtl .frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{right:unset;left:30px}.frm-info-modal .postbox>a.dismiss,.frm-inline-modal>a.dismiss{right:13px;top:13px}.frm-modal .postbox .frm-modal-title+div:last-child a,.frm-modal a.dismiss .frmsvg,.frm_common_modal .frm_modal_top a .frmsvg{color:var(--grey-500)}.frm-modal .postbox .frm-modal-title+div:last-child a:hover,.frm-modal a.dismiss .frmsvg:hover,.frm_common_modal .frm_modal_top a .frmsvg:hover{color:var(--grey-700)}.frm-modal .frm_modal_content>div.inside,.frm_common_modal .frm_modal_content>div.inside{padding:var(--gap-md);margin:0;font-size:var(--text-sm);color:var(--grey-700)}.frm-modal p{color:var(--grey-900)}.frm_common_modal .postbox{display:flex;flex-direction:column}.frm-modal .postbox>div.inside .cta-inside{overflow-y:auto;height:auto}.frm_modal_footer{padding:0 var(--gap-md) var(--gap-sm);text-align:right}body.frm-body-with-open-modal{overflow-y:hidden}.frm-templates-list{margin-top:0}.frm-templates-list.frm_grid_container li{margin-bottom:0}.frm-templates-list li{vertical-align:top;position:relative;box-sizing:border-box;border-radius:6px;border:1px solid rgba(0,0,0,0);text-align:left}.frm-templates-list li:not(.frm_hidden){display:inline-block}.frm-templates-list.frm-categories-list li{width:100%}.frm-templates-list li.frm-selectable{cursor:pointer}.frm-templates-list li.frm-selectable:hover{background:var(--light-blue);border-color:rgba(65,153,253,.5)}.frm-templates-list li.frm-selectable:hover h3,.frm-templates-list li.frm-selectable:hover p{max-width:calc(100% - 65px)}.frm-templates-list .frm-featured-form{display:flex;width:100%}.frm-templates-list li .frm-featured-form{padding:7px 5px}.frm-templates-list li li>div{padding-left:0}.frm-templates-list li>div>div{vertical-align:middle}.frm-category-icon,.frm-icon-wrapper{background:var(--primary-500);border-radius:var(--small-radius);color:#fff;width:32px;height:32px;font-size:18px;box-sizing:border-box;align-self:center;justify-content:center;align-items:center;display:inline-flex}.frm-templates-list li .frm-category-icon{overflow:hidden}.frm-templates-list li h3,.frm-templates-list li p{text-align:left;margin:0;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.frm-templates-list li h3,.frm-templates-list .frm-install-template h3{font-size:var(--text-sm) !important}.frm-templates-list .frm-install-template div{text-align:left}#frm_leave_email,#frm_code_from_email{width:480px;max-width:100%}.frm-templates-list.frm-categories-list li>div>div:last-child{padding-left:0}.frm-hover-icons{position:absolute;right:0;top:17px;max-width:91px;height:100%;box-sizing:border-box;padding:0 10px 0 5px !important;border-radius:var(--small-radius);text-align:right;display:flex;gap:5px}.frm-ready-made-solution .frm-hover-icons{visibility:hidden}.frm-ready-made-solution:hover .frm-hover-icons{visibility:visible}.frm-hover-icons a{width:22px;height:22px;font-size:var(--text-md);display:inline-flex;align-items:center;justify-content:center;border-radius:50%;box-sizing:border-box;line-height:var(--leading);text-align:center}.frm-hover-icons>.frm-preview-form,.frm-hover-icons>.frm-delete-form{border:1px solid var(--primary-500)}.frm-hover-icons>.frm-create-form,.frm-ready-made-solution .frm-hover-icons a{background-color:var(--primary-500)}.frm-hover-icons>a .frmsvg{width:14px;height:14px;vertical-align:baseline}.frm-hover-icons>.frm-preview-form .frmsvg,.frm-hover-icons>.frm-delete-form .frmsvg{color:var(--primary-500)}.frm-hover-icons>.frm-unlock-form{background-color:var(--primary-500)}.frm-hover-icons>.frm-unlock-form .frmsvg{background-color:var(--primary-500)}.frm-ready-made-solution .frmsvg{width:14px;height:14px}.frm-hover-icons .frm-create-form svg,.frm-ready-made-solution .frm-hover-icons svg{color:#fff}.frm-hover-icons .frm-create-form:hover,.frm-ready-made-solution .frm-hover-icons a:hover,.frm-hover-icons>.frm-unlock-form:hover,.frm-hover-icons>.frm-unlock-form:hover .frmsvg{background-color:var(--primary-700) !important}.frm-hover-icons .frm-preview-form:hover,.frm-hover-icons .frm-delete-form:hover{border:1px solid var(--primary-700) !important}.frm-hover-icons .frm-preview-form:hover .frmsvg,.frm-hover-icons .frm-delete-form:hover .frmsvg{color:var(--primary-700) !important}.frm-application-card h4 .frmsvg,.frm-locked-template h3 .frmsvg{height:var(--text-sm);width:var(--text-sm);vertical-align:text-top;color:var(--grey-500)}.frm-modal-back{cursor:pointer;margin-right:4px}.frm-modal-cancel{float:left}.frm-meta-tag,.frm-meta-tag:hover{padding:var(--gap-2xs) var(--gap-xs);border-radius:var(--small-radius);font-weight:600;display:inline-flex;background-color:#d9ebff;gap:2px}.frm-meta-tag.frm-grey-tag,.frm-meta-tag.frm-grey-tag:hover{background-color:var(--sidebar-hover);color:var(--grey-900)}.frm-meta-tag.frm-red-tag,.frm-meta-tag.frm-red-tag:hover{background:var(--error-100);color:var(--error-700)}.frm-meta-tag.frm-orange-tag,.frm-meta-tag.frm-orange-tag:hover{background-color:#fef7f4;color:var(--orange)}.frm-meta-tag.frm-green-tag,.frm-meta-tag.frm-green-tag:hover{background-color:var(--success-500);color:#fff}.frm-entry-status-0,.frm-meta-tag.frm-lt-green-tag,.frm-meta-tag.frm-lt-green-tag:hover{background-color:var(--success-100);color:var(--success-800)}.frm-meta-tag.frm-new-pill{background-color:var(--success-500);vertical-align:text-bottom}.frm_add_field span+.frm-meta-tag{margin-left:0}.dropdown-item .frm-meta-tag{margin-left:0}.frm-entry-status{font-weight:500}.frm-entry-status-1{color:#7a4d05;background:#fff2d2}#frm-create-footer{padding:15px 20px}li .frm-hover-icons .frm-preview-form,.frm-hover-icons .frm-unlock-form,.frm-locked-template .frm-hover-icons .frm-create-form,.frm-modal-back{display:none}.frm-locked-template .frm-hover-icons .frm-unlock-form,li[data-preview] .frm-hover-icons .frm-preview-form{display:inline-flex}.frm-modal-back svg{color:#7f7f7f}#frm-upgrade-body-list-wrapper>div{display:inline-block;width:33.3333333333%;vertical-align:top;text-align:left;margin-bottom:10px}#frm-upgrade-body-list-wrapper ul{padding-left:40px}#frm-upgrade-body-list-wrapper ul li::before{content:"\2022";color:var(--primary-500);display:inline-block;width:1em;margin-left:-1em}.frm-embed-modal-content{padding:var(--gap-md)}.frm-embed-modal-content.frm-loading-page-options{display:flex;justify-content:center}#frm_embed_modal .frm_embed_example{background:var(--sidebar-color);border:1px solid var(--sidebar-hover);border-radius:var(--small-radius);color:var(--grey-900);font-size:var(--text-sm);padding-right:var(--gap-lg);width:100%;height:auto !important;resize:none}#frm_embed_modal textarea.frm_embed_example{padding-bottom:0}.frm-embed-modal-content>div a{position:absolute;right:0;top:0}.frm-embed-modal-content>div{position:relative;margin-bottom:var(--gap-sm)}.frm-embed-modal-content>div:last-child{margin-bottom:0}.frm-embed-modal-content svg[id^=frm_copy_embed_]{position:absolute;bottom:10px;right:10px;cursor:pointer;opacity:.5}.frm-border-info-box,.frm-embed-modal-option{border-radius:var(--small-radius);border:1px solid var(--grey-300);padding:var(--gap-sm);cursor:pointer;display:flex;gap:var(--gap-sm);font-size:var(--text-sm)}.frm-embed-modal-option+.frm-embed-modal-option{margin-top:var(--gap-sm)}.caret.rotate-270,.frm-embed-modal-option .caret{align-self:center;margin-left:auto;transform:rotate(-90deg)}#frm_embed_modal .frm_modal_footer{display:none}#frm_embed_modal.frm-on-page-2 .frm_modal_footer{display:block}.frm-embed-modal-content ul{max-height:300px;overflow-y:scroll}.frm-embed-modal-wrapper.frm-dialog{overflow:visible}#frm-bulk-modal .frm_grid_container{grid-template-columns:repeat(12, 8.33%);grid-gap:0}#frm-bulk-modal .frm8{border-right:1px solid var(--grey-300);padding:10px 20px 10px var(--gap-lg)}#frm-bulk-modal .frm4{padding:10px 0}.frm-inline-modal .howto{margin:5px 0 10px;color:var(--grey)}.frm-inline-modal .frm_code_list+.howto{margin-bottom:0}#frm_bulk_options{height:240px;width:100%;border:none;box-shadow:none;padding:0}.frm-bulk-edit-link{display:flex;align-items:center;justify-content:flex-end;gap:var(--gap-2xs);font-size:var(--text-sm);margin:12px 0 12px auto}.frm-bulk-edit-link .frm-bulk-edit-link{margin:0}.frm-small-add{font-size:var(--text-sm) !important}.frm-small-add span{color:var(--primary-500);font-size:12px;height:12px;width:12px}.frm_no_captcha_text{font-weight:700;color:#a00}.frm_image_from_url{height:50px}h1 .fa-caret-down{font-size:18px}.caret{display:inline-block;width:19px;height:9px;margin-right:-8px;vertical-align:middle}.caret,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,.frm_wrap .ui-autocomplete-input{background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;padding-right:var(--gap-lg) !important}.caret{padding-right:var(--gap-xs) !important;background-position-x:5px}.frm-btn-group .caret{float:right;margin-top:calc(var(--text-md)/2)}.dropdown{position:relative}.dropdown-toggle:focus{outline:0}.frm_wrap .ui-autocomplete,#frm_adv_info.frm-dropdown-menu,.frm-dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;padding-left:4px;padding-right:4px;margin:var(--gap-xs) 0 0;text-align:left;list-style:none;background:none;background-color:#fff;background-clip:padding-box;border:1px solid var(--grey-100);border-radius:.25rem;box-shadow:var(--box-shadow-lg);max-height:200px;overflow-y:auto;overflow-x:hidden;font-size:var(--text-md);width:auto;min-width:160px}.frm6 .frm-dropdown-menu{min-width:100px;max-width:99%}#frm_bs_dropdown .frm-dropdown-menu{max-width:400px}.field_type_list .frm-dropdown-menu{min-width:150px !important}#frm_field_group_controls .frm-dropdown-menu,.frm-field-action-icons .frm-dropdown-menu{min-width:180px !important}.frm-field-action-icons .frm-dropdown-toggle svg,#frm_field_group_controls .frm-dropdown-toggle svg{color:#9ea9b8}.multiselect-container.frm-dropdown-menu,#search-submit .frm-dropdown-menu{min-width:200px !important}.preview .frm-dropdown-menu{min-width:230px !important}.frm-dropdown-menu.dropdown-menu-right{right:0;left:auto}.frm-dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.frm-dropdown-menu>.dropdown-item{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu .frm_dropdown_li{clear:both;font-weight:400;white-space:nowrap;text-decoration:none;border-radius:var(--small-radius)}.frm-dropdown-menu>.active>a,.frm-dropdown-menu>.active>a:hover,.frm-dropdown-menu>.active>a:focus{text-decoration:none;outline:0}.frm-select-list-item.disabled,.frm-dropdown-menu>.disabled>a,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{color:#999}.frm-select-list-item.disabled:hover,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{text-decoration:none;background-color:rgba(0,0,0,0);background-image:none;cursor:not-allowed}.open>.frm-dropdown-menu{display:block}.open>a{outline:0}.dropdown-header{display:block;padding:3px 10px;font-size:var(--text-xs);color:var(--grey-400)}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.dropdown-menu-right>.frm-dropdown-menu,.pull-right>.frm-dropdown-menu{right:0;left:auto}.navbar-fixed-bottom .dropdown .caret{border-top:0 dotted;border-bottom:4px solid #000;content:""}.navbar-fixed-bottom .dropdown .frm-dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.btn{border:1px solid #ddd;background:#fff;height:28px;line-height:var(--leading)}a.frm_option_icon::before{color:var(--primary-500);font-size:22px;width:22px;height:22px}a.frm_option_icon:focus::before,a.frm_option_icon:hover::before{color:var(--primary-700)}.frm_top_left .frm-dropdown-toggle{color:#999}.frm-card ol{margin-left:15px}.frm-dropdown-toggle{text-decoration:none}.frm-card .frm-dropdown-toggle{border:1px solid var(--grey-300);border-radius:var(--small-radius);font-size:13px;color:var(--grey-700);padding:7px 20px}.frm-dropdown-menu .frm_icon_font{vertical-align:middle;color:#5f6c72;margin-right:3px}.multiselect-container.frm-dropdown-menu{top:auto;left:auto;font-size:var(--text-sm);padding:4px;margin-bottom:3px}#post-body-content+.frm-right-panel h3.accordion-section-title{padding:7px 10px 8px 14px;font-size:var(--text-md);color:var(--grey-700)}.frm-with-line,.accordion-section-content h4{font-size:var(--text-md);font-weight:400;margin:20px -20px 10px;padding:0 20px;color:var(--grey-700);position:relative;border:none !important}.frm-with-line span,.accordion-section-content h4 span{background:#fff;padding:0 var(--gap-xs);position:relative;display:inline-block;z-index:2}.accordion-section-content h4 span{background:var(--sidebar-color)}.frm-right-panel .frm-with-line span{background:var(--sidebar-color) !important;margin-left:-4px}.frm-right-panel .frm-inline-modal .frm-with-line span{background:#fff !important}.frm-with-line::before,.accordion-section-content h4::before{content:"";display:block;position:absolute;border-bottom:1px solid var(--grey-300);left:0;width:100%;top:50%}.control-section .accordion-section-title::after,.customize-pane-child .accordion-section-title::after{top:15px}.accordion-container .frm-dropdown-menu{min-width:40px}.frm-btn-group .multiselect.dropdown-toggle{box-sizing:border-box;min-height:unset;cursor:pointer}.accordion-container .frm-dropdown-menu::before,.accordion-container .multiselect.dropdown-toggle::before{font-family:"s11-fp" !important}.multiselect-container{position:absolute;list-style-type:none;margin:0;padding:0;width:100%;max-width:250px}.multiselect-container button.multiselect-option{width:100%;text-align:left;border:none;margin-bottom:4px}.multiselect-container button.multiselect-option label{margin-left:5px}.accordion-container .multiselect-container label{padding:3px 19px 3px 7px}.frm-btn-group.btn-group>.btn-group:nth-child(2)>.multiselect.btn{border-top-left-radius:4px;border-bottom-left-radius:4px}.frm-btn-group.btn-group,.frm-btn-group.btn-group-vertical{display:block}.multiselect-option label{max-width:calc(100% - 22px);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.frm_scale{text-align:center;float:left;margin-right:10px}.frm_scale input{display:block;margin:5px}.frm_multi_fields_container{float:left}.frm_multi_fields_container,.frm_form_builder .frm_form_fields input[type=tel] .frm_form_builder .frm_form_fields input[type=range],.frm_form_builder .frm_form_fields input[type=text]{width:100%;height:auto}.frm_form_builder .frm_time_wrap .frm_time_sep{vertical-align:sub;vertical-align:-webkit-baseline-middle}.frm_form_builder input[type=range]::-webkit-slider-runnable-track{background-color:var(--blue-border)}.frm_form_builder input[type=range]::-moz-range-track{background-color:var(--blue-border)}.frm_form_builder input[type=range]::-ms-fill-lower{background-color:var(--blue-border)}.frm_form_builder input[type=range]::-ms-fill-upper{background-color:var(--blue-border)}.frm-embed-field-placeholder{text-align:center;height:145px;display:flex;align-items:center;justify-content:center}.frm-fake-field{display:block;height:25px;background-color:var(--light-blue);border:1px solid var(--grey-300);margin:10px 0;border-radius:var(--small-radius)}.frm-embed-message{position:absolute;background:#fff;border:1px solid var(--grey-300);color:var(--grey-700);padding:var(--gap-md);font-size:var(--text-lg);max-width:200px;min-width:50%;margin:0 var(--gap-md);overflow:hidden;text-overflow:ellipsis}.frm-summary-message{top:50%;left:50%;padding:15px 0;font-size:var(--text-md);transform:translate(-50%, -50%)}.frm-summary-learn-more{font-size:inherit !important}.frm-single-settings .frm-embed-message{width:100%;position:static;border-radius:var(--small-radius)}#new_fields input[type=text],#new_fields input[type=number],.frm_field_box .frm_form_fields>textarea,.frm_form_fields .frm_form_field>textarea,.frm_form_fields .frm_form_field>input[type=email],.frm_form_fields .frm_form_field>input[type=url],.frm_form_fields .frm_form_field>input[type=number],.frm_form_fields .frm_form_field>input[type=tel],.frm_form_fields .frm_form_field>input[type=text],.frm_form_fields .frm_form_field>input[type=range]{width:100%}.frm_form_fields textarea.wp-editor-area{width:100%;border:none}.frm_form_fields input[type=file],.frm_form_fields input[type=file]:disabled{background:rgba(0,0,0,0);border:none;box-shadow:none;width:auto}.frm_form_fields select{width:auto;max-width:100%}input[type=radio],input[type=checkbox]{width:16px;padding:0}.frm_grid_container>p,.frm_grid_container>p.frm_form_field,.frm_grid_container>div.frm_form_field,#new_fields .frm_grid_container>p{margin-top:8px;margin-bottom:8px;margin-right:0}.frm_grid_container>p>label:only-child,.frm_grid_container>p.frm_form_field>label:only-child,.frm_grid_container>div.frm_form_field>label:only-child,#new_fields .frm_grid_container>p>label:only-child{margin-bottom:0}.frm_grid_container>.frm-has-modal>p:only-child{margin-bottom:var(--gap-xs)}#new_fields div.frm_grid_container>.frm_primary_label{margin-top:8px}#new_fields .frm_primary_label+p,#new_fields .frm_primary_label+.frm6+.frm6,#new_fields .frm_primary_label+.frm6+.frm-inline-modal+.frm6{margin-top:0}.frm_catlevel_2,.frm_catlevel_3,.frm_catlevel_4,.frm_catlevel_5{margin-left:18px}.frm_wrap .frm-fields .auto_width,.frm_form_fields input.auto_width,.frm_form_fields select.auto_width,.frm_form_fields textarea.auto_width{width:auto !important}.frm_form_fields select.auto_width{min-width:60px}.frm_form_fields input:focus,.frm_form_fields select:focus,.frm_form_fields textarea:focus,.frm_focus_field input{background-color:#fff;border-color:#ddd}.frm_form_builder .frm_radio,.frm_form_builder .frm_checkbox{display:block;margin-bottom:2px}.frm_form_builder .frm_radio label,.frm_form_builder .frm_checkbox label{font-size:var(--text-sm)}.horizontal_radio .frm_radio,.horizontal_radio .frm_checkbox{margin-right:5px;display:inline-block}.frm_form_builder .frm_opt_container .frm_radio.frm_image_option label,.frm_form_builder .frm_opt_container .frm_checkbox.frm_image_option label{display:flex;align-items:center;gap:9px;white-space:normal}.frm_form_field.frm_two_col .frm_opt_container,.frm_form_field.frm_three_col .frm_opt_container,.frm_form_field.frm_four_col .frm_opt_container{display:grid;grid-template-columns:repeat(2, 1fr);grid-auto-rows:max-content;grid-gap:0 2.5%}.frm_form_field.frm_three_col .frm_opt_container{grid-template-columns:repeat(3, 1fr)}.frm_form_field.frm_four_col .frm_opt_container{grid-template-columns:repeat(4, 1fr)}.frm_form_field.frm_two_col .frm_radio,.frm_form_field.frm_two_col .frm_checkbox,.frm_form_field.frm_three_col .frm_radio,.frm_form_field.frm_three_col .frm_checkbox,.frm_form_field.frm_four_col .frm_radio,.frm_form_field.frm_four_col .frm_checkbox{grid-column-end:span 1}.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox],.frm_wrap .with_frm_style .frm_radio input[type=radio],.frm_wrap input[type=checkbox],.frm-white-body input[type=checkbox],.field-group input[type=checkbox],.frm_scale input[type=radio],.frm_radio input[type=radio],.frm_checkbox input[type=checkbox]{width:15px;min-width:15px;height:15px;border:1px solid var(--grey-300);box-shadow:var(--box-shadow-sm);-webkit-appearance:none}.frm_wrap input[type=radio]{border-color:var(--grey-300);box-shadow:var(--box-shadow-sm)}.frm_wrap input[type=radio]:checked::before{background-color:var(--primary-500)}.frm_wrap .with_frm_style .frm_checkbox input[type=checkbox],.frm_wrap input[type=checkbox],.frm-white-body input[type=checkbox],.field-group input[type=checkbox],.frm_checkbox input[type=checkbox]{border-radius:4px}.frm-white-body input[type=checkbox]:checked,.frm_wrap input[type=checkbox]:checked{background-color:var(--border-color-active, var(--primary-500)) !important;border-color:var(--border-color-active, var(--primary-500)) !important}.frm-white-body input[type=checkbox]:checked:focus,.frm_wrap input[type=checkbox]:checked:focus{border-color:var(--border-color-active, var(--primary-500))}.frm-white-body input[type=checkbox]:checked::before,.frm_wrap input[type=checkbox]:checked::before{content:"";display:block;width:100% !important;height:100% !important;background-image:url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.6667 1.5L4.25001 7.91667L1.33334 5' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A") !important;background-size:8px !important;background-repeat:no-repeat !important;background-position:center !important;margin:0}.frm_radio input[type=radio],.frm_checkbox input[type=checkbox]{margin-right:5px}.frm_inner_field_container{margin-bottom:10px}.frm_conf_inline .frm_inner_field_container,.frm_conf_inline .frm_inner_conf_container{width:49%;float:left}.frm_conf_inline .frm_inner_field_container{margin-right:2%;clear:both}.frm_inner_field_container>label{text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.frm_field_box:not(.edit_field_type_divider):hover>.frm_inner_field_container>label,.frm_field_box .divider_section_only:hover>.frm_inner_field_container>label,li.ui-state-default.selected>.frm_inner_field_container>label{max-width:calc(100% - 100px)}.frm-drag-fade{background-color:var(--lightest-grey) !important;border-radius:4px}.frm-drag-fade *{opacity:0}.frm-dragging .divider_section_only,.frm-dragging .frm_field_box{pointer-events:none}.frm_form_settings #op-popup,.frm_form_settings com-1password-op-button,.frm_conf_below .frm_conf_field_container .frm_primary_label,.frm_conf_inline .frm_inner_field_container .frm-show-click a,.frm_conf_below .frm_conf_field_container .frm-show-click a{display:none !important}.frm_conf_inline .frm_inner_field_container .frm-field-action-icons{position:absolute;right:5px}.frm_conf_below .frm_conf_field_container{margin-top:10px}.frm_calc_dec{width:50px}.frm_ext_sc{display:none}.frm_long_input{width:100% !important;box-sizing:border-box}.frmcenter{text-align:center}img.frm_help{margin-left:2px;vertical-align:middle;padding-bottom:2px}.frm_spinner.frm-wait,.frm_spinner.spinner{float:left;visibility:hidden;margin:0 10px}.frm_visible_spinner.frm-wait,.frm_visible_spinner.spinner{visibility:visible;float:none}.frm_form_action_settings .frm_spinner.frm-wait,.frm_form_action_settings .frm_spinner.spinner{visibility:visible;float:none;vertical-align:bottom}.frm_form_action_settings .frm_loading{font-size:15px;text-align:center}.frm_ajax_settings_tab .frm-wait,.frm_ajax_settings_tab .spinner{visibility:visible;float:none;margin-top:20px}.wp-core-ui .frm_loading_button.button-primary.frm-button-primary,.frm_loading_button,.frm_loading_form.frm_button_submit{position:relative !important;opacity:.8;color:rgba(0,0,0,0) !important;text-shadow:none !important}.frm_loading_button:hover,.frm_loading_button:active,.frm_loading_button:focus,.frm_loading_form.frm_button_submit:hover,.frm_loading_form.frm_button_submit:active,.frm_loading_form.frm_button_submit:focus{cursor:not-allowed;color:rgba(0,0,0,0) !important;outline:none !important;box-shadow:none}.frm-wait{margin:20px;width:20px;height:20px;position:relative;display:inline-block}#frm-show-fields .frm-wait:only-child{position:absolute;left:50px;top:30px}.frm-wait::before,.frm_loading_button::before,.frm_loading_form.frm_button_submit::before{content:"";display:inline-block;position:absolute;background:rgba(0,0,0,0);border:1px solid #fff;border-top-color:rgba(0,0,0,0);border-left-color:rgba(0,0,0,0);border-radius:50%;box-sizing:border-box;top:50%;left:50%;margin-top:-10px;margin-left:-10px;width:20px;height:20px;animation:spin 2s linear infinite}.frm-wait::before{border-bottom-color:var(--primary-700);border-right-color:var(--primary-700)}.frm_loading_button.frm-button-secondary::before{border-bottom-color:var(--primary-500);border-right-color:var(--primary-500)}input[type=submit]:focus{outline:none !important}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}label input[type=checkbox],label input[type=radio]{vertical-align:inherit}#editorcontainer #dyncontent{margin:0;width:100%;padding:6px;line-height:var(--leading);border:0 none;outline:none;box-sizing:border-box}.frm_postbox_icon{margin:-6px 0 0 -10px}.frm_form_builder a:hover{text-decoration:underline}.frm_form_builder .widget-title h4{padding:10px 15px}.frm_form_builder .widget-top a.widget-action::after{margin:7px 12px 0}.frmbutton.frm_tgateway{display:none !important}.frm_html_legend pre{display:inline}#ed_fullscreen{display:none !important}.frm_posttax_opt_list{overflow:auto;max-height:200px;background-color:#fff}.frm_posttax_opt_list p.howto{font-size:12px}.frm_border_bottom{border-bottom:1px solid var(--grey-300);margin-bottom:10px;padding-bottom:10px}.frm_posttax_opt_list .frm_border_bottom span.howto{padding-right:10px}.frm_posttax_opt_list .frm_border_bottom input{margin-right:1px}.frm_add_remove div.frm_form_field{padding-bottom:5px}.frm_field_opts_list{max-height:260px;overflow:auto}.frm_white_bg,.frm-bg-white{background-color:#fff}.frm-bg-grey-50{background-color:var(--grey-50)}.frm-bg-grey-200{background-color:var(--grey-200)}.frm-bg-grey-800{background-color:var(--grey-800)}.frm-bg-primary-500{background-color:var(--primary-500)}.frm_border_light{border:solid 1px #ddd}#new_fields .form-table input[type=text],#new_fields .form-table select,.form-table .form-field input,.form-table .form-field .quicktags-toolbar input,.form-field input,.form-field .quicktags-toolbar input{width:auto}.frm_aff_link{float:right}.frm_select_box{text-align:center;font-weight:700;width:100%;background-color:rgba(0,0,0,0) !important}.wp-list-table input.frm_select_box{text-align:left;font-weight:400;font-size:inherit !important;border:none;padding:0 !important;background-color:rgba(0,0,0,0) !important}.wp-list-table input.frm_select_box:focus{outline:none;box-shadow:none}.wp-list-table .frm_no_items.frm_select_box{text-align:center;font-weight:700;width:500px;max-width:100%;font-size:inherit}#frm-options-panel{padding:0 var(--gap-sm);color:var(--grey-900);overflow:hidden}.frm-right-panel a.frm_add_logic_link,#frm-options-panel h3,.frm-collapsible{font-size:var(--text-md);font-weight:500;background-color:#fff;border-radius:var(--small-radius);padding:18px var(--gap-sm);margin:2px calc(-1*var(--gap-sm));transition:background-color 200ms ease-out,box-shadow 200ms ease-out,color 200ms ease-out}.frm-right-panel a.frm_add_logic_link .frmsvg,#frm-options-panel h3 .frmsvg,.frm-collapsible .frmsvg{width:13px;height:13px;color:var(--grey-500);transition:transform 300ms ease-in}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type),.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child,#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type),#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child,.frm-collapsible:not(.frm-collapsed):not(:first-of-type),.frm-collapsible:not(.frm-collapsed):first-of-type:first-child{color:var(--grey-700);box-shadow:var(--box-shadow-sm)}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):not(:first-of-type) .frmsvg,.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed):first-of-type:first-child .frmsvg,#frm-options-panel h3:not(.frm-collapsed):not(:first-of-type) .frmsvg,#frm-options-panel h3:not(.frm-collapsed):first-of-type:first-child .frmsvg,.frm-collapsible:not(.frm-collapsed):not(:first-of-type) .frmsvg,.frm-collapsible:not(.frm-collapsed):first-of-type:first-child .frmsvg{transform:rotate(-180deg)}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div,#frm-options-panel h3:not(.frm-collapsed)+div,.frm-collapsible:not(.frm-collapsed)+div{padding-top:6px;padding-bottom:6px}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div.frm_grid_container,#frm-options-panel h3:not(.frm-collapsed)+div.frm_grid_container,.frm-collapsible:not(.frm-collapsed)+div.frm_grid_container{padding-bottom:14px}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div.frm_grid_container>p:first-child,#frm-options-panel h3:not(.frm-collapsed)+div.frm_grid_container>p:first-child,.frm-collapsible:not(.frm-collapsed)+div.frm_grid_container>p:first-child{margin-top:var(--gap-sm)}.frm-right-panel a.frm_add_logic_link:not(.frm-collapsed)+div.frm_grid_container>p:first-child.frm6+.frm6,#frm-options-panel h3:not(.frm-collapsed)+div.frm_grid_container>p:first-child.frm6+.frm6,.frm-collapsible:not(.frm-collapsed)+div.frm_grid_container>p:first-child.frm6+.frm6{margin-top:var(--gap-sm)}.frm-right-panel a.frm_add_logic_link.frm-collapsed,#frm-options-panel h3.frm-collapsed,.frm-collapsible.frm-collapsed{color:var(--grey-500);background-color:rgba(0,0,0,0)}.frm-right-panel a.frm_add_logic_link:hover,#frm-options-panel h3:hover,.frm-collapsible:hover{color:var(--grey-700);background-color:#fff;box-shadow:var(--box-shadow-sm)}.frm-right-panel a.frm_add_logic_link:focus-visible,#frm-options-panel h3:focus-visible,.frm-collapsible:focus-visible{outline:1px solid var(--primary-500) !important;outline-offset:-1px}h4.frm-collapsible:hover{box-shadow:none}.frm-right-panel a.frm_add_logic_link:focus{outline:auto}.frm_field_key{background-color:#f7f7f7}#frm_form_editor_container #edit-slug-box{padding:0}.frm-alt-table{position:relative;width:100%;border-collapse:collapse;margin-top:.5em;font-size:15px}#form_show_entry_page .frm-alt-table:not(.frm-zebra-striping)::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-color:#fff}.frm-alt-table th{width:200px}.frm-alt-table tr,.frm-alt-table tr.frm-odd{background-color:rgba(0,0,0,0)}.frm-alt-table tr.frm-even{background-color:var(--sidebar-color)}.frm-alt-table th,.frm-alt-table td{background-color:rgba(0,0,0,0);vertical-align:top;text-align:left;padding:20px}.frm-alt-table h3{margin-bottom:0}.form-field .frm_cb_button{height:22px;line-height:20px;margin-bottom:10px;margin-right:5px}.edit_field_type_select .frm_option_val_label{margin-left:12px}.frm_rte{background:url(../images/rte.png) no-repeat}.frm_rte .howto{margin:10px 0 46px}.subform_section{margin:25px}.subform_section,.subform_section label,.subform_section input{opacity:80}.subform_section .frm_sortable_field_opts{display:none}#frm_form_editor_container .subform_section .frm_primary_label{display:block}.subform_section.subform_break{border-top:1px dashed #ccc}.button-secondary.frm_html_field{background-color:#ededed;padding:10px 20px;line-height:inherit;width:auto;height:auto !important;border-radius:0;box-sizing:content-box}.frm_html_field_placeholder{margin-bottom:10px;text-align:center}.recaptcha_placeholder{border:1px solid #d3d3d3;width:300px}.turnstile_placeholder{width:300px}.frm_sorting .frm_rte textarea{width:653px;background:#fff;margin:1px 0 0;border:1px solid #dfdfdf;border-top:none;border-radius:0;float:none !important}.frm_full_rte textarea{width:98%;padding:0}.frm_field_box{padding:5px;min-height:20px;margin:10px 0}.frm_indent_opt,td.frm_indent_opt{padding-left:25px}.frm_charts object{background:rgba(0,0,0,0)}.frm_charts h2{height:34px}.frm_single_option.ui-sortable-placeholder,li.sortable-placeholder{border:none;margin:0;visibility:visible !important;box-shadow:2px -10px 0 2px var(--primary-500)}#frm_form_editor_container>ul>.frm_single_option.ui-sortable-placeholder,#frm_form_editor_container>ul>li.sortable-placeholder{width:calc(100% - 5px) !important;height:0 !important}#frm_form_editor_container>ul>li>ul{position:relative}#frm_form_editor_container>ul>li>ul>li.sortable-placeholder,#frm_form_editor_container ul.start_divider>li>ul>li.sortable-placeholder{position:absolute;top:20px;bottom:0}.edit_field_type_divider+li.sortable-placeholder{box-shadow:2px 5px 0 2px var(--primary-500)}.start_divider li.sortable-placeholder{box-shadow:2px -5px 0 2px var(--primary-500)}.frm-is-collapsed+.sortable-placeholder{box-shadow:2px 15px 0 2px var(--primary-500)}.frm_single_option.ui-sortable-placeholder{box-shadow:0 0 1px 1px var(--primary-500)}.frm_sorting>li.edit_field_type_end_divider:first-child,.frm-show-click,li.ui-state-default.edit_field_type_divider .frm-show-click{display:none}.frm_form_field.ui-sortable-helper .frm-field-action-icons,.frm_form_field.ui-sortable-helper .frm_form_fields,.frm_form_field.ui-sortable-helper .frm_description,.frm_form_field.ui-sortable-helper .description{display:none}.frm_form_field.ui-sortable-helper .frm_primary_label,.frm_form_field.ui-sortable-helper .frm_inner_field_container{margin:0 !important}.frm-single-settings .frm-show-click{display:block !important}.frm-show-hover,.frm_single_visible_hover,li.ui-state-default.edit_field_type_divider .frm-show-hover{opacity:0;transition:opacity .15s ease-in-out}#frm-show-fields .frm-field-settings-open .frm-show-hover{opacity:1}.frm_sortable_field_opts{margin-top:5px}.frm_single_option{clear:both;margin:0 !important;padding-bottom:5px}.frm_single_option input[type=radio],.frm_single_option input[type=checkbox]{margin-top:0}.frm_single_option .frm-with-right-icon input[type=text]+.frmsvg{position:relative;right:27px;width:14px;height:14px;padding:0;margin:var(--gap-2xs) 0 0}.frm_product_price_wrapper,.frm_image_preview_wrapper,#new_fields .frm_single_option select,#new_fields .frm_single_option input[type=text]{width:calc(100% - 106px) !important;flex-grow:1}.frm-right-panel .frm_single_option a.frm_remove_tag,.frm_single_option a{padding-left:7px}.frm_single_option:hover .frm_single_visible_hover{opacity:100}.frm_single_option .frm-drag{font-size:23px;width:24px;height:24px;margin-left:-6px;margin-right:var(--gap-xs);color:var(--grey-500)}.frm_single_option .frm-drag::before{vertical-align:middle}.frm-drag,.frm_single_option.ui-sortable-helper{cursor:move}.frm_single_option .frm_option_key.frm_image_preview_wrapper,.frm-type-ranking .frm_single_option .frm_option_key{margin-left:21px !important}.frm_option_key input[type=text]{margin-top:var(--gap-xs) !important;margin-left:11px !important}.frm_option_key input[type=checkbox]+input[type=text],.frm_option_key input[type=radio]+input[type=text]{margin-left:30px !important}.frm-type-ranking .frm_option_key input[id*=field_key_]{margin-left:30px !important}li.ui-state-default.selected .frm-show-click,li.ui-state-default.selected.edit_field_type_divider .frm-show-click{display:inline;vertical-align:top}.frm_field_box:not(.edit_field_type_divider):hover>.frm_inner_field_container>.frm-show-hover,.frm_field_box .divider_section_only:hover>.frm_inner_field_container>.frm-show-hover,li.ui-state-default.selected>.frm_inner_field_container>.frm-show-hover,li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover{opacity:100}li.frm_field_box>ul.frm_grid_container{position:relative}.frm_sorting span.ui-icon{width:16px}body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) .frm_image_options .frm_image_option_container{--field-border-width: 1px;--border-color: var(--grey-300);--border-color-active: var(--primary-500);--border-radius: var(--small-radius)}#form_show_entry_page .frm_file_link,#form_show_entry_page .frm_image_option_container{display:inline-flex;flex-wrap:nowrap;flex-direction:column;text-align:center;align-items:center;width:150px;margin-right:10px;margin-bottom:10px}#form_show_entry_page .frm_image_option_container img{width:150px;height:150px;object-fit:cover}#form_show_entry_page .frm_file_link img{max-width:150px;height:auto}#form_show_entry_page .frm_file_link~br{display:none}#form_show_entry_page .frm_upload_label{padding:10px}#form_show_entry_page.frm_wrap .postbox{overflow:hidden}.frm_image_option_container .frm_image_placeholder_icon svg{height:150px}.frm_list_entry_page .frm_file_link,.frm_list_entry_page .frm_image_option_container.frm_label_with_image{display:block;text-align:center}.frm_list_entry_page .frm_image_option_container img{width:75px;height:75px;object-fit:cover}.frm_list_entry_page img{max-width:100%;height:auto}.frm_image_option_container .frm_empty_url{background-color:var(--sidebar-color)}.frm_list_entry_page .frm_image_option_container .frm_text_label_for_image{display:block;padding:5px 0 10px}.frm_list_entry_page .frm_upload_label,.frm-summary-page-wrapper .frm_text_label_for_image{display:block}#frm-welcome .frm_image_options .frm_image_option_container,#form_global_settings .frm_image_options .frm_image_option_container{background:var(--sidebar-color)}#frm-welcome .frm_image_option_container svg,#form_global_settings .frm_image_option_container svg{max-width:calc(100% - 20px)}#frm-new-template .frm_image_option_container svg{height:50px;margin:10px auto 0}.frm_image_option_container{position:relative}.frm_text_label_for_image>svg{width:30px;position:absolute;top:5px;right:calc(50% - 15px)}.frm_single_option .frm_option_key{margin-top:17px}.frm_single_option .frm_option_key.frm_image_preview_wrapper{margin-top:var(--gap-xs)}.frm_image_data{margin-left:var(--gap-sm);display:flex;flex-direction:column;font-size:var(--text-sm);justify-content:space-around;min-width:0}.frm_image_styling_frame{display:flex;align-items:stretch;margin-left:36px;margin-bottom:var(--gap-xs);width:100%}.frm_image_styling_frame img{height:54px;width:54px;min-width:auto;min-height:auto;border-radius:3px;object-fit:cover;object-position:center}.frm_image_styling_frame .frm_email_attachment_icon img{height:auto;width:auto;max-width:54px}.frm_image_preview_title{color:var(--grey-500);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;flex:1 1 auto}.frm_wrap .frm_choose_image_box{cursor:pointer;color:var(--primary-500);background-color:#fff;margin-left:32px;text-align:center;width:100%}.frm-type-ranking .frm_option_key .frm_choose_image_box{margin-left:11px !important}.frm_wrap .frm_choose_image_box:hover{background:#fff}a.frm_remove_image_option,.frm_remove_image_option{color:var(--grey-400);cursor:pointer}a.frm_remove_image_option:hover .frmsvg,a.frm_remove_image_option:hover,.frm_remove_image_option:hover{color:rgba(40,47,54,.8)}.frm-form-setting-tabs{margin-top:var(--gap-sm) !important}.frm-right-panel>.postbox{background-color:rgba(0,0,0,0);border:none;box-shadow:none;margin:0}.frm-right-panel .postbox.frm_with_icons .inside,.frm-right-panel .postbox .inside,.frm-right-panel .inside{font-size:var(--text-md);padding:15px 20px 20px;color:var(--grey-700)}.frm-right-panel .misc-pub-section{padding:var(--gap-xs) 0;position:relative}.frm-right-panel .inside a,.frm-form-setting-tabs a{font-size:var(--text-md);color:var(--grey-700);padding:var(--gap-sm);display:block}.frm-form-setting-tabs a{color:var(--grey-900);padding:var(--gap-sm) var(--gap-md)}.frm-right-panel .inside a{padding:0;color:var(--primary-500);display:inline-block}.frm-right-panel .inside a:hover{color:var(--primary-700)}.frm-form-setting-tabs a:hover{background:var(--sidebar-hover);color:var(--grey-900)}.frm-right-panel .inside i,.frm-form-setting-tabs a i,.frm-form-setting-tabs a .frmsvg{margin:0 5px;display:inline-block;width:20px;height:20px;color:var(--grey-500)}.frm-form-setting-tabs a .frmsvg{margin:0}.frm-right-panel .inside a:hover i,.frm-right-panel .inside a:hover .frmsvg,.frm-form-setting-tabs a:hover .frmsvg,.frm-form-setting-tabs a:hover span{color:var(--grey-700)}.frm_settings_form .tabs-panel{padding:0 25px}#form_settings_page .tabs-panel,.frm_settings_form .tabs-panel{max-height:initial !important;min-height:50px !important}#frm_adv_info .tabs-panel{min-height:0 !important;overflow-x:hidden;padding:0;border:none;background:rgba(0,0,0,0)}select.frm_cancelnew,input.frm_enternew{width:175px}.frm_posttax_opt_list{border:1px solid var(--grey-300);padding:var(--gap-md);border-radius:var(--small-radius);margin:5px 0 5px var(--gap-md)}.frm_settings_form .wp-picker-open+.wp-picker-input-wrap,.frm-right-panel .wp-picker-open+.wp-picker-input-wrap{position:absolute;margin-left:calc((100% - 35px)*-1);margin-top:1px;width:calc(100% - 36px)}.frm_settings_form .wp-picker-container input[type=text].wp-color-picker,.frm-right-panel .wp-picker-container input[type=text].wp-color-picker{border:none;padding:5px 8px;font-family:inherit;color:var(--grey-700);font-size:var(--text-md);width:100%;line-height:var(--leading)}.frm_settings_form .wp-picker-input-wrap .wp-picker-clear,.frm-right-panel .wp-picker-input-wrap .wp-picker-clear{display:none !important}.frm_settings_form .wp-picker-holder,.frm-right-panel .wp-picker-holder{position:absolute;z-index:999}.frm_settings_form .wp-picker-input-wrap label,.frm-right-panel .wp-picker-input-wrap label{margin-bottom:0}.frm_settings_form .wp-picker-container .wp-color-result.button,.frm-right-panel .wp-picker-container .wp-color-result.button{width:100%;overflow:hidden;margin:0 !important;height:var(--h-md) !important;padding:0 0 0 var(--gap-lg) !important;border-radius:var(--small-radius);border-color:var(--grey-300)}.frm_settings_form .wp-color-result-text,.frm-right-panel .wp-color-result-text{line-height:var(--leading) !important;font-size:var(--text-md);background:#fff !important;color:var(--grey-900);padding:5px 8px;border-color:var(--grey-300);text-align:left}.frm_settings_form .color-alpha,.frm-right-panel .color-alpha{width:var(--gap-lg) !important}.frm_grid_container .wp-picker-container{width:100%;position:relative}.wp-picker-container button.wp-color-result{border:1px solid var(--grey-300) !important}.wp-picker-container .wp-picker-input-wrap input.hex.wp-color-picker{max-width:100%;position:relative}.frm_end .wp-picker-holder{margin-left:-145px}.frm_end.frm6 .wp-picker-holder{margin-left:-86px}.frm_toggle_opt{padding:0;white-space:normal;display:inline;vertical-align:middle;font-weight:400}.frm_on_label,.frm_off_label{color:var(--grey-700)}.frm_toggle{position:relative;display:inline-block;width:40px;height:var(--h-xs);vertical-align:middle}.frm_toggle_block{display:inline-flex !important;gap:var(--gap-xs);align-items:center}.frm_toggle input,.frm_toggle_block input{display:none !important}.frm_toggle_slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--grey-200);transition:.4s;border-radius:30px}.frm_toggle_slider::before{box-sizing:border-box;content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E");position:absolute;left:2px;bottom:2px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:20px;line-height:20px;background-color:#fff;border-radius:50%;transition:.4s;box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider{background-color:var(--primary-500)}input:focus+.frm_toggle .frm_toggle_slider{box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider::before{transform:translateX(16px);content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E")}input[disabled]+.frm_toggle_slider,input[disabled]+.frm_toggle .frm_toggle_slider{pointer-events:none;cursor:text;opacity:.5}.frm_toggle_opt~.frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before{content:"" !important}.rtl .frm_toggle_opt{padding:0 8px}.rtl .frm_toggle_slider::before{left:17px}.rtl input:checked+.frm_toggle .frm_toggle_slider::before{transform:none !important;left:1px}.frm_toggle_off,.frm_toggle_on{display:none;color:#fff;z-index:999;position:absolute;font-size:10px;line-height:20px;left:6px}.frm_toggle_off{display:inline;left:auto;right:5px;color:var(--dark-grey)}.frm_toggle_long{width:80% !important;height:28px;display:inline-block !important}.frm_toggle_long .frm_toggle_slider{background:var(--primary-700);box-shadow:0 0 0 2px var(--primary-700)}.frm_toggle_long .frm_toggle_off,.frm_toggle_long .frm_toggle_on{width:50%;text-align:center;font-size:13px;line-height:28px}.frm_toggle_long .frm_toggle_on{left:0}.frm_toggle_long .frm_toggle_off{right:0}.frm_toggle_long .frm_toggle_slider::before{width:50%;left:0;top:0;border-radius:var(--border-radius) 0 0 var(--border-radius);height:100%;background-color:#fff;color:var(--primary-color);content:"" !important}.frm_toggle_long input:checked+.frm_toggle_slider::before{transform:translateX(101%);border-radius:0 var(--border-radius) var(--border-radius) 0}input:checked+.frm_toggle_slider+.frm_toggle_on{display:inline}input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:none}.frm_toggle_long .frm_toggle_on,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:inline;color:var(--primary-500);font-weight:400}.frm_toggle_long .frm_toggle_off,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on{color:#fff;font-weight:700}.tabs-panel{height:auto !important;min-height:260px}.tabs-panel.panel_secondary{min-height:20px;margin-top:10px;margin-left:150px}label.frm-example-icon{margin-right:20px !important;display:inline-block !important}#frm_stripe_icon{border-radius:5px}#captcha_settings .frm_primary_label{margin-top:var(--gap-sm)}.frm-long-icon-buttons{display:flex;gap:var(--gap-md)}.frm-long-icon-buttons>label{border:1px solid var(--grey-300);color:var(--grey-700);border-radius:var(--small-radius);display:flex;padding:var(--gap-sm);gap:var(--gap-sm);justify-content:center;align-items:center;width:calc(33% - var(--gap-sm));box-sizing:border-box}.frm-long-icon-buttons>label:hover{color:var(--primary-500)}.frm-long-icon-buttons input[type=radio]{display:none}.frm-long-icon-buttons input[type=radio]:checked+label{border-color:var(--primary-500);box-shadow:0 0 0 1px var(--primary-color)}.frm-long-icon-buttons label>svg{height:21px}.frm-example-icon .frmsvg,.frm-example-icon i{height:20px;width:20px;font-size:20px;color:var(--grey-700)}.frm_license_msg{margin-top:0}.frm_authorized_box .frm-show-unauthorized,.frm_unauthorized_box .frm-show-authorized{display:none}.edd_frm_status_icon.frmsvg{margin:0 5px}.edd_frm_license_row .frm_action_success .frmsvg{color:green}.edd_frm_license_row .frm_action_error .frmsvg{color:#d54e21}#form_global_settings .tabs-panel .num svg{display:none}.frm_no_items{margin:0 auto 50px;text-align:center;color:var(--grey-700);max-width:500px}.frm-subscribe{margin:var(--gap-lg) 0}.frm_inbox_count{color:#fff;border-radius:50%;display:inline-block;margin-right:8px;font-size:11px;text-align:center;min-width:18px;height:18px;margin-left:2px;vertical-align:text-bottom}#payments_settings .frm_payments_section .form-table td{padding-left:0;padding-right:0}#payments_settings .frm_payments_section .form-table{margin-top:0}#frm_authnet_general_settings>tr:first-of-type>td:first-of-type{padding-top:0}#frm_authnet_general_settings h3{margin-bottom:0}.frm_payment_settings_tab .frmsvg{height:22px}.frm_payment_settings_tab[for=frm_toggle_paypal_settings] .frmsvg{width:83px}.frm_payment_settings_tab[for=frm_toggle_authorize_net_settings] .frmsvg{width:99px}.frm_payment_settings_tab[for=frm_toggle_square_settings] .frmsvg{width:89px}.frm_payment_settings_tab[for=frm_toggle_stripe_settings] .frmsvg{width:53px}.frm-email-style{float:left;margin-right:var(--gap-md)}.frm-email-style:last-of-type{margin-right:0}.frm-email-style__card{position:relative}.frm-email-style__name{margin-top:var(--gap-xs);padding-top:var(--gap-2xs);text-align:center}.frm-email-style__name .frmsvg{vertical-align:sub}.frm-email-style__click{display:block;border-radius:12px;border:1px solid var(--grey-200);box-shadow:0 .47px .94px 0 rgba(16,24,40,.0588235294)}.frm-email-style__click:focus,.frm-email-style--selected .frm-email-style__click{border-color:var(--primary-500);outline:1px solid var(--primary-500)}.frm-email-style__click img{width:160px;display:block}.frm-email-style--disabled .frm-email-style__click::after{content:"";display:block;position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--grey-100);opacity:.5}.frm-email-style__buttons{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;display:none;flex-direction:column;justify-content:center;align-items:center;gap:12px}.frm-email-style__button{cursor:pointer;display:block}.frm-email-style__button:disabled{cursor:not-allowed;display:none;background:var(--primary-700) !important;border-color:var(--primary-700) !important}.frm-email-style--selected .frm-email-style__button:disabled{display:block}.frm-email-style--selected .frm-email-style__button[data-action=choose]{display:none}.frm-email-style--disabled .frm-email-style__button[data-action=choose]{display:none}.frm-email-style:hover .frm-email-style__buttons,.frm-email-style__click:focus+.frm-email-style__buttons,.frm-email-style:focus-within .frm-email-style__buttons{display:flex}#frm-send-test-email,.frm-upload-image-btn,.frm-remove-image-btn,.frm-reset-colors-btn{cursor:pointer}#frm-send-test-email-modal .postbox{padding:var(--gap-sm) var(--gap-md)}#frm-send-test-email-modal .postbox *{box-sizing:border-box}#frm-send-test-email-modal .inside{margin:0;padding:0}.frm-lite .xml_opts .frm-export-xml-items{display:none}.csv_opts #frm_csv_col_sep{width:45px}#frm_advanced td.frm_left_label{width:20%;padding-right:2px}#frm_where_options select{max-width:200px}#frm_where_options select.frm_insert_where_options{width:30%}#frm_where_options select.frm_where_is_options{width:20%}#frm_where_options span.frm_where_val{width:32%;display:inline-block;position:relative}#frm_where_options span.frm_where_val .frm_tooltip_icon,#frm_where_options span.frm_where_val .frm_help{left:-4px;position:absolute}#frm_where_options span.frm_where_val.frm_hidden{display:none}#frm_where_options span.frm_where_val input,#frm_where_options span.frm_where_val select{width:90%;margin-left:10px}#frm_where_options{min-height:31px}.tabs-panel.active .tabs-panel,.frm_settings_form .tabs-panel .tabs-panel{border:none;padding:0}.frm-feature-banner{background:var(--grey-700);color:#fff;border-radius:var(--small-radius);padding:20px;margin:10px 0}.frm-feature-banner p{font-size:var(--text-sm)}.frm-feature-banner .dismiss{margin-top:-10px;margin-right:-10px}.frm-feature-banner .dismiss svg{color:#fff}.frm-feature-banner .frm-big-icon{padding-right:20px;float:left;min-height:60px}.frm-big-icon svg{height:60px;width:60px}.frm-feature-banner p{margin-top:0}.frm_98_width{width:100% !important}h2.frm-h2,.frm_form_settings h2{border-bottom:1px solid var(--grey-300);color:var(--grey-900);font-weight:400 !important;padding:9px 0 5px;margin:0}.frm_settings_form h3,.frm_form_settings h3,.frm_form_settings span.frm_add_logic_link{font-size:var(--text-md);border-top:1px solid var(--grey-300);padding-top:var(--gap-sm);margin:var(--gap-sm) 0;font-weight:400;text-transform:uppercase;color:var(--medium-grey);display:block}.frm_form_settings .howto{color:var(--grey-500);font-size:var(--text-sm);margin-top:8px}.frm_form_settings .advanced_settings .form-table{margin-top:0}.frm_form_settings td.frm_175_width{width:175px}.frm_form_settings #success_url{width:95%}.frm_wrap .ui-autocomplete{padding:3px 0;max-height:310px}.frm_wrap .ui-widget{font-family:inherit}.frm_wrap .ui-autocomplete li{padding:2px 4px;background:none;color:var(--grey-700);border:none;font-weight:400}.frm_wrap .ui-autocomplete .ui-menu-item-wrapper.ui-state-active{border:none;font-weight:inherit}.frm_select_with_label{margin:7px 0 0}#frm-insert-fields-box,#frm-conditionals{max-height:none}#frm-conditionals,#frm-adv-info-tab{display:none;max-height:355px}#frm-insert-fields-box ul.subsubsub,#frm-conditionals ul.subsubsub{float:right;margin:0}#frm-insert-fields-box ul.alignleft,#frm-conditionals ul.alignleft{margin:4px 0 0}#frm_adv_info ul.frm_code_list.frm-full-hover{clear:both;max-height:215px;overflow:auto}#frm-insert-fields-box ul.frm_code_list li.clear.frm_block{height:10px}#frm_adv_info .frm_noallow{display:none}#frm_adv_info #frm-conditionals .frm_noallow{display:block}#frm_html_tab.frm_hidden{display:none}#frm_html_tab.active{display:inline}.frm_email_reply_container select,.frm_email_reply_container input,.form-table td.frm_150_width{width:170px}#frm_notification_settings .frm_no_top_padding{padding-top:0}.frm_email_settings.frm_email_settings.widgets-holder-wrap{overflow:auto;box-shadow:none}#frm_notification_settings .widget-top .widget-action,#frm_form_editor_container .widget-top .widget-action{border:0;margin:0;padding:8px;background:0 0;cursor:pointer;outline:0}#frm_notification_settings .widget-top .widget-action{padding-top:13.5px}#frm_email_addon_menu{border:1px solid var(--grey-300);padding:var(--gap-sm);border-radius:4px;margin:var(--gap-md) 0 var(--gap-sm)}#frm_email_addon_menu .frm-search{float:right;margin:0}#frm_email_addon_menu h3.frm-no-border{clear:none;padding-top:7px}.frm_email_settings .widget .widget-top{background-color:var(--sidebar-color)}.frm_email_settings .widget .widget-top,.frm_email_settings .widget .widget-top h3{cursor:pointer !important}.frm_email_settings .widget{margin-bottom:var(--gap-sm)}.frm_form_action_settings .widget-top{box-shadow:none;border-color:var(--grey-300);border-radius:var(--small-radius);background:var(--lightest-grey);color:var(--grey-700)}.frm_form_action_settings:hover .widget-top{border-color:var(--grey)}.frm_form_action_settings.open .widget-top{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}.frm_form_action_settings.open:hover .widget-top{border-color:var(--grey-300)}.frm_form_action_settings>.widget-inside{display:none}.frm_form_action_settings.open>.widget-inside{display:block}.frm_form_action_settings .widget-inside{min-height:25px;padding:15px;border-color:var(--grey-300);border-bottom-left-radius:4px;border-bottom-right-radius:4px}.frm_form_action_settings .widget-title h4,.frm_form_action_settings .widget-title h3{display:inline-block;border-bottom:none;padding:10px 10px 5px;font-size:var(--text-md);font-weight:500}#frm_email_addon_menu h3{margin:0 0 var(--gap-sm);clear:both}.frm_single_api_settings p>label{display:inline}.frm_form_action_icon{margin-right:5px}.frm_actions_list{margin:0;display:inline}.frm_actions_list li{float:left;width:15.6%;margin:10px .5% 15px;height:100px;text-align:center}.frm-limited-actions .frm-group-heading,.frm-limited-actions #frm-hide-groups,.frm-all-actions #frm-show-groups,.frm-limited-actions .frm-not-installed:not(.frm-search-result):not(.frm-default-show){display:none}label.frm_action_events{padding-left:15px}#frm-hide-groups,#frm-show-groups{font-size:var(--text-md);float:right}.frm_actions_list a:active,.frm_actions_list a:focus{outline:none}.frm_actions_list a{font-size:var(--text-sm);color:var(--grey-700);word-break:break-word}.frm_actions_list span.frm-outer-circle{background-color:var(--grey-100);padding:10px;text-align:center;border-radius:50%;display:block;width:30px;height:30px;margin:0 auto 15px;line-height:1;box-sizing:content-box}.frm_email_settings .widget-title h4{color:var(--grey-700)}.frm_disabled_action .widget-title h4{color:var(--grey)}.frm_actions_list a .frmsvg,.frm_actions_list a i{height:18px;width:18px;font-size:18px;padding:2px;color:var(--lightest-grey);box-sizing:content-box}span.frm-inner-circle,.frm_email_settings .widget-title .frm_form_action_icon{background-color:var(--grey-400);border-radius:50%;display:inline-block;text-align:center;line-height:1}span.frm-inner-circle{background-color:var(--primary-700);height:22px;width:22px;padding:4px;color:#fff;box-sizing:content-box}.frm-inner-circle svg{fill:currentColor}.frm_email_settings .widget-title .frm_form_action_icon{height:15px;width:15px;padding:5px;color:#fff;vertical-align:middle}.frm_actions_list .frmsvg,.frm_actions_list i::before,.frm_email_settings .widget-title .frm_form_action_icon i,.frm_email_settings .widget-title .frm_form_action_icon .frmsvg{height:15px;width:15px;vertical-align:text-top}.frm_actions_list i::before{vertical-align:middle}.frm_email_settings .widget-title:hover .frm_form_action_icon{background-color:var(--grey)}span.frm-inner-circle.frm-inverse{background-color:rgba(0,0,0,0);color:var(--primary-700);padding:0;height:30px;width:100%}.frm_actions_list span.frm-inverse i,.frm_actions_list span.frm-inverse .frmsvg{color:var(--primary-700);height:30px;width:30px;font-size:30px;padding:0}.frm_actions_list i.frm-inverse::before{height:30px;width:100%;font-size:30px}.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse{background:#fff;padding:0;height:24px;width:24px}.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse .frmsvg,.frm_email_settings .widget-title .frm_form_action_icon.frm-inverse i::before{color:var(--grey-400);height:24px;width:24px;font-size:24px}.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse .frmsvg,.frm_email_settings .widget-title:hover .frm_form_action_icon.frm-inverse i::before{color:var(--grey-500)}.frm_email_icons{padding:10px 0 5px 6px;font-size:20px}.frm_email_icons a{margin-left:8px;color:var(--grey);opacity:0;transition:all .2s ease}.frm_email_icons a .frmsvg{color:var(--grey)}.frm_email_icons a:hover,.widget-top:hover .frm_email_icons a{opacity:1}.frm_actions_list a.frm_inactive_action{color:var(--grey)}.frm_inactive_action .frm-inner-circle,.frm_actions_list .frm_inactive_action i{opacity:.4}table td,.form-table tr td{vertical-align:top}#new_fields .form-table tr td{display:block;padding:7px 0 0}#new_fields .form-table tr td:first-child{margin:0}#new_fields .form-table tr td:last-child{margin-bottom:9px}.form-table #list-table th{text-align:center}#form_settings_page th,#form_settings_page td,.frm_settings_form td,#frm_notification_settings .frm_form_action_settings td p{padding:7px 0}#permissions_settings_settings .frm_grid_container{align-items:center}#frm_notification_settings .form-table>tbody>tr>th{width:150px;font-weight:400;padding-right:10px}#frm_notification_settings .frm_single_email_settings .form-table>tbody>tr>th{width:80px}#frm_notification_settings table tr td:first-child{padding-left:0}#frm_notification_settings table tr td:last-child{padding-right:0}#frm_notification_settings .frm_left_label{float:none;width:auto !important}.frm-fields .frm_autoresponder_rows select{width:auto}#frm_notification_settings .frm_with_left_label,#frm_notification_settings .frm_left_label+textarea,#frm_notification_settings .frm_left_label+select,#frm_notification_settings .frm_left_label+input[type=text]{width:100%}#frm_notification_settings .frm_email_buttons{padding:var(--gap-2xs);background:var(--light-blue);color:var(--primary-700);border-radius:var(--small-radius);border-color:var(--blue-border);line-height:1;height:auto;min-height:12px;font-size:var(--text-xs);box-shadow:none}p.frm_bcc_cc_container,p.frm_reply_to_container{position:relative;float:right;margin:-4px 0 0;z-index:1}.frm_email_row .frm_cancel1_icon::before{vertical-align:bottom}.frm_cc_row.frm_email_row .frm-with-right-icon,.frm_bcc_row.frm_email_row .frm-with-right-icon,.frm_reply_to_row.frm_email_row .frm-with-right-icon{width:calc(100% - 20px);display:inline-block}.frm_email_row .frm_remove_field .frm_close_icon{position:relative;fill:var(--grey-500);vertical-align:middle}.frm-inline-select,p.frm-inline-select,.frm_logic_rows .frm-collapse-me{line-height:var(--h-md) !important}.frm_logic_row{padding:var(--gap-xs) 0 0}.frm-single-settings ul.frm_sortable_field_opts{border-bottom:1px solid var(--grey-200);padding-bottom:var(--gap-xs);margin-bottom:var(--gap-xs)}.frm-single-settings .frm-add-other svg.frm_add_tag{position:relative;top:5px;margin-right:4px}.frm-single-settings .frm_single_option .frm_remove_tag::before{content:""}.frm-single-settings input[type=checkbox][readonly]{opacity:.5;pointer-events:none}.advanced_settings .frm_logic_row{margin:14px 0}.advanced_settings .frm_logic_row select,.advanced_settings .frm_logic_row input{max-width:30% !important}.frm_form_action_settings .frm_logic_row p{margin-top:0;margin-bottom:0;padding:0}#poststuff .widgets-holder-wrap .frm_form_action_settings .widget-inside{padding-bottom:0}#poststuff .frm_form_settings .widgets-holder-wrap .widget-inside{padding-left:15px;padding-right:15px}#form_global_settings h3{font-size:var(--text-sm);margin-top:25px}#form_global_settings .tabs-panel+h3{margin-top:0;border:none}#poststuff .frm_form_settings .widget-inside h3,#poststuff .frm_form_settings .advanced_settings h3,#poststuff .frm_settings_form h3,#frm_advanced .inside h3{border-top:1px solid #eee;border-bottom:none;margin:15px -15px 0;padding:8px 15px;font-size:var(--text-sm)}#poststuff .frm_form_settings h3.frm_first_h3,#poststuff h3.frm_first_h3{border:none;margin-top:0}h3.frm_add_logic_link{margin-bottom:0 !important}a.frm_add_logic_link.frm_hidden{display:none}a.frm_add_logic_link.frm_hidden+.frm_logic_rows{height:auto}.frm_icon_font{color:#a0a0a0;color:var(--grey)}.frm-fields label .frm_icon_font{font-size:inherit}.misc-pub-revisions.frm_icon_font,.misc-pub-revisions.frm_icon_font:hover{color:inherit}.postbox.frm_with_icons .inside{padding:0;margin:0}.frm_add_tag::before{content:"\e602"}.frm_remove_tag::before{content:"\e600"}.frm_logic_row .frm1>.frm_remove_tag{padding:0}.frm_tooltip_icon::before{font-size:13px;vertical-align:top}.frm_help svg,.frm_help .frmsvg{height:13px;width:13px;vertical-align:top;color:var(--grey-400)}.form-field input[type=text].frm_other_input{width:30%;margin-left:10px}.frm-add-other{text-align:right}.frm-add-other .frm_add_tag{vertical-align:20%}.frm_action_icon{margin:5px 0 0 5px}span.frm_action_icon{margin:0 4px 0 0}.frm_action_icon:active{outline:none}a.frm_action_icon:hover{text-decoration:none}.frm_action_icon.frm_error_icon::before{content:"\e608"}.frm_inactive_icon.frm_action_icon.frm_error_icon::before{content:"\e606"}.frm-field-action-icons{text-align:right;position:absolute;top:2px;right:2px;max-width:100%}.frm-field-action-icons .frm-field-id{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:80px;max-width:calc(100% - 50px);position:relative;top:2px}.frm-field-action-icons>a{font-size:var(--text-md);width:17px}.frm-field-action-icons a:hover{text-decoration:none}.frm-field-action-icons .dropdown{display:inline-block}.frm-field-action-icons>a .frmsvg{color:var(--grey-500) !important;font-size:17px;width:17px;height:17px}.frm-field-action-icons>a .frmsvg,.frm-field-action-icons>div>a .frmsvg{vertical-align:baseline}.edit_field_type_end_divider .frm-field-action-icons{display:none !important}.frm-move{cursor:grab}span.howto{display:inline}.frm_import_message{margin:15px 0;line-height:2.5}.frm_sorting .form-field .widget input[type=text],.frm_sorting .form-field .widget input[type=number],.frm_sorting .form-field .widget select,#wpcontent .frm_sorting .form-field .widget select,.frm_sorting .form-field .widget textarea{width:auto}.tagchecklist span.no_taglist{display:inline;float:none;line-height:15px;margin-right:0;font-size:inherit}.tagchecklist .frm_exclude_cat_list span{display:inline}.tagchecklist span a::before{line-height:23px;text-align:start}.frm_form_action_settings .frm_email_row .frm_tooltip_icon{position:relative;bottom:2px}.frm_no_entries_form{padding:60px 0}.frm_no_entries_form .frm_no_entries_header{font-size:20px;margin-bottom:10px}.frm_no_entries_form .frm_no_entries_text{line-height:var(--leading)}#form_entries_page #the-list .no-items{height:240px}#form_reports_page img.frm_no_reports{max-width:100%}.frm_wrap .google-visualization-table .gradient,.frm_wrap .google-visualization-table-tr-head,.frm_wrap .google-visualization-table-tr-odd,.frm_wrap .google-visualization-table-tr-odd.google-visualization-table-tr-over{background:var(--lightest-grey)}.frm_wrap .google-visualization-table-tr-over{background:#fff}.frm_wrap .google-visualization-table-table th,.frm_wrap .google-visualization-table-table td{border-right-width:0;padding:10px !important}.frm_wrap .google-visualization-table-tr-head,.frm_wrap .google-visualization-table-tr-head th{white-space:pre-wrap;font-size:var(--text-md);font-weight:400 !important;text-align:left}.frm_wrap .google-visualization-table-td-number{text-align:inherit}#form_reports_page .postbox{text-align:center;float:none;display:inline-block;margin-right:2%;width:20%;min-width:175px}#form_views_page img.frm_no_views{max-width:100%}.frm_field_opts_popup{min-width:300px;background-color:#fff}.frm_field_opts_popup #wpadminbar{display:none}.frm_prepop{width:100%;list-style:none;overflow:auto;margin:0;max-height:295px}.frm_prepop li{margin:0}.frm_prepop li a{display:block;text-decoration:none;cursor:pointer;padding:5px 20px}.frm_prepop li a:hover{background:var(--sidebar-color)}#frm_form_editor_container #frm_form_key_box{width:13em;max-width:30%}#frm_form_editor_container #frm_form_desc{width:70%}#frm_form_editor_container .ui-widget-content{display:none;padding:15px}#frm_form_editor_container .ui-widget-content label{float:left;width:170px;text-align:right;padding-right:5px;clear:both}#frm_form_editor_container .ui-widget-content label.nofloat{clear:none;float:none;margin-left:10px}#frm_form_editor_container .ui-state-default{color:#333 !important}.frm_green{color:var(--green) !important}#frm_form_editor_container .ui-state-default a.frm_orange,.frm-right-panel a.frm_orange,#postbox-container-1 a.frm_orange{color:#d54e21}#styling_settings input[type=checkbox],#styling_settings input[type=radio]{border:solid 1px #bbb}#styling_settings .widget .widget-top,#frm_form_editor_container .widget .widget-top{cursor:pointer}.frm_sorting .widget,.frm_settings_page .widget{background:#fff}.frm_sorting .widget-title h4{font-weight:400}.frm_sorting .widget,#postbox-container-1 .widget,.frm-right-panel .widget,.frm_settings_page .widget{margin-bottom:0}.frm_settings_page .widget-inside{padding:0 5px 5px}.frm_sorting .widget,.widget-inside,.frm_sorting .form-field .widget{display:none}#frm-show-fields{min-height:350px;padding:0 0 35px;margin:0;position:relative}.frm-has-fields #frm-show-fields{min-height:50px}#frm_builder_page .frm-lite-credit-card-element,body.frm-admin-page-styles .frm-lite-credit-card-element{position:relative}#frm_builder_page .frm-lite-credit-card-element>div,body.frm-admin-page-styles .frm-lite-credit-card-element>div{position:absolute;top:calc(50% - 1px);transform:translateY(-50%);right:10px;color:#d0d4dd}#frm_builder_page #frm_field_group_controls{position:absolute;padding:5px;border-radius:4px 4px 0 0;text-align:right;box-sizing:border-box;right:0;top:-28px;height:28px;z-index:3}.frm-field-group-hover-target,.frm-has-open-field-group-popup,#frm_builder_page #frm_field_group_controls,.frm-selected-field-group{background:rgba(65,153,253,.04)}.frm-selected-field-group{position:relative}#frm_builder_page #frm_field_group_controls>span:first-child{margin-right:5px}#frm_builder_page #frm_field_group_controls svg{pointer-events:none}#frm_field_group_controls{visibility:hidden}.frm-field-group-hover-target #frm_field_group_controls{visibility:visible}#frm_field_group_controls .dropdown-item a span{color:var(--grey-700)}#frm_field_group_controls .dropdown-item a:hover{text-decoration:none}.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider{display:none !important}.frm-right-panel .ui-state-default,#postbox-container-1 .ui-state-default,.frm_sorting>li.ui-state-default,.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover{border:1px solid rgba(0,0,0,0);font-weight:400 !important;background-color:rgba(0,0,0,0);background-image:none;padding:5px;margin:0;box-shadow:none;display:block;text-align:inherit !important;overflow:visible;position:relative}#frm-show-fields li.frm_cancel_sort{display:none}.divider_drop{text-align:center}.divider_drop .howto .frm_icon_font{font-style:normal}.show_repeat_sec{display:none}.repeat_section .show_repeat_sec{display:inline-block;margin:5px 0 0}.repeat_section tr.show_repeat_sec{display:table-row}.repeat_format .frm_repeat_label,.repeat_formattext .frmsvg,.repeat_formattext i{display:none}.frm_button{text-decoration:none;border:1px solid #eee;padding:5px;color:#444;vertical-align:middle;box-shadow:none !important}a.frm_button:hover{text-decoration:none !important}.frm_button,.frm_button .frm_icon_font::before{font-size:13px;vertical-align:middle}.frm_button .frmsvg{width:13px;height:13px}.frm-right-panel .ui-state-default,#postbox-container-1 .ui-state-default{padding:0;margin:0}ul.start_divider{padding:8px 13px 0 8px;min-height:115px;transition:all .4s linear}.frm-section-collapsed .frm_no_section_fields,.frm-section-collapsed ul.start_divider{height:0;min-height:0 !important}.frm-section-collapsed ul.start_divider{overflow:hidden}.frm-section-collapsed .frm_no_section_fields{overflow:hidden;padding:0;opacity:0}.frm-section-collapsed .divider_section_only .frm-collapsed-label{display:inline}.frm-page-collapsed .frm_clone_icon,.frm-page-collapsed .frm_delete_field,.frm-page-collapsed .frm_clone_field,.frm-section-collapsed .frm_clone_icon{opacity:.5;cursor:not-allowed}.edit_field_type_summary .frm_more_options_li:nth-child(2){display:none !important}.edit_field_type_submit .frm_more_options_li:not(:last-child){display:none !important}.frm_no_section_fields:not(.frm_block)+ul.start_divider{padding:0;min-height:132px}.frm_sorting li.ui-state-default .divider_section_only{padding:6px;margin-top:-10px;border:2px solid rgba(0,0,0,0);border-radius:var(--small-radius);z-index:2;position:relative}.divider_section_only>.frm_inner_field_container{padding:5px 0;margin:0}.frm-collapsed-label,.divider_section_only>.frm_inner_field_container .frm_form_fields{display:none}.frm-section-collapsed .divider_section_only::after,.divider_section_only::before{content:"";display:block;padding:2px 0;line-height:1px;border-top:2px solid var(--grey-300);top:-2px;position:absolute;width:100%;transition:.5s border-color ease-in-out}.frm-section-collapsed .divider_section_only::after{top:auto;bottom:-6px}.frm-section-collapsed .divider_section_only:hover::after,li.selected.frm-section-collapsed .divider_section_only::before,li.selected.frm-section-collapsed .divider_section_only::after,.divider_section_only:hover::before,li.selected .divider_section_only::before{border-color:rgba(0,0,0,0)}.frm_sorting li.ui-state-default.edit_field_type_divider{overflow:visible;position:relative;padding:0 0 0 20px;margin:25px 0 0 -5px;border-left:1px solid var(--primary-700);transition:border .7s ease-out}.frm-section-collapsed{border-left-color:rgba(0,0,0,0) !important}.frm_sorting li.edit_field_type_end_divider,.frm_sorting .no_repeat_section li.ui-state-default.edit_field_type_end_divider:hover{margin:0 0 var(--gap-sm)}.frm-first-page .frm_prev_page{display:none}#frm_builder_page .frm_remove_form_row.frm_button,#frm_builder_page .frm_add_form_row.frm_button{border-radius:var(--small-radius);border:1px solid var(--blue-border)}#frm_builder_page .frm_remove_form_row .frmsvg,#frm_builder_page .frm_remove_form_row i::before,#frm_builder_page .frm_add_form_row .frmsvg,#frm_builder_page .frm_add_form_row i::before{color:var(--primary-700)}.frm-preview-buttons .frm_button_submit{margin:0 5px}.frm-page-break{border-top:1px dashed var(--primary-700);margin-top:var(--gap-lg);position:relative}.frm-page-break::before,.frm-page-break::after{content:"";position:absolute;background-color:#fff;border-radius:50%;border:1px solid var(--primary-700);text-rendering:auto;-webkit-font-smoothing:antialiased}.edit_field_type_divider .frm-divider-icon.frmsvg{padding:2px;position:absolute;left:-12px;color:#fff;background-color:var(--primary-700);border-radius:50%}.edit_field_type_divider .start_divider .frm-divider-icon.frmsvg{height:8px;width:8px;padding:0;bottom:-4px;left:-24.5px;color:var(--primary-700);background-color:#fff}.edit_field_type_divider.selected .frm-divider-icon.frmsvg,.edit_field_type_divider:hover .frm-divider-icon.frmsvg{background:var(--primary-500)}.edit_field_type_divider.selected .start_divider .frm-divider-icon.frmsvg,.edit_field_type_divider:hover .start_divider .frm-divider-icon.frmsvg{background-color:#fff;color:var(--primary-500)}.frm-page-break::before,.frm-page-break::after{width:8px;height:8px;top:-6px;border-color:var(--grey)}.frm-page-break::after{right:0}#frm-fake-page .frm-page-break{border-color:var(--grey)}#frm-fake-page{padding:0 5px}.frm_sorting li.edit_field_type_divider:hover,.frm_sorting li.edit_field_type_divider.selected{border-left-color:var(--primary-500)}.frm-section-collapsed::after{border-color:rgba(0,0,0,0) !important;color:rgba(0,0,0,0)}.frm-page-break .frm-collapse-page.button{margin-left:46%;margin-top:-16px;padding:6px 12px !important}#frm-fake-page.frm-page-collapsed{margin-bottom:0}.frm-page-collapsed{position:relative;overflow:visible !important;margin-bottom:var(--gap-lg)}.frm-collapse-page .frmsvg,.frm-collapse-page .frm_arrowdown6_icon{width:var(--text-sm);height:var(--text-sm);font-size:var(--text-sm);text-align:center;margin-left:2px;color:currentColor;transition:transform 300ms ease-in-out}.frm-page-collapsed .frm-collapse-page .frmsvg{transform:rotate(180deg)}#frm-fake-page .frm_arrowdown6_icon{color:currentColor}.frm-collapsed i::before,.frm-page-collapsed .frm_arrowdown6_icon::before{content:"\e913"}.frm-collapse-section svg{fill:var(--primary-color);transition:transform .2s ease-out,fill .2s ease-out}.frm-collapse-section:hover svg{fill:var(--primary-700)}.frm-section-collapsed .frm-collapse-section svg{transform:rotate(-90deg)}.open .widget-top .widget-title-action button .frmsvg{transform:rotate(90deg)}.widget-top .widget-title-action button .frmsvg use{color:var(--grey)}.frm-collapsed+.frm-collapse-me{overflow:hidden !important}.frm-collapse-me{padding-bottom:10px}.frm-collapse-me.frm_grid_container:has(.dropdown-toggle.multiselect){position:relative;z-index:1}.frm-collapsed+div{height:0;padding:0}.frm-collapsed+div.frm-collapse-me{display:none}.frm-collapsible{display:flex;justify-content:space-between;align-items:center;font-weight:700;padding:var(--gap-xs) 0;margin:0;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.frm-collapsible.frm-collapsed{font-weight:400}.frm-collapsible:not(.frm-collapsed) .frmsvg{transform:rotate(-180deg)}h4.frm-collapsible{font-size:var(--text-md)}.frm-collapsible+.frm-collapse-me{padding-bottom:0}.frm-collapsible:focus-visible{outline:1px solid var(--primary-500)}.frm_sorting .divider_section_only>.frm_ipe_field_label{font-size:116%}#frm_form_editor_container .edit_field_type_break .frm_primary_label.frm_ipe_field_label.button{width:150px;text-align:center;margin-bottom:3px;display:block}tr.frm_options_heading td{padding-bottom:0}.frm_sorting .widget-inside .form-table td p,.frm_sorting .widget-inside .form-wrap label{padding:10px 0}.frm_no_fields,.frm_no_section_fields{text-align:center;position:absolute;color:var(--medium-grey);font-size:var(--text-md);box-sizing:border-box;border:1px dashed var(--grey-300);outline:2px solid rgba(0,0,0,0)}.frm-over-droppable+.frm_no_fields{border-style:solid;border-color:var(--primary-500);outline-color:var(--primary-500)}.frm_no_section_fields{display:none;margin:0;padding:20px 0 0;width:calc(100% - 20px);height:121px;transition:all .4s linear}.frm-empty-fields .frm_updated_message~.frm_no_fields{top:60px}#frm_form_editor_container:not(.frm-has-fields) #frm-show-fields>.frm_field_box:last-child{visibility:hidden}.frm-has-fields .frm_no_fields{display:none}#frm_form_editor_container:not(.frm-has-fields) #frm_drag_placeholder{display:none}#frm-form-button{display:none;margin:0 7px 25px}.frm-has-fields #frm-form-button{display:block}.frm-large-plus.frmsvg{color:var(--primary-700);height:45px;width:45px}.frm_no_section_fields p{color:var(--grey);font-size:15px}.frm_no_fields{top:0;width:calc(100% - 24px);min-height:320px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--gap-md);padding:var(--gap-md);border:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Crect width='99%25' height='99%25' fill='none' stroke='%23D0D5DD' stroke-width='1' stroke-dasharray='8,8' rx='8' ry='8' x='0.5%25' y='0.5%25' stroke-linecap='square' vector-effect='non-scaling-stroke'/%3E%3C/svg%3E");border-radius:var(--medium-radius);margin:var(--gap-sm) 12px}.frm_no_fields img{margin-left:calc(-1*var(--gap-lg))}.frm_no_fields .frm_drag_inst{font-size:20px;font-weight:600;margin:0 0 12px}.frm_no_fields p{color:var(--grey-600);font-size:var(--text-md);margin:0}.frm_product_price_wrapper{display:inline-block;vertical-align:middle}.frm_prod_type_single .frm_product_price_wrapper{width:100%}#new_fields .frm_product_price_wrapper input:first-child{width:60% !important;float:left}#new_fields .frm_product_price_wrapper input:nth-child(2){width:37% !important;float:right}li.frm_single_option{padding-bottom:var(--gap-sm);border-bottom:0}.frm_prod_type_single input[type=radio],.frm_prod_type_single .frm_drag_icon,.frm_prod_type_single .frm_sortable_field_opts li:nth-child(n+3),.frm_prod_type_single .frm_sortable_field_opts .frm_remove_tag,.frm_prod_type_single .frm_form_field:not(.frm_product_type):not(.frm_sep_val_product),.frm_prod_type_single .frm-bulk-edit-link,.frm_prod_type_user_def.frm_grid_container,.frm_prod_options_heading.frm_prod_user_def{display:none}.frm_prod_type_single .frm-ai-generate-options-modal-trigger{display:none !important}.frm_prod_type_single .frm_option_key{margin-left:0 !important}.frm_prod_type_single .frm_option_key input[type=checkbox]+input[type=text],.frm_prod_type_single .frm_option_key input[type=radio]+input[type=text]{margin-left:0 !important}.plugin-card-bottom .frm-trash{color:#a00}.frm-fields p>.frm_inline_label,.frm_inline_label{padding-left:3px;margin-right:12px;display:inline-block}.frm_left_label{clear:both;float:left;width:32% !important;margin-right:2% !important;line-height:2em}table td.frm_left_label{float:none;line-height:inherit;padding:5px 0 5px 2%}.frm_left_label.frm_alignright{padding-right:10px;text-align:right}.frm-fields .frm_left_label+textarea,.frm-fields .frm_left_label+select,.frm-fields .frm_left_label+input[type=text],.frm_with_left_label{width:66%}td.frm_left_label+td{width:66%;padding-top:0}#html_settings label{display:block}#html_settings .frm_field_html_box{width:100%}.frm-has-required .frm-required{color:var(--error-500)}ul.frm-category-tabs{margin-top:2px}.frm-category-tabs>li a,.frm-category-tabs>li a:active{outline:none;box-shadow:none;display:flex;gap:var(--gap-xs);align-items:center}.frm-category-tabs>li.active .frmsvg,.frm-category-tabs>li.active i,.frm-category-tabs>li.active span,.frm-category-tabs>li.active a{color:var(--primary-500)}.frm_wrap .manage-menus{margin-top:0;border:none;border-bottom:1px solid var(--grey-300);background:var(--lightest-grey)}.general_settings .postbox .manage-menus{border-top:none;border-left:none;border-right:none}.frm-postbox-no-h3{padding-top:10px}.frm-right-panel .ui-state-default,#postbox-container-1 .ui-state-default{color:var(--grey-900)}.no_repeat_section .frm_sorting>li.ui-state-default.edit_field_type_end_divider:hover{box-shadow:none}.frm-selected-field-group li.ui-state-default,.start_divider.frm_sorting li.ui-state-default.frm_not_divider.selected,.start_divider.frm_sorting li.ui-state-default.frm_not_divider:hover,.frm_sorting li.ui-state-default.frm_not_divider:hover,.frm_sorting li.ui-state-default.ui-sortable-helper,.frm_sorting li.ui-state-default.edit_field_type_divider .divider_section_only:hover,.frm_sorting .repeat_section li.ui-state-default.edit_field_type_end_divider:hover,.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only,.frm_update_msg,.frm_sorting li.ui-state-default.frm_not_divider.selected,.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only{border-color:var(--primary-500);transition:.5s border-color ease-in-out}.frm_sorting li.ui-state-default.frm_not_divider.selected{box-shadow:0 0 1px 0 var(--primary-500)}.frm_sorting li.ui-state-default{transition:.7s box-shadow ease-in-out,.7s height linear}.frm_sorting li.ui-state-default.frm-newly-added{box-shadow:inset 0 0 2px 1px var(--blue-border)}.frm_sorting li.ui-state-default.selected.edit_field_type_divider .divider_section_only .frm-show-hover{visibility:visible !important;display:inline !important}.edit_field_type_end_divider>label{display:none !important}.frm_email_actions.feature-filter{font-weight:700;border:1px solid #dfdfdf;background-color:#eee;padding:3px 5px 2px;font-size:var(--text-md);line-height:20px}.frm_update_msg{border-style:solid;margin:10px 0;color:#21759b;padding:8px 15px;border-radius:4px}.frm_update_msg.wrap{margin:10px 20px 0 2px}#frm-insert-fields-box .frm_update_msg{margin-right:.9em}.frm_update_msg a{font-weight:700}.widefat td{width:auto}.widefat .column-id{width:3.7em}.widefat .column-show_count{width:5em}.widefat .column-shortcode{width:9em}.toplevel_page_formidable .column-shortcode div{display:flex;gap:var(--gap-xs)}.widefat .column-entries,.widefat .column-link{width:10%;text-align:center}.widefat .column-form_key,.widefat .column-created_at{width:10%}.frm-white-body .search-box,.frm_wrap .frm-search{float:right;margin:0;clear:right}.frm-white-body .search-box,.frm-search{min-width:32%;position:relative;display:flex;gap:var(--gap-sm);align-items:center}.frm-inline-modal .frm-search,#frm_adv_info .frm-search{float:none;width:100%;clear:both;margin:var(--gap-xs) 0}.frm-button-group a{margin:0 7px !important}.frm_has_textarea .frm-with-right-icon{display:block}.frm-with-left-icon,.frm-with-right-icon{position:relative}i.frm-show-box,i.frm-show-inline-modal,.frm-with-left-icon i,.frm-with-right-icon i:not([class*=mce-]),.frmsvg.frm-show-box,.frmsvg.frm-show-inline-modal,.frm-with-left-icon .frmsvg,.frm-with-right-icon .frmsvg,.frm-search>.frmsvg,.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select){position:absolute;padding:0 14px;pointer-events:none;left:0;color:var(--grey-400);font-size:var(--text-xs)}.frm-search>.frmsvg,.frm-search span:not(.multiselect-selected-text):not(.multiselect-native-select){padding-left:var(--gap-xs);padding-right:var(--gap-xs)}.frm-search>.frmsvg{box-sizing:unset}.frm-with-right-icon .frmsvg,.frm-with-right-icon i:not([class*=mce-]){right:0;top:-3px;left:auto;padding:0 10px 0 5px}.frm_form_settings .frm-with-right-icon .frmsvg{top:0}.frm_form_settings .wp-editor-container .frm-with-right-icon .frmsvg,#frm_builder_page .wp-editor-container .frm-with-right-icon .frmsvg{top:auto;bottom:var(--gap-sm)}.frm_form_settings .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg,#frm_builder_page .tmce-active .wp-editor-container .frm-with-right-icon .frmsvg{bottom:var(--gap-lg)}.frm_form_settings .frm_has_textarea .frm-with-right-icon .frmsvg{top:auto;bottom:6px}.frmsvg.frm-show-box,.frmsvg.frm-show-inline-modal,i.frm-show-box,i.frm-show-inline-modal{top:auto;background-color:var(--primary-50);color:var(--primary-500);border-radius:6px;padding:var(--gap-2xs);margin:5px;margin-bottom:0;z-index:1;cursor:pointer;pointer-events:initial}.frmsvg.frm-show-box:focus,.frmsvg.frm-show-inline-modal:focus,i.frm-show-box:focus,i.frm-show-inline-modal:focus{outline:1px solid var(--primary-500)}.frm_form_settings .frmsvg.frm-show-box,.frm_form_settings .frmsvg.frm-show-inline-modal,.frm_form_settings i.frm-show-box,.frm_form_settings i.frm-show-inline-modal{margin:4px 4px 0}.frm-open+.frm-inline-modal{top:-10px;margin-bottom:0}.frm-open+.frm-inline-modal.frm-modal-no-dismiss .inside>.frm-search:first-child{margin-top:var(--gap-sm)}.frm_grid_container>.frm-open+.frm-inline-modal{top:-4px}.frm_grid_container>.frm-open+.frm-inline-modal.frm-modal-no-dismiss{top:0 !important}.frm-with-left-icon input{padding-left:37px !important}.frm_wrap .frm-with-right-icon textarea,.frm_wrap .frm-with-right-icon input,.frm_wrap .frm-with-right-icon input[type=text]{padding-right:var(--gap-md)}#frm-show-fields .frm-with-left-icon .frmsvg,#frm-show-fields .frm-with-left-icon i{padding-top:10px}.frm-search input[name=s],.frm-search .dropdown-toggle,.frm-search input.frm-search-input{color:var(--grey-800);border-color:var(--grey-300);border-radius:var(--small-radius);box-shadow:var(--box-shadow-xs)}.frm-search input[type=search],.frm-search input[type=text]{padding-left:var(--gap-lg) !important}.frm-search .dropdown-toggle{width:100%;float:none;max-width:200px;background:rgba(0,0,0,0);padding:7px;padding-left:33px !important;min-height:32px;text-align:inherit;overflow:hidden;text-overflow:ellipsis}.frm-search #search-submit a{color:var(--grey-800)}.frm-search #search-submit .caret{opacity:.7}.frm-white-body .search-box input[name=s],#wpwrap .frm-search input[type=search]{flex:1;font-size:var(--text-md);line-height:var(--text-xl);padding:var(--gap-xs)}span.multiselect-selected-text{white-space:nowrap;display:inline-block;max-width:calc(90% - var(--gap-xs));text-overflow:ellipsis;overflow:hidden}.frm-not-set input{color:var(--primary-500) !important;font-size:13px}.frm-not-set .frmsvg,.frm-not-set i{color:var(--primary-700);opacity:1}.post-type-frm_display select[name=m]+#post-query-submit,select[name=m]{display:none}.frm_shortcode_select optgroup option{margin-left:1em}.frm_shortcode_select optgroup{padding-top:5px}.frm_shortcode_select .frm_subopt{margin-left:2em}.misc-pub-section a.edit-frm_shortcode,.misc-pub-section a.edit-form-status{float:none;font-size:13px}.frm-grid{border-collapse:collapse;border:none;margin-right:10px}.frm-grid td,.frm-grid th{padding:5px;border:1px solid #000}.post-type-frm_display #poststuff #post-body.columns-2{margin-right:var(--big-sidebar)}.post-type-frm_display #post-body.columns-2 #postbox-container-1{margin-right:calc(var(--big-sidebar)*-1);width:calc(var(--big-sidebar) - 40px)}.post-type-frm_display #poststuff #post-body.columns-2 #side-sortables{width:100%}#frm_dyncontent .hndle,#frm_dyncontent .handlediv{display:none !important}.post-type-frm_display .meta-box-sortables .frm_form_nav>li>a,.post-type-frm_display .frm_form_nav .nav-tab-active{padding:0 2px 5px;line-height:1.4}.post-type-frm_display #advanced-sortables h2.hndle,.post-type-frm_display #side-sortables h2.hndle,.post-type-frm_display #normal-sortables h2.hndle{border-bottom:1px solid var(--grey-300);margin:10px 0 0 !important;padding:0 25px 8px}.post-type-frm_display #side-sortables h2.hndle{margin-top:0 !important;padding-top:10px}.post-type-frm_display #post-body-content{margin-top:var(--gap-lg)}.post-type-frm_display.edit-php #wpbody-content>.wrap{margin:0}.post-type-frm_display .postbox .hndle,.post-type-frm_display .postbox{border-color:var(--grey-300)}.post-type-frm_display #postbox-container-1 .postbox,.post-type-frm_display #postbox-container-2 .postbox{border-radius:var(--small-radius);border-color:var(--grey-300);box-shadow:none}.post-type-frm_display #side-sortables .postbox{border-radius:0;border-top-width:0;margin-bottom:0}.post-type-frm_display #side-sortables .misc-pub-section{padding:15px 20px 10px}.post-type-frm_display .misc-pub-section .frmsvg,.post-type-frm_display #post-body .misc-pub-post-status::before,.post-type-frm_display #post-body #visibility::before,.post-type-frm_display .curtime #timestamp::before,.post-type-frm_display #post-body .misc-pub-revisions::before,.post-type-frm_display span.wp-media-buttons-icon::before{color:var(--grey)}.post-type-frm_display #frm_top_bar+#poststuff #submitdiv #publishing-action,.post-type-frm_display #frm_top_bar+#poststuff #submitdiv #minor-publishing-actions,.post-type-frm_display #frm_top_bar+#poststuff #edit-slug-box,.post-type-frm_display .wrap h1.wp-heading-inline,.post-type-frm_display .wrap>.page-title-action{display:none}.post-type-frm_display #poststuff h2.nav-tab-wrapper{padding-left:10px;margin-bottom:0;padding-bottom:0}.post-type-frm_display .nav-menus-php .wrap{margin:10px 0 0}.post-type-frm_display .nav-menus-php .wrap p{padding-left:12px;padding-right:12px}.post-type-frm_display .nav-tab{display:inline-block;background-color:#f4f4f4}.post-type-frm_display .nav-tab.frm_hidden{display:none}.post-type-frm_display .nav-tab:hover{background-color:#e4e4e4}.frm_order_row,.frm_where_row{margin-bottom:7px;line-height:30px}.frm-single-settings .frm_prod_field_opt_cont{margin-top:initial;margin-bottom:20px}select.texture{display:none}.post-type-frm_display #wp-content-editor-tools,#wp-content-editor-tools{background-color:rgba(0,0,0,0)}.post-type-frm_display #major-publishing-actions{border-color:var(--grey-300);background:var(--sidebar-color)}.post-type-frm_display #frm_adv_info{width:calc(var(--big-sidebar) - 40px);height:calc(100vh - 32px);overflow:hidden}.post-type-frm_display #frm_adv_info:not(.frm_fixed){top:0 !important}.post-type-frm_display #frm_adv_info.frm_fixed{position:fixed;z-index:9999;top:32px}.post-type-frm_display #frm_adv_info ul.frm_code_list.frm-full-hover{max-height:calc(100vh - 180px)}.frm_col_one{margin-right:4%;clear:both}ul .frm_col_one{float:left}ul .frm_col_two{float:right}ul.frm_two_col{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:var(--gap-sm)}.frm_two_col li{margin-bottom:0}.frm-info-modal a,.frm-info-modal ul,.frm-info-modal p,.frm-info-modal,.settings-lite-cta a,.settings-lite-cta ul,.settings-lite-cta{color:var(--grey-500);font-size:var(--text-md);box-shadow:none !important}.frm-info-modal h3,.settings-lite-cta h3{font-size:17px !important}.frm-green-icons .frmsvg{color:var(--green)}.frm-info-modal .postbox .inside,.settings-lite-cta .postbox .inside{padding:var(--gap-md);margin:0}.cta-inside a{color:var(--orange)}.info-modal-inside a.frm-standard-link{color:var(--primary-500)}.info-modal-inside a.frm-standard-link:hover{color:var(--primary-700)}.frm_no_p_margin>p{margin:0}.frm_code_list a.button{display:block;text-align:center;font-size:11px;overflow:hidden}#frm-navbarDrop+.frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0;min-width:300px;max-height:256px}.frm_code_list.frm-full-hover li{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu>.dropdown-item>a:visited,.frm-dropdown-menu>.dropdown-item>a:link,.frm-dropdown-menu .frm_dropdown_li,.frm_code_list.frm-full-hover a{display:flex;color:var(--grey-700);padding:5px 10px;font-size:var(--text-md);gap:var(--gap-xs);align-items:center}.multiselect-container button.multiselect-option.disabled{opacity:.5}.frm_code_list.frm-full-hover a span{max-width:83px;margin-right:var(--gap-xs);margin-left:auto}.frm_code_list.frm-full-hover a{border-radius:var(--small-radius)}.frm_code_list.frm-full-hover a:not(#frm-insert-condition),.frm_code_list.frm-full-hover a span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frm_code_list.frm-full-hover a:focus span:last-child{outline:1px solid var(--primary-500);outline-offset:var(--gap-2xs)}.frm_code_list.frm-full-hover.frmcenter a{display:block}#frm-layout-classes frm-full-hover a span{max-width:45%}.frm-select-list-item.active,.frm-select-list-item:hover,.frm_wrap .ui-autocomplete li div.ui-state-active,.frm_wrap .ui-autocomplete li.ui-state-focus,.multiselect-container button.multiselect-option.active,.multiselect-container button.multiselect-option:hover,.frm-dropdown-menu>.dropdown-item>a:hover,.frm_code_list.frm-full-hover a:hover span,.frm_code_list.frm-full-hover a:hover{background:var(--primary-25);color:var(--primary-500)}.frm-select-list-item .frmsvg,.frm-dropdown-menu>.dropdown-item>a .frmsvg{opacity:.8}.frm-select-list-item:hover .frmsvg,.frm-dropdown-menu>.dropdown-item>a:hover .frmsvg{opacity:1}.frm-dropdown-menu.frm_code_list>li>a{padding:3px 15px;width:300px}#frm_edit_box_content_modal .frm-with-search,.frm-dropdown-menu .frm-with-search{padding:var(--gap-xs) 10px 0}.frm-dropdown-menu .subsubsub{padding:0 10px}.frm_grid_container{overflow:visible}.frm_code_list.frm_grid_container{grid-gap:var(--gap-xs)}.frm_code_list.frm_grid_container li{width:auto;margin:0}.frm_code_list.frm_grid_container a{display:block;font-size:var(--text-md) !important;font-weight:500;text-align:center;color:var(--primary-500);background-color:var(--light-blue);border:1px solid var(--primary-300);border-radius:var(--small-radius);padding:10px 0;box-shadow:var(--box-shadow-sm)}.frm_code_list.frm_grid_container a:hover{background-color:var(--primary-500);color:#fff}.frm_code_list.frm_grid_container a:focus-visible{outline:2px solid var(--primary-500);outline-offset:-1px}.frm-single-settings .frm_code_list.frm-full-hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{padding:0;margin:var(--gap-xs) -10px 0}.frm-single-settings .frm_code_list.frm-full-hover>li>a,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a{font-size:var(--text-md);color:var(--grey-900);padding:var(--gap-xs) 12px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span{margin:0}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:first-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:first-child{max-width:130px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:last-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:last-child{max-width:120px;margin-left:auto}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover{font-weight:500}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover .frmsvg,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover .frmsvg,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover span{color:var(--primary-500)}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg{width:20px;height:20px}.frm_field_list #frm-insert-fields{max-height:none;font-size:var(--text-sm)}.frm_field_list #frm-insert-fields .button a{display:block;max-width:95%;overflow:hidden}#frm-insert-fields{padding:0 var(--gap-xs);overflow:hidden}#frm-insert-fields .frm-search{float:none;margin:0 0 var(--gap-md);width:auto}#frm-insert-fields li,#frm-insert-fields li a{text-decoration:none;font-weight:500;font-size:var(--text-md) !important;color:var(--grey-900)}#frm-insert-fields li.frm_show_upgrade{cursor:pointer;opacity:.5}#frm-insert-fields li.frm_show_update{cursor:pointer}#frm-insert-fields li span:not(.frm-new-pill){white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}#frm-insert-fields li a.disabled:hover{cursor:not-allowed}#frm-insert-fields li.ui-draggable-disabled{opacity:.5}#frm-insert-fields li a:not(.disabled):hover .frmsvg,#frm-insert-fields li a:not(.disabled):hover i{color:var(--grey-600)}#frm-insert-fields li.frm_show_upgrade,#frm-insert-fields li.frm_show_update,#frm-insert-fields li a{text-decoration:none;display:inline-flex !important;gap:var(--gap-xs);align-items:center;border-radius:var(--small-radius) !important;padding:11px var(--gap-md) 11px var(--gap-xs) !important;color:var(--grey-900) !important}#frm-insert-fields li a{display:flex !important;transition:background-color .2s ease-out,box-shadow .2s ease-out}#frm-insert-fields li a:not(.disabled):hover{background:#fff;box-shadow:var(--box-shadow-md)}#frm-insert-fields li a:focus-visible{outline:1px solid var(--primary-500)}#frm-insert-fields li.frm_show_upgrade.frm_hidden,#frm-insert-fields li.frm_show_update.frm_hidden{display:none !important}#frm-insert-fields .frm-with-line{padding:12px var(--gap-md);font-weight:500;font-size:var(--text-sm)}#frm-insert-fields .frm-with-line::before{margin-left:calc(-1*var(--gap-sm));width:calc(100% + var(--gap-md))}.frm_code_list{clear:both}.frm_code_list.frm-full-hover a.frm_hidden,.frm_code_list .frmkeys{display:none}.frmsvg{fill:currentColor;width:18px;height:18px;vertical-align:middle}.frmsvg svg{pointer-events:none}.frmsvg.frm_svg40{width:40px;height:40px}.frmsvg.frm_svg24{width:24px;height:24px}.frmsvg.frm_svg20{width:20px;height:20px}.frmsvg.frm_svg15{width:15px;height:15px}.frmsvg.frm_svg14{width:14px !important;height:14px !important}.frmsvg.frm_svg13{width:13px;height:13px}.frmsvg.frm_svg12{width:12px;height:12px}.frmsvg.frm_svg9{width:9px;height:9px}.frmsvg.frm_svg7{width:7px;height:7px}input[disabled]{pointer-events:none}.frmbutton.ui-sortable-helper .frmsvg,.field_type_list li.frmbutton .frmsvg,.frmbutton.ui-sortable-helper i,.field_type_list li.frmbutton i,.frm_code_list a .frmsvg,.frm_code_list a i{color:var(--grey-500);display:inline-block;vertical-align:middle;width:var(--text-md);font-size:var(--text-md)}.field_type_list.frm_grid_container{gap:10px;margin:13px 0}.field_type_list li{margin:0;padding:0}.field_type_list li.frmbutton .frmsvg{width:24px;height:24px;font-size:24px}.frm_code_list i::before{font-size:inherit}.frmbutton.ui-draggable-dragging{pointer-events:none}.frmbutton.ui-draggable-dragging a{color:var(--grey-900) !important;background:var(--grey-100);text-decoration:none;display:inline-flex !important;gap:var(--gap-xs);align-items:center;border-radius:var(--small-radius) !important;padding:11px var(--gap-md) 11px var(--gap-xs) !important;box-shadow:var(--box-shadow-md)}.frmbutton.frm_at_limit{opacity:.5}.frmbutton.ui-draggable-dragging a{border:1px solid var(--grey-300);box-shadow:var(--box-shadow-md)}.frmbutton.ui-draggable-dragging span{font-size:15px}#frm-show-fields .frmbutton.ui-sortable-helper i,.frmbutton.ui-draggable-dragging i,.frmbutton.ui-draggable-dragging .frmsvg{color:#fff !important}.frmbutton.ui-draggable-dragging i,.frmbutton.ui-draggable-dragging .frmsvg{color:var(--grey-700) !important}.frm_sorting li.ui-state-default.ui-sortable-helper,.frmbutton.ui-sortable-helper{transition:opacity .2s;opacity:1;position:fixed;z-index:99999}#frm-insert-fields .frmbutton.ui-sortable-helper a,#frm-show-fields .frmbutton.ui-sortable-helper a{min-width:100px}.ui-draggable-dragging .frm-meta-tag.frm-new-pill{display:none}li.frm_noallow.button,.frm_noallow{opacity:.5}.frm_actions_list a.frm_show_upgrade.frm_inactive_action::before,li.frm_noallow.button.frm_show_upgrade,li.frm_noallow.button.frm_show_update{cursor:pointer}.field_type_list li.frm_noallow.button.frm_show_upgrade:hover,.field_type_list li.frm_noallow.button.frm_show_update:hover{border-color:inherit}.frm_noallow a{color:inherit}#frm_upgrade_modal_image{max-width:200px}#frm_upgrade_modal .cta-inside{display:flex;flex-direction:column;gap:var(--gap-sm)}#frm_upgrade_modal .frm-upgrade-message img{width:100%;margin:var(--gap-sm) 0 10px}#frm_upgrade_modal .frm-oneclick.frm_hidden{display:none !important}#frm_upgrade_modal .frm-oneclick-button{margin-left:auto}#frm_upgrade_modal .frm-upgrade-modal-actions{flex-direction:row-reverse;justify-content:flex-start;margin:0 !important}#frm_upgrade_modal .frm-upgrade-link{align-self:end}#frm_upgrade_modal.frm-success .frm-circled-icon svg{width:24px;height:24px}#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-prefix,#frm_upgrade_modal.frm-success .frm_are_not_installed{display:none !important}#frm_upgrade_modal.frm-success .frm-upgrade-modal-title-suffix{display:inline !important}#frm_upgrade_modal.frm-success .frm-addon-status{margin:0}#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options{display:flex;gap:var(--gap-xs);flex-direction:row-reverse;margin:0}#frm_upgrade_modal.frm-success .frm-addon-status .frm-save-and-reload-options .frm-save-and-reload{margin:0}.frm-dialog[aria-describedby=frm_upgrade_modal]{position:fixed !important;top:50% !important;left:50% !important;transform:translate(-50%, -50%) !important}.frm-tab-message{max-width:600px;margin:20px auto;color:rgba(63,75,91,.8)}.frm-settings-screenshot-toolbar{min-height:39px;display:flex}.frm-settings-screenshot-toolbar .frm-minmax-icon{height:8px;width:8px;border-radius:50%;align-self:center;margin-left:10px}.frm-settings-screenshot-toolbar .frm-minmax-icon:first-of-type{margin-left:20px}.frm-settings-screenshot-toolbar img{object-fit:contain;align-self:flex-end;margin-left:25px}.frm-settings-screenshot-toolbar+div{background:#fff;padding-top:25px;border-radius:0 0 16px 16px}.frm-settings-screenshot-toolbar+div img{max-width:calc(100% - 40px)}.frm-settings-screenshot-wrapper{max-width:700px;margin:50px auto 0;box-shadow:0 4px 4px rgba(189,196,205,.25),0 12px 56px rgba(42,57,75,.25);border-radius:16px;background:#ebecf1}.frm-dialog{z-index:100;padding:0 !important;border-radius:16px;border:none;background-color:#fff;max-width:100% !important}.frm-dialog .postbox{background:rgba(0,0,0,0);box-shadow:none;border:none;line-height:var(--leading)}.frm-dialog input[type=text],.frm-dialog textarea{font-size:var(--text-md)}.frm-dialog textarea{height:75px}.frm-dialog button.frm-button-primary{margin-right:10px}.frm-dialog .frm-sub-label,.frm-sub-label{color:var(--grey);text-transform:none;padding-left:8px}h2 .frm-sub-label{font-size:var(--text-md)}.frm-views-editor-body .ui-widget-overlay,.frm-white-body .ui-widget-overlay,.toplevel_page_formidable .ui-widget-overlay,body[class*=formidable-payments] .ui-widget-overlay,body.plugins-php .ui-widget-overlay{position:fixed;width:100%;height:100%;top:0;left:0;right:0;bottom:0;background:var(--grey-500);opacity:.5;z-index:2}.frm-circled-icon{width:60px;height:60px;border-radius:50%;background-color:var(--primary-25)}.frm-circled-icon-large{width:80px;height:80px}.frm-circled-icon-green{background-color:var(--success-50)}.frm-circled-icon .frmsvg{width:21px;height:24px}.frm-circled-icon .frmsvg.frm_svg32{width:32px !important;height:32px !important}.frm-circled-icon-large .frmsvg{width:24px}.frm-circled-icon .frmsvg use{color:var(--primary-500)}.frm-circled-icon-green .frmsvg use{color:var(--success-500)}.frm-border-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--grey-300);border-radius:var(--small-radius)}.frm-upgrade-message img{max-width:100%}a.frm-link-secondary{color:#c4c4c4;font-size:var(--text-sm);text-decoration:underline}.field_type_list li.button.frm_noallow,.field_type_list li.button.frm_noallow:hover,.button.frm_noallow,.button.frm_noallow:hover{color:inherit;border-color:#ccc;background:inherit}iframe#dyncontent_ifr{min-height:150px}/*! * Bootstrap v4.6.1 - */ -.tooltip { - /* Copied from Bootstrap */ - position: absolute; - display: block; - margin: 0; - font-style: normal; - font-weight: 400; - line-height: 1.5; - text-align: left; - text-align: start; - text-decoration: none; - text-shadow: none; - text-transform: none; - letter-spacing: normal; - word-break: normal; - word-spacing: normal; - white-space: normal; - line-break: auto; - font-size: 0.875rem; - word-wrap: break-word; - opacity: 0; - /* Custom rules */ - z-index: 9999999; - pointer-events: none; -} - -.tooltip.show { - opacity: 0.9; -} - -.tooltip .arrow { - position: absolute; - display: block; - width: 0.8rem; - height: 0.4rem; - margin-left: 0 !important; -} - -.tooltip .arrow::before { - position: absolute; - content: ""; - border-color: transparent; - border-style: solid; -} - -.bs-tooltip-top, -.bs-tooltip-auto[x-placement^=top] { - padding: 0.4rem 0; -} - -.bs-tooltip-top .arrow, -.bs-tooltip-auto[x-placement^=top] .arrow { - bottom: 0; -} - -.bs-tooltip-top .arrow::before, -.bs-tooltip-auto[x-placement^=top] .arrow::before { - top: 0; - border-width: 0.4rem 0.4rem 0; - border-top-color: #000; -} - -.bs-tooltip-right, -.bs-tooltip-auto[x-placement^=right] { - padding: 0 0.4rem; -} - -.bs-tooltip-right .arrow, -.bs-tooltip-auto[x-placement^=right] .arrow { - left: 0; - width: 0.4rem; - height: 0.8rem; -} - -.bs-tooltip-right .arrow::before, -.bs-tooltip-auto[x-placement^=right] .arrow::before { - right: 0; - border-width: 0.4rem 0.4rem 0.4rem 0; - border-right-color: #000; -} - -.bs-tooltip-bottom, -.bs-tooltip-auto[x-placement^=bottom] { - padding: 0.4rem 0; -} - -.bs-tooltip-bottom .arrow, -.bs-tooltip-auto[x-placement^=bottom] .arrow { - top: 0; -} - -.bs-tooltip-bottom .arrow::before, -.bs-tooltip-auto[x-placement^=bottom] .arrow::before { - bottom: 0; - border-width: 0 0.4rem 0.4rem; - border-bottom-color: #000; -} - -.bs-tooltip-left, -.bs-tooltip-auto[x-placement^=left] { - padding: 0 0.4rem; -} - -.bs-tooltip-left .arrow, -.bs-tooltip-auto[x-placement^=left] .arrow { - right: 0; - width: 0.4rem; - height: 0.8rem; -} - -.bs-tooltip-left .arrow::before, -.bs-tooltip-auto[x-placement^=left] .arrow::before { - left: 0; - border-width: 0.4rem 0 0.4rem 0.4rem; - border-left-color: #000; -} - -.tooltip-inner { - max-width: 200px; - padding: 0.25rem 0.5rem; - color: #fff; - text-align: center; - background-color: #000; - border-radius: 0.25rem; -} - -.frm-dropdown-menu.show { - display: block; -} - -.frm-single-settings .frm-dropdown-menu.show { - background: #fff; -} - -/* End Bootstrap */ -.preview.dropdown .dropdown-menu { - min-width: 205px; -} - -.frm_clear { - clear: both; -} - -.frm_clearfix::after { - content: "."; - display: block; - clear: both; - visibility: hidden; - line-height: 0; - height: 0; -} - -.frm_clearfix { - display: block; -} - -.frm_admin_progress { - overflow: hidden; - height: 20px; - margin-bottom: 20px; - background-color: #f5f5f5; - border-radius: 4px; - box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1); -} - -.frm_admin_progress_bar { - float: left; - width: 0; - height: 100%; - font-size: 12px; - line-height: 20px; - color: #fff; - text-align: center; - box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15); - transition: width 0.6s ease; - background-color: #04a4cc; -} - -.tooltip.frm_tooltip { - position: fixed; - top: auto !important; - bottom: 0 !important; - left: 0 !important; - max-width: none; - width: 100% !important; - z-index: 99999; -} - -.tooltip.frm_tooltip.bottom { - padding: 0; -} - -.frm_tooltip .tooltip-inner { - max-width: none; - min-height: 40px !important; - text-align: left; - box-shadow: 5px 5px 25px rgba(0, 0, 0, 0.5); - padding: 10px 40px; - border-top-color: #ccc; - background: var(--sidebar-color); - color: var(--grey-700); - border-radius: 0; - opacity: 1; - font-size: var(--text-sm); -} - -#frm_custom_css_box { - width: 100%; -} - -/** - * Component: Admin Inputs - */ -.frmdates_add_blackout_date_link, -.frmdates_add_exception_link, -.frm_form_field.frm_scroll_box .frm_opt_container, -.frm-white-body .wrap input[type=text], -.frm-white-body .wrap input[type=search], -.frm-white-body .wrap input[type=number], -.frm-white-body .wrap select, -#frm-form-templates-modal select, -.frm-white-body .wrap textarea, -button.frm_choose_image_box, -#titlediv input[type=text], -.frm-fields button.btn, -.frm_wrap textarea, -.frm_wrap input[type=tel], -.frm_wrap input[type=text], -.frm_wrap input[type=email] .frm_wrap input[type=search], -.frm_wrap input[type=number], -.frm_wrap input[type=date], -.frm_wrap select, -.wp-admin .frm_wrap select, -.field-group textarea, -.field-group input[type=text], -.field-group select, -.frm-fields .frm-input-field { - outline: 0; - box-shadow: var(--box-shadow-xs); - border-radius: var(--small-radius); - padding: 5px 14px; - border-color: var(--grey-300); - color: var(--grey-800); - font-size: var(--text-md); - margin: 0; - background-color: #fff; - line-height: var(--leading); -} - -.frm_input_with_suffix { - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - display: inline-block; - padding-right: 14px; -} - -.frm_input_with_suffix input { - border: 0 !important; - padding-right: 5px !important; -} - -.frm_wrap ::-webkit-datetime-edit { - line-height: var(--leading); -} - -.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus, -.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus, -.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus, -.frm_wrap input:focus, -.frm_wrap select:focus, -.wp-core-ui .frm_wrap select:focus, -#frm-form-templates-modal select:focus, -.frm-btn-group .multiselect.dropdown-toggle:focus, -.frm_wrap textarea:focus { - border-color: var(--primary-500) !important; - box-shadow: none !important; -} - -/* -Pages like Entries and Styles need the border-color and box-shadow properties without the !important flag. -To achieve this, we exclude them above and duplicate these rules specifically for those pages without using !important. -*/ -.wp-admin .frm_fields_container textarea:focus, -.wp-admin .frm_fields_container input:focus, -.wp-admin .frm_fields_container select:focus { - border-color: var(--primary-500); - box-shadow: none; -} - -#postbox-container-2 textarea, -.frm_wrap textarea, -.field-group textarea { - line-height: 2; -} - -.frm_wrap input[type=number] { - height: auto; -} - -.frm_wrap select { - padding: 2px; -} - -.wp-admin .frm_wrap select, -#frm-form-templates-modal select { - max-width: 100%; -} - -.frm_form_field.frm_scroll_box .frm_opt_container { - padding: 10px 12px; -} - -.frm_wrap input[disabled], -.frm_wrap select[disabled], -.frm_wrap textarea[disabled], -.frm_wrap input[readonly], -.frm_wrap select[readonly], -.frm_wrap textarea[readonly], -.frm_wrap input::placeholder { - color: var(--grey-500); -} - -textarea[id^=frm_calc_]::placeholder { - font-size: var(--text-sm); - line-height: var(--leading); - font-style: italic; - color: var(--grey-400); - padding-top: 5px; -} - -.frm_wrap .frm-button-primary.frm-disabled { - opacity: 0.5; - cursor: default; -} - -#postcustomstuff table td > div { - /* To override some inline css in add-on */ - padding-top: 0 !important; -} - -.wp-admin .frm_wrap .form-table select { - vertical-align: top; -} - -.frm_wrap .frm_form_builder select { - line-height: var(--leading); - height: var(--text-md); - width: 100%; -} - -#postbox-container-2 select, -.wp-admin .frm_wrap select, -.frm_wrap .frm_form_builder select, -#frm-form-templates-modal select { - height: auto; -} - -.frm-white-body .tablenav select, -.frm-white-body .tablenav input[type=text], -.wp-admin .frm_wrap .tablenav select, -.frm_wrap .tablenav input[type=date], -.frm_wrap .tablenav input[type=text] { - padding-top: 0; - padding-bottom: 0; - line-height: 1; -} - -.frm_wrap .tablenav ::-webkit-datetime-edit { - line-height: 1; -} - -.frm-fields button.btn, -.frm-fields textarea, -.frm-fields input[type=text], -.frm-fields select, -.field-group textarea, -.field-group input[type=text], -.field-group select, -.accordion-container input.hex, -.frm-fields .frm-input-field { - width: 100%; - outline: 0; -} - -.frm-fields button.btn { - height: var(--h-md); - text-align: inherit; -} - -.global-font .field-group input[type=text] { - width: auto; -} - -/** - * Component: Button Grey - */ -.wp-core-ui .frm_grey.frm-button-primary.disabled, -.wp-core-ui .frm_grey.frm-button-primary, -#frm-welcome .frm_grey { - opacity: 0.5; - background: #f6f6f6 !important; - border-color: #ddd !important; - color: #9fa5aa !important; -} - -/** - * Component: Scrollbars - */ -.windows::-webkit-scrollbar, -.windows ::-webkit-scrollbar { - width: 7px; - background: transparent; -} -.windows::-webkit-scrollbar-thumb, -.windows ::-webkit-scrollbar-thumb { - background: var(--grey-300); - -webkit-border-radius: var(--border-radius); - -webkit-box-shadow: none; -} -.windows::-webkit-scrollbar-corner, -.windows ::-webkit-scrollbar-corner { - background: transparent; -} - -.frm-scrollbar-wrapper, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list, -#frm_builder_page #frm_adv_info .frm_code_list, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div, -.frm-single-settings .frm_field_opts_list { - overflow-x: hidden; - overflow-y: auto !important; /* Enable scrolling */ - -ms-overflow-style: none; /* For IE and Edge */ - scrollbar-color: transparent transparent; /* Firefox Scrollbar - transparent by default and show on hover */ - scrollbar-width: thin; -} -.frm-scrollbar-wrapper:hover, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover, -#frm_builder_page #frm_adv_info .frm_code_list:hover, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div:hover, -.frm-single-settings .frm_field_opts_list:hover { - scrollbar-color: var(--grey-300) transparent; /* Firefox Scrollbar - Show on hover with transparent background */ -} -.frm-scrollbar-wrapper:hover::-webkit-scrollbar-thumb, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover::-webkit-scrollbar-thumb, -#frm_builder_page #frm_adv_info .frm_code_list:hover::-webkit-scrollbar-thumb, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div:hover::-webkit-scrollbar-thumb, -.frm-single-settings .frm_field_opts_list:hover::-webkit-scrollbar-thumb { - background: var(--grey-300); /* Show scrollbar on hover */ -} -.frm-scrollbar-wrapper::-webkit-scrollbar, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar, -#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar, -.frm-single-settings .frm_field_opts_list::-webkit-scrollbar { - width: 3px; -} -.frm-scrollbar-wrapper::-webkit-scrollbar-track, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-track, -#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-track, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar-track, -.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-track { - background: transparent; /* Transparent background */ - border-radius: 100vw; /* Consistent radius with thumb */ -} -.frm-scrollbar-wrapper::-webkit-scrollbar-thumb, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb, -#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar-thumb, -.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb { - background: transparent; - border-radius: 100vw; -} -.frm-scrollbar-wrapper::-webkit-scrollbar-thumb:hover, -.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb:hover, -#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb:hover, -#frm_builder_page #frm_adv_info #taxonomy-linkcategory > div::-webkit-scrollbar-thumb:hover, -.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb:hover { - background: var(--grey-300); /* Show scrollbar on hover */ -} - -/** - * Component: RTL - */ -.rtl h3 { - font-weight: inherit !important; -} - -.rtl.js .accordion-section-title::after { - left: 10px; - right: auto; -} - -.rtl #frm_top_bar #frm_bs_dropdown { - padding-left: 15px; -} - -.rtl .frm-full-close, -.rtl .frm_wrap .columns-2 .frm-right-panel + div, -.rtl .frm-right-panel { - border-left-width: 0; - border-right: 1px solid var(--grey-300); -} - -.rtl .frm-full-close { - padding-left: 0; - padding-right: var(--gap-md); -} - -.rtl .frm-text-right { - text-align: left; -} - -.rtl .frm_wrap #frm_adv_info ul.category-tabs li:first-child { - border-left-width: 1px; -} - -.rtl .frm-dropdown-menu { - text-align: right; -} - -.rtl #frm-insert-fields-box, -.rtl #frm-conditionals { - padding-right: 0.9em; -} - -.rtl #html_settings .frm_field_html_box { - margin-right: 0; -} - -.rtl .frm_list_entry_page h2 { - float: right; -} - -.rtl .frm_scale { - float: right; - margin-left: 10px; - margin-right: 0; -} - -.rtl .frm-page-break .frm-collapse-page.button { - margin-left: 0; - margin-right: 46%; -} - -.rtl .frm-field-action-icons { - right: unset; - left: 2px; -} - -.rtl .frm_has_shortcodes > i { - right: auto; - left: 5px; -} - -.rtl p.frm_reply_to_container, -.rtl p.frm_bcc_cc_container { - float: left; -} - -.rtl .frm-with-right-icon:not(.frm-token-container) .frmsvg { - right: auto; - left: 0; -} - -.rtl .frm-inline-modal > a.dismiss { - left: 13px; - right: auto; -} - -.rtl.wp-admin .frm_wrap select { - padding-left: var(--gap-lg) !important; - padding-right: 5px !important; - background-position: left 11px top 55%; -} - -.rtl .frm_code_list.frm-full-hover a span { - margin-left: var(--gap-xs); -} - -.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child { - margin-left: unset; - margin-right: var(--gap-xs); -} -.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child { - margin-right: unset; - margin-left: var(--gap-xs); -} -.rtl .frm-style-tabs-wrapper .frm-tabs-active-underline { - left: unset !important; - right: 0; -} - -.rtl .frm-unit-input .frm-input-group-suffix { - right: unset; - left: 1px; - padding-right: unset; - padding-left: var(--gap-xs); -} -.rtl .frm-unit-input .frm-input-group-suffix select { - text-align: left; - background-position: left 0 top 50%; - padding-left: 21px !important; -} - -/** - * Component: Clearfix - */ -span.clear { - display: block; -} - -.clearfix::after { - content: "."; - display: block; - height: 0; - clear: both; - visibility: hidden; -} - -.clearfix { - display: inline-block; -} - -/*Override styling from other plugins*/ -.frm_form_fields .clear { - height: auto; -} - -/* Hides from IE-mac \*/ -* html .clearfix { - height: 1%; -} - -.clearfix { - display: block; -} - -#frm_small_device_message_container { - display: none; -} - -/* End hide from IE-mac */ -/** - * Responsive Styles - * - * Media queries for desktop, tablet, and mobile devices - */ -@media only screen and (max-width: 1200px) { - .frm-addons { - grid-template-columns: 1fr 1fr; - } - #frm_top_bar h1 { - min-width: 0; /* Reset the min-width to prevent menu items from stacking vertically */ - } -} -@media only screen and (max-width: 1050px) { - .frm-white-body, -.frm_wrap { - --biggest-sidebar: 390px; - } - #form_settings_page .columns-2 { - margin: 0; - } - .frm_actions_list { - margin-left: 0; - } - #frm_bs_dropdown .frm_bstooltip { - /* There isn't enough room for the title on a screen this size so just hide it. */ - display: none !important; - } -} -@media only screen and (max-width: 960px) { - .frm-white-body, -.frm_wrap { - --gap-sm: 8px; - --gap-md: 16px; - --gap-2xl: 24px; - } - /* Revert settings panel gap variables to default */ - .frm-settings-panel { - --gap-sm: 16px; - --gap-md: 24px; - --gap-2xl: 32px; - } - .auto-fold #adminmenuwrap { - width: 36px; - } - .frm_wrap #postbox-container-1 #frm_adv_info { - min-width: 220px; - } - p.howto { - display: inline-block; - } - /* Fix: Issue where the admin page content had extra white space to the left on small screens */ - .auto-fold.frm-admin-page-styles:not(.frm-full-screen) .frm_page_container, -.auto-fold:not(.frm-full-screen) .frm_wrap .frm_page_container { - left: 36px; - } -} -@media only screen and (max-width: 850px) { - .frm-white-body, -.frm_wrap { - --biggest-sidebar: 350px; - --big-sidebar: 350px; - } - .frm_col_one { - clear: none; - } - .frm-fields p > .frm_inline_label, -.frm_inline_label { - display: block; - margin: 5px 0; - } - #frm_top_bar h1 { - width: auto; - max-width: 200px; - } - #frm-publishing { - width: auto; - } - #frm_form_editor_container, -.frm-entry-container { - margin: 0 20px; - } - .frm_wrap .frm-search { - float: none !important; - width: auto; - clear: both; - } - .post-type-frm_display #frm_adv_info { - top: auto !important; - position: static; - width: auto; - } - .frm_wrap .frm-right-panel #frm_adv_info, -.frm_wrap #postbox-container-1 #frm_adv_info { - min-width: 275px; - } - .frm_wrap #frm_adv_info ul.category-tabs li, -.frm_wrap #frm_adv_info ul.category-tabs li.tabs { - border: none; - } - .frm_wrap #frm_adv_info ul.category-tabs li:first-child { - margin-left: 12px; - } - .frm_wrap #frm_adv_info ul.category-tabs li.tabs { - border-bottom: 2px solid #5b9dd9; - padding-bottom: 8px; - } - .post-type-frm_display #poststuff { - padding: 10px 25px; - } - .post-type-frm_display #side-sortables .postbox { - margin-bottom: 20px; - border-radius: var(--small-radius); - border-top-width: 1px; - } - #frm_top_bar .frm_form_nav { - box-shadow: 0 -0.47px 10px 0 rgba(16, 24, 40, 0.0588235294); - } - #frm_top_bar ul.frm_form_nav { - padding: 1em 0; - position: fixed; - bottom: 0; - width: 100%; - background: white; - z-index: 99; - transform: translate(-50%, 0); - left: 50%; - } - .frm_page_container > .columns-2, -#frm_styler_wrapper { - padding-bottom: 64px; - } - #frm_style_preview .frm_floating_style_button:not(.frm_hidden) { - position: static; - display: inline-block; - } - .frm_wrap .columns-2 .frm-right-panel { - padding-bottom: 0; - } - #frm-publishing { - margin-left: auto; - } - #frm_top_bar > .frm-full-close:last-child { - margin-left: 0; - } - #frm_bs_dropdown { - display: block; - } - #frm_bs_dropdown .frm_bstooltip { - display: block !important; - } -} -@media only screen and (max-width: 782px) { - .frm-white-body, -.frm_wrap { - --small-sidebar: 20%; - --medium-sidebar: 35%; - } - #form_settings_page .advanced_settings .form-table td, -.form-table th { - display: table-cell; - width: auto !important; - } - .frm-white-body #publishing-action, -.frm_wrap #publishing-action { - line-height: normal; - } - .frm-white-body #screen-meta-links { - display: none; - } - .frm_wrap .misc-pub-section { - padding: 6px 0; - } - .frm_wrap .misc-pub-section > a { - float: none; - white-space: nowrap; - } - .frm-form-setting-tabs a { - position: relative; - padding: 10px 5px 10px 40px; - } - .frm-form-setting-tabs a .frmsvg, -.frm-form-setting-tabs a i { - position: absolute; - left: 13px; - top: calc(50% - 10px); - margin: 0; - } - #frm-insert-fields .button, -#frm-insert-fields .button a, -.frmbutton.ui-sortable-helper a { - line-height: 26px; - max-height: 28px; - } - a.frm_add_logic_link { - margin-left: 0; - margin-right: 0; - width: 100%; - box-sizing: border-box; - } - a.frm_add_logic_link:not([id^=logic_]) .frmsvg, -a.frm_add_logic_link i { - display: none; - } - #new_fields .frm_single_option select, -#new_fields .frm_single_option input[type=text] { - width: calc(100% - 83px); - } - .frm_single_entry_page .frm_form_fields input[type=text], -.frm_single_entry_page .frm_form_fields select, -.frm_single_entry_page .frm_form_fields textarea { - width: 100%; - } - .with_frm_style .frm_radio input[type=radio], -.with_frm_style .frm_checkbox input[type=checkbox] { - width: 25px !important; - } - .frm_single_entry_page .with_frm_style .frm_radio input[type=radio], -.frm_single_entry_page .with_frm_style .frm_checkbox input[type=checkbox] { - width: 18px !important; - } - .wp-list-table.toplevel_page_formidable .column-entries, -.wp-list-table.toplevel_page_formidable .column-form_key, -.wp-list-table.toplevel_page_formidable .column-shortcode, -.wp-list-table.toplevel_page_formidable .column-created_at { - display: none !important; - } - .wp-list-table.toplevel_page_formidable td.column-entries, -.wp-list-table.toplevel_page_formidable td.column-form_key, -.wp-list-table.toplevel_page_formidable td.column-shortcode, -.wp-list-table.toplevel_page_formidable td.column-created_at { - padding: 3px 8px 3px 35%; - text-align: left; - } - #form_entries_page .wp-list-table th.frm_hidden, -#form_entries_page .wp-list-table td.frm_hidden { - display: none !important; - } - .frm-white-body.auto-fold #wpcontent { - padding-left: 0; - } - .frm_right_addon .frm_remove_field { - bottom: 11px; - } - .frm-addons { - grid-template-columns: 1fr; - } - .frm-admin-page-styles .frm_page_container, -.frm_wrap .frm_page_container { - left: 0 !important; - } - .frm_single_entry_page.frm_wrap .columns-2 { - display: block; - border-bottom: none; - } - .frm_single_entry_page .wrap.frm-with-margin { - margin: 10px 20px; - } - .frm_single_entry_page #post-body-content + .frm-right-panel { - width: auto; - margin: 0 20px; - border: 1px solid var(--sidebar-hover); - border-radius: 6px; - } - #wp-content-media-buttons a.frm_insert_form { - padding: 0 var(--gap-sm); - } - .frm-white-body input[type=checkbox]:checked::before, -.frm_wrap input[type=checkbox]:checked::before { - width: 1.2rem; - height: 1.2rem; - } -} -@media only screen and (max-width: 700px) { - .frm-white-body, -.frm_wrap { - --biggest-sidebar: 50%; - --big-sidebar: 50%; - } -} -@media only screen and (max-width: 600px) { - .frm-white-body, -.frm_wrap { - --small-sidebar: 45px; - } - .frm-form-setting-tabs a { - visibility: collapse; - font-size: 0; - padding: 0 var(--gap-sm); - } - .frm-form-setting-tabs a .frmsvg, -.frm-form-setting-tabs a i { - visibility: visible; - position: initial; - font-size: 18px; - } - #frm_builder_page #frm-insert-fields { - padding: 0; - } - .frm_wrap #frm_adv_info ul.category-tabs li { - display: inline-block; - padding: 0; - margin: 2px 0; - border-bottom: 2px solid transparent; - } - .frm_wrap #frm_adv_info ul.category-tabs li.tabs, -.frm_wrap #frm_adv_info ul.category-tabs li:first-child { - margin-left: 0; - padding: 0; - } - .field_type_list li { - text-align: center; - } - #frm-insert-fields li a { - padding: 5px; - } - #frm_form_editor_container .frm_primary_label { - clear: both; - } - #frm_builder_page .frm_code_list a.button { - padding: 2px; - } - .frm-right-panel h3.accordion-section-title { - padding-right: 10px; - padding-left: 10px; - font-size: 20px; - white-space: nowrap; - overflow: hidden; - } - .frm-right-panel .accordion-section-title::before { - margin-left: 0; - margin-right: 3px; - } - .frm_on_submit_type svg { - display: none; - } -} -@media only screen and (max-width: 475px) { - #frm_bs_dropdown { - float: none; - } - #frm-nav-tabs { - padding: 0; - white-space: nowrap; - } - #frm-nav-tabs a { - margin-right: 0; - } - #frm_small_device_message_container { - display: flex; - flex-direction: column; - align-items: center; - justify-content: center; - position: fixed; - top: 0; - width: 100%; - height: 100%; - z-index: 999999; - background: var(--primary-500); - } - #frm_small_device_message { - text-align: center; - display: flex; - flex-direction: column; - align-items: center; - width: 80%; - padding: 1rem; - background: #fff; - border: solid 1px #fff; - border-radius: var(--medium-radius); - } - #frm_small_device_message::before { - content: ""; - position: absolute; - top: 50%; - left: 50%; - transform: translate(-78%, -65%); - width: 900px; - height: 900px; - background-color: #0d7dfc; - border-radius: 50%; - z-index: -1; - opacity: 0.3; - } - #frm_small_device_message > svg { - padding-bottom: 1rem; - } - .toplevel_page_formidable:has(#frm_small_device_message_container) #posts-filter, -.post-type-frm_display:has(#frm_small_device_message_container) #posts-filter { - display: none; - } -} -@media print { - a, -.misc-pub-section a { - color: #000 !important; - } - .add-new-h2, -#frm_top_bar, -.dashicons, -#adminmenuwrap, -#adminmenuback, -#wphead, -#button_bar, -#submitdiv, -.button-secondary, -#screen-metas, -#screen-meta-links, -#footer, -#wpfooter, -.inner-sidebar, -.frm_form_nav, -.frm_flash_graph, -.frm_no_print, -object, -.error { - visibility: hidden; - display: none !important; - } - .widget, -.postbox, -.stuffbox, -.postbox h3 { - border-width: 0 !important; - border-color: #fff; - } - .postbox { - background: #fff !important; - border: none; - position: static; - } - .postbox h3, -.postbox h4 { - background: #fff !important; - } - #wpbody-content { - float: none; - } - #wpcontent, -#post-body-content, -.has-right-sidebar #post-body, -#poststuff .columns-2 { - margin: 0 !important; - } - .frm_wrap #poststuff .columns-2 { - display: block; - } - #post-body-content + .frm-right-panel, -.frm_wrap .columns-2 .frm-right-panel, -.frm-right-panel { - border: none; - width: auto; - display: block; - padding: 20px; - } - .frm_wrap .columns-2, -.frm_wrap .frm_page_container { - height: auto; - display: block; - } - .misc-pub-section > span { - padding: 0; - } - .frm-right-panel .postbox .inside { - padding-left: 12px; - padding-right: 12px; - } - .curtime #timestamp::before { - display: none; - content: none !important; - } - .frm_charts .alignleft { - float: none; - } - .pg_odd, -.pg_even { - page-break-inside: avoid; - max-width: 600px; - } - .form-table td, -.form-table th { - padding: 0; - } - .frm_file_container a { - display: block; - width: 100%; - } -} -/** - * Extended Components - * - * Additional components loaded after the main layout - */ -/** - * Layout: Publishing - */ -.frm-admin-page-styles #frm-publishing #save_menu_header, -.frm-admin-page-styles2 #frm-publishing #save_menu_header { - display: inline-block; -} - -/* Change the order of subfields of the Name field in the backend */ -.edit_form_item .frm_combo_inputs_container[data-name-layout=last_first] .frm_form_subfield-first { - order: 2; -} - -.frm-video-wrapper iframe { - width: 100%; - max-width: 843px; - border-radius: var(--border-radius); -} - -/** - * Field group popup and related functionality - */ -#frm_field_group_popup { - position: absolute; - top: 0; - right: 0; - width: 366px; - max-height: 231px; - border-radius: 8px; - background: #fff; - box-shadow: 0 20px 48px rgba(40, 47, 54, 0.15); - z-index: 3; - box-sizing: border-box; - padding: 24px 0; - text-align: left; -} - -.rtl #frm_field_group_popup { - text-align: right; -} - -.frm-merge-fields-into-row #frm_field_group_popup { - top: unset; - bottom: 50px; - height: 196px; -} - -#frm_field_group_popup > hr { - margin: 12px 0; -} - -#frm_field_group_popup .frm-cancel-custom-field-group-layout, -#frm_field_group_popup .frm-save-custom-field-group-layout { - padding: 4px 18px; -} - -#frm_field_group_popup .frm-cancel-custom-field-group-layout:hover { - border-color: var(--primary-500) !important; - color: var(--primary-500); - background-color: transparent !important; -} - -.frm-merge-fields-into-row #frm_field_group_popup .frm-break-field-group { - display: none; -} - -.frm-merge-fields-into-row > a { - color: rgba(40, 47, 54, 0.85); - position: relative; - top: 2px; -} - -.frm-row-layout-title { - font-weight: 600; - font-size: 11px; - line-height: 15px; - text-transform: uppercase; - color: rgba(40, 47, 54, 0.45); - margin-bottom: 27px; -} - -.frm-row-layout-option { - background: #f6f7fb; - box-sizing: border-box; - border-radius: 2px; - padding: 15px 10px; -} - -#frm_field_group_popup .frm-row-layout-option .frm_grid_container { - grid-gap: 0 5%; - grid-template-columns: repeat(12, auto); -} - -#frm_field_group_popup .frm-row-layout-option { - cursor: pointer; - border: 2px solid transparent; -} - -#frm_field_group_popup .frm-row-layout-option.frm-active-row-layout, -#frm_field_group_popup .frm-row-layout-option:hover { - border-color: var(--primary-500); -} - -.frm-custom-field-group-layout, -.frm-break-field-group { - padding: 4px 24px; - cursor: pointer; - font-size: var(--text-sm); - line-height: 19px; - color: rgb(72, 78, 84); -} - -.frm-custom-field-group-layout:hover, -.frm-break-field-group:hover { - background-color: rgba(245, 245, 245, 0.9607843137); -} - -.frm-custom-field-group-layout svg, -.frm-break-field-group svg { - margin-right: 5px; -} - -/** - * Field multiselect popup - */ -#frm_field_multiselect_popup { - background: white; - height: 48px; - position: fixed; - border-radius: 4px; - box-shadow: 0 8px 24px rgba(40, 47, 54, 0.15); - color: rgba(40, 47, 54, 0.85); - font-size: 13px; - right: 30px; - bottom: 10px; - z-index: 2; -} - -#frm_field_multiselect_popup > div { - display: inline-block; - line-height: 48px; - vertical-align: top; -} - -#frm_field_multiselect_popup.frm-unmergable > .frm-merge-fields-into-row, -#frm_field_multiselect_popup.frm-unmergable > .frm-multiselect-popup-separator { - display: none; -} - -#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator) { - padding: 0 20px; - cursor: pointer; -} - -#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator):hover { - background: rgba(245, 245, 245, 0.9607843137); -} - -.frm-builder-popup-heading { - font-weight: 600; - font-size: 11px; - line-height: 15px; - text-transform: uppercase; - color: rgba(40, 47, 54, 0.45); - margin-bottom: 7px; -} - -.frm-builder-popup-subheading { - font-size: 12px; - line-height: 16px; - color: rgba(40, 47, 54, 0.45); -} - -#frm_field_group_popup input[type=text] { - height: 30px; - border-radius: 3px; - font-size: 14px; - padding: 8px; - color: rgb(84, 95, 110); - border-color: rgba(40, 47, 54, 0.2); -} - -.frm-multiselect-popup-separator { - height: 36px; - width: 1px; - position: relative; - top: 6px; - background: #c4c4c4; -} - -.frm-sortable-helper, -.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider) { - pointer-events: none; -} - -.frm-sortable-helper { - /* Make sure the item being dragged appears above other form builder fields */ - z-index: 99; -} - -/** - * Component: Banner Notification - */ -#frm_banner { - width: 100%; - color: #fff; - background: var(--primary-500); - height: 40px; - line-height: 40px; - text-align: center; - position: relative; -} - -.frm-banner-emoji { - font-size: 19px; -} - -.frm-banner-emoji, -.frm-banner-title { - margin-right: 5px; - vertical-align: top; -} - -.frm-banner-cta a { - text-decoration: underline !important; -} - -#frm_banner .frm-banner-cta a.frm_inbox_dismiss { - display: none; -} - -.frm-banner-dismiss { - cursor: pointer; - position: absolute; - right: 10px; - top: 50%; - transform: translateY(-50%); -} - -.frm-banner-dismiss .frmsvg { - vertical-align: top; -} - -/** - * Ready-made solution styles - */ -.frm-ready-made-solution:not(.frm-search-result) { - display: none !important; -} - -#frm_leave_email_wrapper .frmsvg { - top: 0; -} - -#frm-add-my-email-address { - margin-top: 30px; -} - -.frm-ready-made-solution h3 ~ a { - color: var(--primary-500); -} - -.frm-ready-made-solution img { - max-width: 100%; - display: block; - box-shadow: var(--box-shadow-lg); -} - -/** - * Component: On Submit Action - */ -.frm_single_on_submit_settings .frm_form_field { - margin: 22px 0; -} - -.frm_on_submit_type_setting { - padding: 8px 0; -} - -.frm_on_submit_type label { - display: flex; - border: 1px solid var(--grey-border); - border-radius: var(--small-radius); - gap: 16px; - padding: 16px; - align-items: center; - justify-content: center; -} - -.frm_on_submit_type input { - opacity: 0 !important; - position: absolute; - z-index: -1; -} - -.frm_on_submit_type input[type=radio]:checked + label { - border-color: var(--primary-color); - box-shadow: 0 0 0 1px var(--primary-color); -} - -#form_settings_page .frm_on_submit_type label:hover, -.frm_on_submit_type input[type=radio]:checked + label svg { - color: var(--primary-color); -} - -/** - * Component: Call-to-Action - */ -.frm_pro_tip, -.frm-cta { - justify-content: space-between; - align-items: center; - gap: var(--gap-2xl); - padding: var(--gap-xs) var(--gap-sm); - border-radius: var(--small-radius); - background: var(--primary-25); -} - -.frm-cta.frm-cta-border { - border: 1px solid var(--primary-200); -} - -.frm-cta.frm-cta-border .frm-cta-footer { - background-color: #fff; - padding: 12px var(--gap-sm); - border-top: 1px solid var(--primary-200); - border-bottom-left-radius: var(--small-radius); - border-bottom-right-radius: var(--small-radius); - margin-top: 12px; - margin-bottom: calc(-1 * var(--gap-sm)); - margin-left: calc(-1 * var(--gap-sm)); - margin-right: calc(-1 * var(--gap-sm)); -} - -.frm-cta h4 { - font-weight: 600; - margin-top: 0; - margin-bottom: var(--gap-2xs); -} - -.frm-cta-green { - background-color: var(--success-25); -} - -.frm-cta-green .frm-banner-title { - gap: calc(var(--gap-2xs) + 1px); - color: var(--grey-700); -} - -.frm-cta-green.frm-cta-border { - border-color: var(--success-100); -} - -.frm-cta-green.frm-cta-border .frm-cta-footer { - border-color: var(--success-100); -} - -.frm-cta-red { - background-color: var(--error-25); -} - -.frm-cta-red.frm-cta-border { - border-color: var(--error-100); -} - -.frm-cta-icon { - padding: 3px 15px 3px 0; - border-right: 1px solid currentColor; -} - -#frm-upgrade-banner { - gap: 0; -} - -#frm-upgrade-banner .frm-cta-icon + .frm-cta-content { - margin-right: auto; - padding-left: 15px; -} - -#frm-upgrade-banner.frm-gradient h4, -#frm-upgrade-banner.frm-gradient p { - color: currentColor; -} - -#frm-upgrade-banner.frm-gradient h4 { - font-size: 16px; - font-weight: 600; -} - -#frm-upgrade-banner.frm-gradient p { - font-size: 14px; -} - -.frm-right-panel .inside .frm_pro_tip, -.frm_pro_tip { - color: var(--grey-700); - background: #ffe7de; - margin: 0 auto; - display: flex; - gap: var(--gap-xs); -} - -.frm_field_list .frm_pro_tip { - margin: 10px 15px; - position: relative; - width: calc(100% - 30px); - box-sizing: border-box; - font-size: 14px; -} - -.frm_pro_tip .frmsvg, -.frm_pro_tip i { - color: var(--orange); -} - -.frm-tip-info { - flex: 1; - text-align: left; -} - -.frm-tip-cta { - color: var(--orange); -} - -.frm-gradient .frm-tip-cta, -.frm-light-tip .frm-gradient .frm-tip-cta { - color: currentColor; - font-weight: 700; -} - -.frm-tip-badge { - font-size: 9px; - font-weight: 700; - text-transform: uppercase; - color: #1e63d5; - background-color: #fff; - line-height: 1; - border-radius: 4px; - padding: 3px 4px; -} - -.frm-light-tip .frm_pro_tip { - background: var(--primary-25); -} - -.frm-light-tip .frm_pro_tip .frmsvg, -.frm-light-tip .frm_pro_tip i, -.frm-light-tip .frm-tip-cta { - color: var(--primary-500); -} - -.nav-tab-wrapper .frm_pro_tip { - float: right; -} - -/** - * Component: Form Templates Modal - */ -/* Start confirm and form templates modals */ -#frm-form-templates-modal textarea { - height: 108px; -} - -#frm-form-templates-modal .frm-fields button.btn { - border-color: var(--grey-300); - color: var(--grey-900); - cursor: pointer; -} - -#frm-form-templates-modal .frm-fields button.btn .frmsvg { - color: var(--grey-400); - width: 14px; - height: 14px; -} - -#frm-form-templates-modal .frm-form-templates-modal-fieldset { - position: relative; -} - -#frm-form-templates-modal .frm-form-templates-modal-fieldset .frm-with-left-icon .frmsvg { - padding: 0; - top: 0; - left: 13px; -} - -/* Fixes pro issue #3508, prevent a conflict that hides the postbox in modal */ -#frm-form-templates-modal .postbox { - display: block !important; -} - -/* Leave email modal */ -#frm_empty_inbox #frm-leave-email-modal { - margin-top: var(--gap-2xl); -} - -/* Name your form modal */ -#frm-name-your-form-modal .frm_modal_top { - padding-top: var(--gap-sm); -} - -/* End confirm and form templates modals */ -/** - * Component: Field Group Message - */ -#frm-field-group-message { - position: absolute; - bottom: 32px; - right: calc(50% - var(--biggest-sidebar)); - padding: var(--gap-xs) var(--gap-sm); - border-radius: 100px; - background-color: var(--primary-25); -} - -#frm-field-group-message .frm-field-group-message-text { - gap: 10px; - color: var(--grey-800); -} - -#frm-field-group-message-dismiss { - margin-left: var(--gap-xs); -} - -#frm-field-group-message-dismiss .frmsvg { - color: var(--grey-800); - width: 15px; - height: 15px; - cursor: pointer; - transition: color 300ms ease-in-out; -} - -#frm-field-group-message-dismiss .frmsvg:hover { - color: var(--grey-500); -} - -/** - * Component - Card Item - */ -.frm-card-item { - display: flex; - border: 1px solid var(--grey-200); - border-radius: var(--small-radius); - padding: var(--gap-sm); - box-shadow: var(--box-shadow-xs); - background: #fff; -} - -.frm-card-item:not(.frm-counter-card) { - gap: 10px; -} - -.frm-compact-card-item { - padding: var(--gap-sm) 35px 10px 35px; -} - -.frm-card-bottom { - background-color: var(--grey-50); - margin-left: calc(var(--gap-sm) * -1); - margin-bottom: calc(var(--gap-sm) * -1); - margin-right: calc(var(--gap-sm) * -1); - padding: var(--gap-sm); - border-radius: 0 0 var(--small-radius) var(--small-radius); -} - -/** - * Component: Pirate Forms Importer - */ -#welcome-panel:has(#frm_form_pf_importer) { - background-color: #fff; - margin: var(--gap-sm) var(--gap-md) var(--gap-md); - line-height: 2; -} - -#welcome-panel:has(#frm_form_pf_importer) .welcome-panel-content { - text-align: start !important; - min-height: unset; - display: block; -} - -#frm_form_pf_importer div { - margin: 10px 0 !important; -} - -#frm_form_pf_importer button { - border: 1px solid var(--primary-500); - padding: 7px 16px; - min-height: 28px; - line-height: var(--leading); - margin-bottom: 0; - background: var(--primary-500); - color: #fff !important; -} - -#frm_form_pf_importer button:hover { - background: #135e96; - border-color: #135e96; -} - -/** - * Component: Option Box - */ -.frm-option-box { - display: flex; - justify-content: space-between; - align-items: center; - font-size: 14px; - font-weight: 500; - background-color: #fff; - padding: 12px var(--gap-sm); - border: 1px solid var(--grey-200); - border-radius: var(--small-radius); - margin-bottom: var(--gap-xs); - transition: background-color 100ms ease-out; - cursor: pointer; -} - -.frm-option-box:hover { - background-color: var(--grey-25); -} - -.frm-option-box.frm-checked { - background-color: var(--primary-25); - border-color: var(--primary-200); -} - -.frm-option-box.frm-disabled { - cursor: default; -} - -.frm-option-box input[type=checkbox] { - margin: 0; -} - -.frm-option-box.frm-disabled input[type=checkbox] { - opacity: 0.5; -} - -.frm-option-box .frm_help .frmsvg { - width: 12px; - height: 12px; -} - -/** - * Component: Validation Error - */ -.frm-validation-error:not(.frm_hidden) { - display: flex; -} - -.frm-validation-error { - gap: calc(var(--gap-xs) + var(--gap-2xs)); -} - -.frm-validation-error span { - color: var(--error-500); -} - -.frm-validation-error span[frm-error] { - display: none; -} - -.frm-validation-error[frm-error=empty] span[frm-error=empty], -.frm-validation-error[frm-error=invalid] span[frm-error=invalid], -.frm-validation-error[frm-error=custom] span[frm-error=custom] { - display: inline-block; -} - -/** - * Utility: Box - */ -.frm-box { - padding: var(--gap-sm); - border: 1px solid var(--grey-200); - border-radius: var(--small-radius); -} - -/** - * External Link styles - */ -.frm-link-with-external-icon { - display: flex; - align-items: center; - gap: var(--gap-2xs); - font-size: var(--text-xs); -} - -.frm-link-with-external-icon .frmsvg { - width: 16px; - height: 16px; - transform: rotate(45deg); -} - -/** - * Page Skeleton - * - * Manages the layout and appearance of the page's content area. - */ -/* Core Styles for the Page */ -#wpbody-content .frm-page-skeleton { - /* Sidebar Styles */ - /* Scrollbar */ - /* Search */ -} -#wpbody-content .frm-page-skeleton ul, -#wpbody-content .frm-page-skeleton li { - margin: 0; -} -#wpbody-content .frm-page-skeleton .frm-right-panel { - padding: 2px; - overflow-y: initial; -} -#wpbody-content .frm-page-skeleton .frm-scrollbar-wrapper { - padding: var(--gap-md) var(--gap-sm); -} -#wpbody-content .frm-page-skeleton .frm-search { - float: none; - padding: 0 var(--gap-2xs); -} -#wpbody-content .frm-page-skeleton .frm-search > svg { - left: var(--gap-2xs); -} -#wpbody-content .frm-page-skeleton .frm-search > input { - width: 100%; -} - -/* Categories */ -.frm-page-skeleton-cat { - cursor: pointer; - padding: var(--gap-xs); - border-radius: var(--small-radius); - background-color: transparent; - transition: background-color 250ms ease-out; -} -.frm-page-skeleton-cat:hover { - background-color: var(--grey-100); -} -.frm-page-skeleton-cat > * { - z-index: 2; -} - -.frm-page-skeleton-cat-text { - color: var(--grey-900); - text-transform: capitalize; -} - -.frm-page-skeleton-cat-count { - color: var(--grey-400); -} - -.frm-current .frm-page-skeleton-cat-text, -.frm-current .frm-page-skeleton-cat-count { - color: var(--primary-500); -} - -/* Page Content Styles */ -.frm-list-grid-layout { - display: grid; - grid-template-columns: repeat(auto-fill, minmax(303px, 1fr)); - grid-auto-rows: max-content; - gap: var(--gap-sm); -} -.frm-list-grid-layout > * { - grid-column: span 1; -} - -/* Empty State Styles */ -#frm-page-skeleton-empty-state { - height: 100%; - margin-top: calc(-1 * var(--gap-md)); -} -#frm-page-skeleton-empty-state .frm-page-skeleton-text { - max-width: 420px; -} - -/* Helper Classes */ -.frm-page-skeleton-divider { - border-top: 1px solid var(--grey-200); - margin: 0; -} - -/** - * Submit field styles - */ -.field_type_list .frm_tsubmit { - display: none !important; -} - -/** - * Component: Accordion Title - */ -#frm_style_sidebar .accordion-section-title::after, -#frm_view_editor_left .accordion-section-title::after { - content: ""; -} - -a[href="#square_settings"] svg.frmsvg { - width: 23px !important; - height: 22px !important; -} - -#frm_square_test_setup_modal a:focus { - box-shadow: none !important; -} - -@media only screen and (max-width: 900px) { - #square_settings .frm_grid_container:has(.frm-card-item) { - grid-template-columns: repeat(1, 1fr); - } - #square_settings .frm-card-item + .frm-card-item { - margin-top: var(--gap-sm); - } -} -.frm-coupons-upsell-wrapper { - display: flex; - flex-direction: column; - align-items: center; -} -.frm-coupons-upsell-wrapper p { - margin-top: var(--gap-xs); - max-width: 364px; - text-align: center; -} -.frm-coupons-upsell-wrapper img { - max-width: 100%; - max-height: 300px; -} -.frm-coupons-upsell-wrapper h2 { - margin-bottom: 0; -} - -.frm-coupons-upsell { - background-color: #f5f5f7; - border-radius: 16px; - border: 6px solid #fff; - box-shadow: 0 0.471px 1.412px 0 rgba(16, 24, 40, 0.1), 0 0.471px 0.941px 0 rgba(16, 24, 40, 0.06); - text-align: center; - width: 100%; - box-sizing: border-box; -} - -.frm-main-coupons-upsell { - margin-top: var(--gap-lg); -} -.frm-main-coupons-upsell img { - vertical-align: bottom; -} - -.frm-secondary-coupons-upsells { - margin-top: var(--gap-md); - width: 100%; -} - -#frm_sale_banner { - display: flex; - height: 90px; - flex-direction: row; - align-items: center; - gap: var(--gap-sm); - cursor: pointer; - position: relative; -} -#frm_sale_banner > div:first-child { - align-self: flex-end; - width: 150px; - height: 100%; - display: flex; - justify-content: center; -} -#frm_sale_banner > div:first-child img { - align-self: center; -} -#frm_sale_banner > div:nth-child(3) { - margin-left: auto; - margin-right: 50px; -} -#frm_sale_banner > div:nth-child(2) > div:last-child { - opacity: 0.8; -} -#frm_sale_banner a:not(.dismiss) { - text-shadow: none; - border-radius: 30px; - border: 1px transparent; - font-size: var(--text-sm); - padding: 7px 16px; - height: auto; - min-height: 28px; - outline: none; - line-height: var(--leading); - box-sizing: border-box; - margin-bottom: 0; - display: inline-block; - font-weight: 700; - background-color: #fff; - color: #000; -} -#frm_sale_banner .dismiss { - position: absolute; - color: #fff; - opacity: 0.6; - right: 15px; - top: 10px; -} -#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: #fff"] { - background-color: #f0f0f0 !important; -} -#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(241, 90, 36, 1)"] { - background-color: #e6470f !important; -} -#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(239, 58, 78, 1)"] { - background-color: #ed1d34 !important; -} -#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(33, 2, 14, 1)"] { - background-color: #3e041a !important; -} -#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(72, 51, 64, 1)"] { - background-color: #362630 !important; -} - -.frm-get-free-templates-banner { - flex-grow: 1; -} -.frm-get-free-templates-banner .frm-banner-image-wrapper { - display: flex; - justify-content: center; - align-items: flex-end; - background-color: var(--primary-25); - padding: 19px 14px 0; - border-radius: var(--small-radius); -} -.frm-get-free-templates-banner[data-direction=vertical] { - flex-direction: column; - align-items: stretch; - gap: 12px; -} -.frm-get-free-templates-banner[data-direction=vertical] .frm-banner-content { - align-items: center; - text-align: center; -} - -/** - * Backwards Compatibility - */ -.frm-lookup-box-label { - display: none; -} - -.frm-inline-modal[id^=frm-lookup-box] { - background-color: transparent; - border: 0; - box-shadow: none; -} -.frm-inline-modal[id^=frm-lookup-box] .frm-nav-tabs, -.frm-inline-modal[id^=frm-lookup-box] .dismiss { - display: none; -} - -.frm_single_option a.frm_remove_tag svg, -.frm_single_option a.frm_add_opt svg { - width: 15px; - height: 15px; -} - -#frm_builder_page #frm-options-panel .frm-single-settings.frm-type-ranking .frm_image_styling_frame { - margin-left: 12px; -} - -/*# sourceMappingURL=frm_admin.css.map*/ \ No newline at end of file + */.tooltip{position:absolute;display:block;margin:0;font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0;z-index:9999999;pointer-events:none}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem;margin-left:0 !important}.tooltip .arrow::before{position:absolute;content:"";border-color:rgba(0,0,0,0);border-style:solid}.bs-tooltip-top,.bs-tooltip-auto[x-placement^=top]{padding:.4rem 0}.bs-tooltip-top .arrow,.bs-tooltip-auto[x-placement^=top] .arrow{bottom:0}.bs-tooltip-top .arrow::before,.bs-tooltip-auto[x-placement^=top] .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-right,.bs-tooltip-auto[x-placement^=right]{padding:0 .4rem}.bs-tooltip-right .arrow,.bs-tooltip-auto[x-placement^=right] .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-right .arrow::before,.bs-tooltip-auto[x-placement^=right] .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-bottom,.bs-tooltip-auto[x-placement^=bottom]{padding:.4rem 0}.bs-tooltip-bottom .arrow,.bs-tooltip-auto[x-placement^=bottom] .arrow{top:0}.bs-tooltip-bottom .arrow::before,.bs-tooltip-auto[x-placement^=bottom] .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-left,.bs-tooltip-auto[x-placement^=left]{padding:0 .4rem}.bs-tooltip-left .arrow,.bs-tooltip-auto[x-placement^=left] .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-left .arrow::before,.bs-tooltip-auto[x-placement^=left] .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.frm-dropdown-menu.show{display:block}.frm-single-settings .frm-dropdown-menu.show{background:#fff}.preview.dropdown .dropdown-menu{min-width:205px}.frm_clear{clear:both}.frm_clearfix::after{content:".";display:block;clear:both;visibility:hidden;line-height:0;height:0}.frm_clearfix{display:block}.frm_admin_progress{overflow:hidden;height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.frm_admin_progress_bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);transition:width .6s ease;background-color:#04a4cc}.tooltip.frm_tooltip{position:fixed;top:auto !important;bottom:0 !important;left:0 !important;max-width:none;width:100% !important;z-index:99999}.tooltip.frm_tooltip.bottom{padding:0}.frm_tooltip .tooltip-inner{max-width:none;min-height:40px !important;text-align:left;box-shadow:5px 5px 25px rgba(0,0,0,.5);padding:10px 40px;border-top-color:#ccc;background:var(--sidebar-color);color:var(--grey-700);border-radius:0;opacity:1;font-size:var(--text-sm)}#frm_custom_css_box{width:100%}.frmdates_add_blackout_date_link,.frmdates_add_exception_link,.frm_form_field.frm_scroll_box .frm_opt_container,.frm-white-body .wrap input[type=text],.frm-white-body .wrap input[type=search],.frm-white-body .wrap input[type=number],.frm-white-body .wrap select,#frm-form-templates-modal select,.frm-white-body .wrap textarea,button.frm_choose_image_box,#titlediv input[type=text],.frm-fields button.btn,.frm_wrap textarea,.frm_wrap input[type=tel],.frm_wrap input[type=text],.frm_wrap input[type=email] .frm_wrap input[type=search],.frm_wrap input[type=number],.frm_wrap input[type=date],.frm_wrap select,.wp-admin .frm_wrap select,.field-group textarea,.field-group input[type=text],.field-group select,.frm-fields .frm-input-field{outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;background-color:#fff;line-height:var(--leading)}.frm_input_with_suffix{border-radius:var(--small-radius);border:1px solid var(--grey-300);display:inline-block;padding-right:14px}.frm_input_with_suffix input{border:0 !important;padding-right:5px !important}.frm_wrap ::-webkit-datetime-edit{line-height:var(--leading)}.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus,.frm_wrap input:focus,.frm_wrap select:focus,.wp-core-ui .frm_wrap select:focus,#frm-form-templates-modal select:focus,.frm-btn-group .multiselect.dropdown-toggle:focus,.frm_wrap textarea:focus{border-color:var(--primary-500) !important;box-shadow:none !important}.wp-admin .frm_fields_container textarea:focus,.wp-admin .frm_fields_container input:focus,.wp-admin .frm_fields_container select:focus{border-color:var(--primary-500);box-shadow:none}#postbox-container-2 textarea,.frm_wrap textarea,.field-group textarea{line-height:2}.frm_wrap input[type=number]{height:auto}.frm_wrap select{padding:2px}.wp-admin .frm_wrap select,#frm-form-templates-modal select{max-width:100%}.frm_form_field.frm_scroll_box .frm_opt_container{padding:10px 12px}.frm_wrap input[disabled],.frm_wrap select[disabled],.frm_wrap textarea[disabled],.frm_wrap input[readonly],.frm_wrap select[readonly],.frm_wrap textarea[readonly],.frm_wrap input::placeholder{color:var(--grey-500)}textarea[id^=frm_calc_]::placeholder{font-size:var(--text-sm);line-height:var(--leading);font-style:italic;color:var(--grey-400);padding-top:5px}.frm_wrap .frm-button-primary.frm-disabled{opacity:.5;cursor:default}#postcustomstuff table td>div{padding-top:0 !important}.wp-admin .frm_wrap .form-table select{vertical-align:top}.frm_wrap .frm_form_builder select{line-height:var(--leading);height:var(--text-md);width:100%}#postbox-container-2 select,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,#frm-form-templates-modal select{height:auto}.frm-white-body .tablenav select,.frm-white-body .tablenav input[type=text],.wp-admin .frm_wrap .tablenav select,.frm_wrap .tablenav input[type=date],.frm_wrap .tablenav input[type=text]{padding-top:0;padding-bottom:0;line-height:1}.frm_wrap .tablenav ::-webkit-datetime-edit{line-height:1}.frm-fields button.btn,.frm-fields textarea,.frm-fields input[type=text],.frm-fields select,.field-group textarea,.field-group input[type=text],.field-group select,.accordion-container input.hex,.frm-fields .frm-input-field{width:100%;outline:0}.frm-fields button.btn{height:var(--h-md);text-align:inherit}.global-font .field-group input[type=text]{width:auto}.wp-core-ui .frm_grey.frm-button-primary.disabled,.wp-core-ui .frm_grey.frm-button-primary,#frm-welcome .frm_grey{opacity:.5;background:#f6f6f6 !important;border-color:#ddd !important;color:#9fa5aa !important}.windows::-webkit-scrollbar,.windows ::-webkit-scrollbar{width:7px;background:rgba(0,0,0,0)}.windows::-webkit-scrollbar-thumb,.windows ::-webkit-scrollbar-thumb{background:var(--grey-300);-webkit-border-radius:var(--border-radius);-webkit-box-shadow:none}.windows::-webkit-scrollbar-corner,.windows ::-webkit-scrollbar-corner{background:rgba(0,0,0,0)}.frm-scrollbar-wrapper,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list,#frm_builder_page #frm_adv_info .frm_code_list,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div,.frm-single-settings .frm_field_opts_list{overflow-x:hidden;overflow-y:auto !important;-ms-overflow-style:none;scrollbar-color:rgba(0,0,0,0) rgba(0,0,0,0);scrollbar-width:thin}.frm-scrollbar-wrapper:hover,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover,#frm_builder_page #frm_adv_info .frm_code_list:hover,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div:hover,.frm-single-settings .frm_field_opts_list:hover{scrollbar-color:var(--grey-300) rgba(0,0,0,0)}.frm-scrollbar-wrapper:hover::-webkit-scrollbar-thumb,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list:hover::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info .frm_code_list:hover::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div:hover::-webkit-scrollbar-thumb,.frm-single-settings .frm_field_opts_list:hover::-webkit-scrollbar-thumb{background:var(--grey-300)}.frm-scrollbar-wrapper::-webkit-scrollbar,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar{width:3px}.frm-scrollbar-wrapper::-webkit-scrollbar-track,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-track,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-track,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar-track,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-track{background:rgba(0,0,0,0);border-radius:100vw}.frm-scrollbar-wrapper::-webkit-scrollbar-thumb,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar-thumb,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb{background:rgba(0,0,0,0);border-radius:100vw}.frm-scrollbar-wrapper::-webkit-scrollbar-thumb:hover,.frm-single-settings .frm_code_list.frm-full-hover.frm-short-list::-webkit-scrollbar-thumb:hover,#frm_builder_page #frm_adv_info .frm_code_list::-webkit-scrollbar-thumb:hover,#frm_builder_page #frm_adv_info #taxonomy-linkcategory>div::-webkit-scrollbar-thumb:hover,.frm-single-settings .frm_field_opts_list::-webkit-scrollbar-thumb:hover{background:var(--grey-300)}.rtl h3{font-weight:inherit !important}.rtl.js .accordion-section-title::after{left:10px;right:auto}.rtl #frm_top_bar #frm_bs_dropdown{padding-left:15px}.rtl .frm-full-close,.rtl .frm_wrap .columns-2 .frm-right-panel+div,.rtl .frm-right-panel{border-left-width:0;border-right:1px solid var(--grey-300)}.rtl .frm-full-close{padding-left:0;padding-right:var(--gap-md)}.rtl .frm-text-right{text-align:left}.rtl .frm_wrap #frm_adv_info ul.category-tabs li:first-child{border-left-width:1px}.rtl .frm-dropdown-menu{text-align:right}.rtl #frm-insert-fields-box,.rtl #frm-conditionals{padding-right:.9em}.rtl #html_settings .frm_field_html_box{margin-right:0}.rtl .frm_list_entry_page h2{float:right}.rtl .frm_scale{float:right;margin-left:10px;margin-right:0}.rtl .frm-page-break .frm-collapse-page.button{margin-left:0;margin-right:46%}.rtl .frm-field-action-icons{right:unset;left:2px}.rtl .frm_has_shortcodes>i{right:auto;left:5px}.rtl p.frm_reply_to_container,.rtl p.frm_bcc_cc_container{float:left}.rtl .frm-with-right-icon:not(.frm-token-container) .frmsvg{right:auto;left:0}.rtl .frm-inline-modal>a.dismiss{left:13px;right:auto}.rtl.wp-admin .frm_wrap select{padding-left:var(--gap-lg) !important;padding-right:5px !important;background-position:left 11px top 55%}.rtl .frm_code_list.frm-full-hover a span{margin-left:var(--gap-xs)}.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:first-child{margin-left:unset;margin-right:var(--gap-xs)}.rtl .frm-style-tabs-wrapper .frm-tabs-navs ul li:last-child{margin-right:unset;margin-left:var(--gap-xs)}.rtl .frm-style-tabs-wrapper .frm-tabs-active-underline{left:unset !important;right:0}.rtl .frm-unit-input .frm-input-group-suffix{right:unset;left:1px;padding-right:unset;padding-left:var(--gap-xs)}.rtl .frm-unit-input .frm-input-group-suffix select{text-align:left;background-position:left 0 top 50%;padding-left:21px !important}span.clear{display:block}.clearfix::after{content:".";display:block;height:0;clear:both;visibility:hidden}.clearfix{display:inline-block}.frm_form_fields .clear{height:auto}* html .clearfix{height:1%}.clearfix{display:block}#frm_small_device_message_container{display:none}@media only screen and (max-width: 1200px){.frm-addons{grid-template-columns:1fr 1fr}#frm_top_bar h1{min-width:0}}@media only screen and (max-width: 1050px){.frm-white-body,.frm_wrap{--biggest-sidebar: 390px}#form_settings_page .columns-2{margin:0}.frm_actions_list{margin-left:0}#frm_bs_dropdown .frm_bstooltip{display:none !important}}@media only screen and (max-width: 960px){.frm-white-body,.frm_wrap{--gap-sm: 8px;--gap-md: 16px;--gap-2xl: 24px}.frm-settings-panel{--gap-sm: 16px;--gap-md: 24px;--gap-2xl: 32px}.auto-fold #adminmenuwrap{width:36px}.frm_wrap #postbox-container-1 #frm_adv_info{min-width:220px}p.howto{display:inline-block}.auto-fold.frm-admin-page-styles:not(.frm-full-screen) .frm_page_container,.auto-fold:not(.frm-full-screen) .frm_wrap .frm_page_container{left:36px}}@media only screen and (max-width: 850px){.frm-white-body,.frm_wrap{--biggest-sidebar: 350px;--big-sidebar: 350px}.frm_col_one{clear:none}.frm-fields p>.frm_inline_label,.frm_inline_label{display:block;margin:5px 0}#frm_top_bar h1{width:auto;max-width:200px}#frm-publishing{width:auto}#frm_form_editor_container,.frm-entry-container{margin:0 20px}.frm_wrap .frm-search{float:none !important;width:auto;clear:both}.post-type-frm_display #frm_adv_info{top:auto !important;position:static;width:auto}.frm_wrap .frm-right-panel #frm_adv_info,.frm_wrap #postbox-container-1 #frm_adv_info{min-width:275px}.frm_wrap #frm_adv_info ul.category-tabs li,.frm_wrap #frm_adv_info ul.category-tabs li.tabs{border:none}.frm_wrap #frm_adv_info ul.category-tabs li:first-child{margin-left:12px}.frm_wrap #frm_adv_info ul.category-tabs li.tabs{border-bottom:2px solid #5b9dd9;padding-bottom:8px}.post-type-frm_display #poststuff{padding:10px 25px}.post-type-frm_display #side-sortables .postbox{margin-bottom:20px;border-radius:var(--small-radius);border-top-width:1px}#frm_top_bar .frm_form_nav{box-shadow:0 -0.47px 10px 0 rgba(16,24,40,.0588235294)}#frm_top_bar ul.frm_form_nav{padding:1em 0;position:fixed;bottom:0;width:100%;background:#fff;z-index:99;transform:translate(-50%, 0);left:50%}.frm_page_container>.columns-2,#frm_styler_wrapper{padding-bottom:64px}#frm_style_preview .frm_floating_style_button:not(.frm_hidden){position:static;display:inline-block}.frm_wrap .columns-2 .frm-right-panel{padding-bottom:0}#frm-publishing{margin-left:auto}#frm_top_bar>.frm-full-close:last-child{margin-left:0}#frm_bs_dropdown{display:block}#frm_bs_dropdown .frm_bstooltip{display:block !important}}@media only screen and (max-width: 782px){.frm-white-body,.frm_wrap{--small-sidebar: 20%;--medium-sidebar: 35%}#form_settings_page .advanced_settings .form-table td,.form-table th{display:table-cell;width:auto !important}.frm-white-body #publishing-action,.frm_wrap #publishing-action{line-height:normal}.frm-white-body #screen-meta-links{display:none}.frm_wrap .misc-pub-section{padding:6px 0}.frm_wrap .misc-pub-section>a{float:none;white-space:nowrap}.frm-form-setting-tabs a{position:relative;padding:10px 5px 10px 40px}.frm-form-setting-tabs a .frmsvg,.frm-form-setting-tabs a i{position:absolute;left:13px;top:calc(50% - 10px);margin:0}#frm-insert-fields .button,#frm-insert-fields .button a,.frmbutton.ui-sortable-helper a{line-height:26px;max-height:28px}a.frm_add_logic_link{margin-left:0;margin-right:0;width:100%;box-sizing:border-box}a.frm_add_logic_link:not([id^=logic_]) .frmsvg,a.frm_add_logic_link i{display:none}#new_fields .frm_single_option select,#new_fields .frm_single_option input[type=text]{width:calc(100% - 83px)}.frm_single_entry_page .frm_form_fields input[type=text],.frm_single_entry_page .frm_form_fields select,.frm_single_entry_page .frm_form_fields textarea{width:100%}.with_frm_style .frm_radio input[type=radio],.with_frm_style .frm_checkbox input[type=checkbox]{width:25px !important}.frm_single_entry_page .with_frm_style .frm_radio input[type=radio],.frm_single_entry_page .with_frm_style .frm_checkbox input[type=checkbox]{width:18px !important}.wp-list-table.toplevel_page_formidable .column-entries,.wp-list-table.toplevel_page_formidable .column-form_key,.wp-list-table.toplevel_page_formidable .column-shortcode,.wp-list-table.toplevel_page_formidable .column-created_at{display:none !important}.wp-list-table.toplevel_page_formidable td.column-entries,.wp-list-table.toplevel_page_formidable td.column-form_key,.wp-list-table.toplevel_page_formidable td.column-shortcode,.wp-list-table.toplevel_page_formidable td.column-created_at{padding:3px 8px 3px 35%;text-align:left}#form_entries_page .wp-list-table th.frm_hidden,#form_entries_page .wp-list-table td.frm_hidden{display:none !important}.frm-white-body.auto-fold #wpcontent{padding-left:0}.frm_right_addon .frm_remove_field{bottom:11px}.frm-addons{grid-template-columns:1fr}.frm-admin-page-styles .frm_page_container,.frm_wrap .frm_page_container{left:0 !important}.frm_single_entry_page.frm_wrap .columns-2{display:block;border-bottom:none}.frm_single_entry_page .wrap.frm-with-margin{margin:10px 20px}.frm_single_entry_page #post-body-content+.frm-right-panel{width:auto;margin:0 20px;border:1px solid var(--sidebar-hover);border-radius:6px}#wp-content-media-buttons a.frm_insert_form{padding:0 var(--gap-sm)}.frm-white-body input[type=checkbox]:checked::before,.frm_wrap input[type=checkbox]:checked::before{width:1.2rem;height:1.2rem}}@media only screen and (max-width: 700px){.frm-white-body,.frm_wrap{--biggest-sidebar: 50%;--big-sidebar: 50%}}@media only screen and (max-width: 600px){.frm-white-body,.frm_wrap{--small-sidebar: 45px}.frm-form-setting-tabs a{visibility:collapse;font-size:0;padding:0 var(--gap-sm)}.frm-form-setting-tabs a .frmsvg,.frm-form-setting-tabs a i{visibility:visible;position:initial;font-size:18px}#frm_builder_page #frm-insert-fields{padding:0}.frm_wrap #frm_adv_info ul.category-tabs li{display:inline-block;padding:0;margin:2px 0;border-bottom:2px solid rgba(0,0,0,0)}.frm_wrap #frm_adv_info ul.category-tabs li.tabs,.frm_wrap #frm_adv_info ul.category-tabs li:first-child{margin-left:0;padding:0}.field_type_list li{text-align:center}#frm-insert-fields li a{padding:5px}#frm_form_editor_container .frm_primary_label{clear:both}#frm_builder_page .frm_code_list a.button{padding:2px}.frm-right-panel h3.accordion-section-title{padding-right:10px;padding-left:10px;font-size:20px;white-space:nowrap;overflow:hidden}.frm-right-panel .accordion-section-title::before{margin-left:0;margin-right:3px}.frm_on_submit_type svg{display:none}}@media only screen and (max-width: 475px){#frm_bs_dropdown{float:none}#frm-nav-tabs{padding:0;white-space:nowrap}#frm-nav-tabs a{margin-right:0}#frm_small_device_message_container{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;top:0;width:100%;height:100%;z-index:999999;background:var(--primary-500)}#frm_small_device_message{text-align:center;display:flex;flex-direction:column;align-items:center;width:80%;padding:1rem;background:#fff;border:solid 1px #fff;border-radius:var(--medium-radius)}#frm_small_device_message::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-78%, -65%);width:900px;height:900px;background-color:#0d7dfc;border-radius:50%;z-index:-1;opacity:.3}#frm_small_device_message>svg{padding-bottom:1rem}.toplevel_page_formidable:has(#frm_small_device_message_container) #posts-filter,.post-type-frm_display:has(#frm_small_device_message_container) #posts-filter{display:none}}@media print{a,.misc-pub-section a{color:#000 !important}.add-new-h2,#frm_top_bar,.dashicons,#adminmenuwrap,#adminmenuback,#wphead,#button_bar,#submitdiv,.button-secondary,#screen-metas,#screen-meta-links,#footer,#wpfooter,.inner-sidebar,.frm_form_nav,.frm_flash_graph,.frm_no_print,object,.error{visibility:hidden;display:none !important}.widget,.postbox,.stuffbox,.postbox h3{border-width:0 !important;border-color:#fff}.postbox{background:#fff !important;border:none;position:static}.postbox h3,.postbox h4{background:#fff !important}#wpbody-content{float:none}#wpcontent,#post-body-content,.has-right-sidebar #post-body,#poststuff .columns-2{margin:0 !important}.frm_wrap #poststuff .columns-2{display:block}#post-body-content+.frm-right-panel,.frm_wrap .columns-2 .frm-right-panel,.frm-right-panel{border:none;width:auto;display:block;padding:20px}.frm_wrap .columns-2,.frm_wrap .frm_page_container{height:auto;display:block}.misc-pub-section>span{padding:0}.frm-right-panel .postbox .inside{padding-left:12px;padding-right:12px}.curtime #timestamp::before{display:none;content:none !important}.frm_charts .alignleft{float:none}.pg_odd,.pg_even{page-break-inside:avoid;max-width:600px}.form-table td,.form-table th{padding:0}.frm_file_container a{display:block;width:100%}}.frm-admin-page-styles #frm-publishing #save_menu_header,.frm-admin-page-styles2 #frm-publishing #save_menu_header{display:inline-block}.edit_form_item .frm_combo_inputs_container[data-name-layout=last_first] .frm_form_subfield-first{order:2}.frm-video-wrapper iframe{width:100%;max-width:843px;border-radius:var(--border-radius)}#frm_field_group_popup{position:absolute;top:0;right:0;width:366px;max-height:231px;border-radius:8px;background:#fff;box-shadow:0 20px 48px rgba(40,47,54,.15);z-index:3;box-sizing:border-box;padding:24px 0;text-align:left}.rtl #frm_field_group_popup{text-align:right}.frm-merge-fields-into-row #frm_field_group_popup{top:unset;bottom:50px;height:196px}#frm_field_group_popup>hr{margin:12px 0}#frm_field_group_popup .frm-cancel-custom-field-group-layout,#frm_field_group_popup .frm-save-custom-field-group-layout{padding:4px 18px}#frm_field_group_popup .frm-cancel-custom-field-group-layout:hover{border-color:var(--primary-500) !important;color:var(--primary-500);background-color:rgba(0,0,0,0) !important}.frm-merge-fields-into-row #frm_field_group_popup .frm-break-field-group{display:none}.frm-merge-fields-into-row>a{color:rgba(40,47,54,.85);position:relative;top:2px}.frm-row-layout-title{font-weight:600;font-size:11px;line-height:15px;text-transform:uppercase;color:rgba(40,47,54,.45);margin-bottom:27px}.frm-row-layout-option{background:#f6f7fb;box-sizing:border-box;border-radius:2px;padding:15px 10px}#frm_field_group_popup .frm-row-layout-option .frm_grid_container{grid-gap:0 5%;grid-template-columns:repeat(12, auto)}#frm_field_group_popup .frm-row-layout-option{cursor:pointer;border:2px solid rgba(0,0,0,0)}#frm_field_group_popup .frm-row-layout-option.frm-active-row-layout,#frm_field_group_popup .frm-row-layout-option:hover{border-color:var(--primary-500)}.frm-custom-field-group-layout,.frm-break-field-group{padding:4px 24px;cursor:pointer;font-size:var(--text-sm);line-height:19px;color:#484e54}.frm-custom-field-group-layout:hover,.frm-break-field-group:hover{background-color:rgba(245,245,245,.9607843137)}.frm-custom-field-group-layout svg,.frm-break-field-group svg{margin-right:5px}#frm_field_multiselect_popup{background:#fff;height:48px;position:fixed;border-radius:4px;box-shadow:0 8px 24px rgba(40,47,54,.15);color:rgba(40,47,54,.85);font-size:13px;right:30px;bottom:10px;z-index:2}#frm_field_multiselect_popup>div{display:inline-block;line-height:48px;vertical-align:top}#frm_field_multiselect_popup.frm-unmergable>.frm-merge-fields-into-row,#frm_field_multiselect_popup.frm-unmergable>.frm-multiselect-popup-separator{display:none}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator){padding:0 20px;cursor:pointer}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator):hover{background:rgba(245,245,245,.9607843137)}.frm-builder-popup-heading{font-weight:600;font-size:11px;line-height:15px;text-transform:uppercase;color:rgba(40,47,54,.45);margin-bottom:7px}.frm-builder-popup-subheading{font-size:12px;line-height:16px;color:rgba(40,47,54,.45)}#frm_field_group_popup input[type=text]{height:30px;border-radius:3px;font-size:14px;padding:8px;color:#545f6e;border-color:rgba(40,47,54,.2)}.frm-multiselect-popup-separator{height:36px;width:1px;position:relative;top:6px;background:#c4c4c4}.frm-sortable-helper,.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider){pointer-events:none}.frm-sortable-helper{z-index:99}#frm_banner{width:100%;color:#fff;background:var(--primary-500);height:40px;line-height:40px;text-align:center;position:relative}.frm-banner-emoji{font-size:19px}.frm-banner-emoji,.frm-banner-title{margin-right:5px;vertical-align:top}.frm-banner-cta a{text-decoration:underline !important}#frm_banner .frm-banner-cta a.frm_inbox_dismiss{display:none}.frm-banner-dismiss{cursor:pointer;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.frm-banner-dismiss .frmsvg{vertical-align:top}.frm-ready-made-solution:not(.frm-search-result){display:none !important}#frm_leave_email_wrapper .frmsvg{top:0}#frm-add-my-email-address{margin-top:30px}.frm-ready-made-solution h3~a{color:var(--primary-500)}.frm-ready-made-solution img{max-width:100%;display:block;box-shadow:var(--box-shadow-lg)}.frm_single_on_submit_settings .frm_form_field{margin:22px 0}.frm_on_submit_type_setting{padding:8px 0}.frm_on_submit_type label{display:flex;border:1px solid var(--grey-border);border-radius:var(--small-radius);gap:16px;padding:16px;align-items:center;justify-content:center}.frm_on_submit_type input{opacity:0 !important;position:absolute;z-index:-1}.frm_on_submit_type input[type=radio]:checked+label{border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-color)}#form_settings_page .frm_on_submit_type label:hover,.frm_on_submit_type input[type=radio]:checked+label svg{color:var(--primary-color)}.frm_pro_tip,.frm-cta{justify-content:space-between;align-items:center;gap:var(--gap-2xl);padding:var(--gap-xs) var(--gap-sm);border-radius:var(--small-radius);background:var(--primary-25)}.frm-cta.frm-cta-border{border:1px solid var(--primary-200)}.frm-cta.frm-cta-border .frm-cta-footer{background-color:#fff;padding:12px var(--gap-sm);border-top:1px solid var(--primary-200);border-bottom-left-radius:var(--small-radius);border-bottom-right-radius:var(--small-radius);margin-top:12px;margin-bottom:calc(-1*var(--gap-sm));margin-left:calc(-1*var(--gap-sm));margin-right:calc(-1*var(--gap-sm))}.frm-cta h4{font-weight:600;margin-top:0;margin-bottom:var(--gap-2xs)}.frm-cta-green{background-color:var(--success-25)}.frm-cta-green .frm-banner-title{gap:calc(var(--gap-2xs) + 1px);color:var(--grey-700)}.frm-cta-green.frm-cta-border{border-color:var(--success-100)}.frm-cta-green.frm-cta-border .frm-cta-footer{border-color:var(--success-100)}.frm-cta-red{background-color:var(--error-25)}.frm-cta-red.frm-cta-border{border-color:var(--error-100)}.frm-cta-icon{padding:3px 15px 3px 0;border-right:1px solid currentColor}#frm-upgrade-banner{gap:0}#frm-upgrade-banner .frm-cta-icon+.frm-cta-content{margin-right:auto;padding-left:15px}#frm-upgrade-banner.frm-gradient h4,#frm-upgrade-banner.frm-gradient p{color:currentColor}#frm-upgrade-banner.frm-gradient h4{font-size:16px;font-weight:600}#frm-upgrade-banner.frm-gradient p{font-size:14px}.frm-right-panel .inside .frm_pro_tip,.frm_pro_tip{color:var(--grey-700);background:#ffe7de;margin:0 auto;display:flex;gap:var(--gap-xs)}.frm_field_list .frm_pro_tip{margin:10px 15px;position:relative;width:calc(100% - 30px);box-sizing:border-box;font-size:14px}.frm_pro_tip .frmsvg,.frm_pro_tip i{color:var(--orange)}.frm-tip-info{flex:1;text-align:left}.frm-tip-cta{color:var(--orange)}.frm-gradient .frm-tip-cta,.frm-light-tip .frm-gradient .frm-tip-cta{color:currentColor;font-weight:700}.frm-tip-badge{font-size:9px;font-weight:700;text-transform:uppercase;color:#1e63d5;background-color:#fff;line-height:1;border-radius:4px;padding:3px 4px}.frm-light-tip .frm_pro_tip{background:var(--primary-25)}.frm-light-tip .frm_pro_tip .frmsvg,.frm-light-tip .frm_pro_tip i,.frm-light-tip .frm-tip-cta{color:var(--primary-500)}.nav-tab-wrapper .frm_pro_tip{float:right}#frm-form-templates-modal textarea{height:108px}#frm-form-templates-modal .frm-fields button.btn{border-color:var(--grey-300);color:var(--grey-900);cursor:pointer}#frm-form-templates-modal .frm-fields button.btn .frmsvg{color:var(--grey-400);width:14px;height:14px}#frm-form-templates-modal .frm-form-templates-modal-fieldset{position:relative}#frm-form-templates-modal .frm-form-templates-modal-fieldset .frm-with-left-icon .frmsvg{padding:0;top:0;left:13px}#frm-form-templates-modal .postbox{display:block !important}#frm_empty_inbox #frm-leave-email-modal{margin-top:var(--gap-2xl)}#frm-name-your-form-modal .frm_modal_top{padding-top:var(--gap-sm)}#frm-field-group-message{position:absolute;bottom:32px;right:calc(50% - var(--biggest-sidebar));padding:var(--gap-xs) var(--gap-sm);border-radius:100px;background-color:var(--primary-25)}#frm-field-group-message .frm-field-group-message-text{gap:10px;color:var(--grey-800)}#frm-field-group-message-dismiss{margin-left:var(--gap-xs)}#frm-field-group-message-dismiss .frmsvg{color:var(--grey-800);width:15px;height:15px;cursor:pointer;transition:color 300ms ease-in-out}#frm-field-group-message-dismiss .frmsvg:hover{color:var(--grey-500)}.frm-card-item{display:flex;border:1px solid var(--grey-200);border-radius:var(--small-radius);padding:var(--gap-sm);box-shadow:var(--box-shadow-xs);background:#fff}.frm-card-item:not(.frm-counter-card){gap:10px}.frm-compact-card-item{padding:var(--gap-sm) 35px 10px 35px}.frm-card-bottom{background-color:var(--grey-50);margin-left:calc(var(--gap-sm)*-1);margin-bottom:calc(var(--gap-sm)*-1);margin-right:calc(var(--gap-sm)*-1);padding:var(--gap-sm);border-radius:0 0 var(--small-radius) var(--small-radius)}#welcome-panel:has(#frm_form_pf_importer){background-color:#fff;margin:var(--gap-sm) var(--gap-md) var(--gap-md);line-height:2}#welcome-panel:has(#frm_form_pf_importer) .welcome-panel-content{text-align:start !important;min-height:unset;display:block}#frm_form_pf_importer div{margin:10px 0 !important}#frm_form_pf_importer button{border:1px solid var(--primary-500);padding:7px 16px;min-height:28px;line-height:var(--leading);margin-bottom:0;background:var(--primary-500);color:#fff !important}#frm_form_pf_importer button:hover{background:#135e96;border-color:#135e96}.frm-option-box{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:500;background-color:#fff;padding:12px var(--gap-sm);border:1px solid var(--grey-200);border-radius:var(--small-radius);margin-bottom:var(--gap-xs);transition:background-color 100ms ease-out;cursor:pointer}.frm-option-box:hover{background-color:var(--grey-25)}.frm-option-box.frm-checked{background-color:var(--primary-25);border-color:var(--primary-200)}.frm-option-box.frm-disabled{cursor:default}.frm-option-box input[type=checkbox]{margin:0}.frm-option-box.frm-disabled input[type=checkbox]{opacity:.5}.frm-option-box .frm_help .frmsvg{width:12px;height:12px}.frm-validation-error:not(.frm_hidden){display:flex}.frm-validation-error{gap:calc(var(--gap-xs) + var(--gap-2xs))}.frm-validation-error span{color:var(--error-500)}.frm-validation-error span[frm-error]{display:none}.frm-validation-error[frm-error=empty] span[frm-error=empty],.frm-validation-error[frm-error=invalid] span[frm-error=invalid],.frm-validation-error[frm-error=custom] span[frm-error=custom]{display:inline-block}.frm-box{padding:var(--gap-sm);border:1px solid var(--grey-200);border-radius:var(--small-radius)}.frm-link-with-external-icon{display:flex;align-items:center;gap:var(--gap-2xs);font-size:var(--text-xs)}.frm-link-with-external-icon .frmsvg{width:16px;height:16px;transform:rotate(45deg)}#wpbody-content .frm-page-skeleton ul,#wpbody-content .frm-page-skeleton li{margin:0}#wpbody-content .frm-page-skeleton .frm-right-panel{padding:2px;overflow-y:initial}#wpbody-content .frm-page-skeleton .frm-scrollbar-wrapper{padding:var(--gap-md) var(--gap-sm)}#wpbody-content .frm-page-skeleton .frm-search{float:none;padding:0 var(--gap-2xs)}#wpbody-content .frm-page-skeleton .frm-search>svg{left:var(--gap-2xs)}#wpbody-content .frm-page-skeleton .frm-search>input{width:100%}.frm-page-skeleton-cat{cursor:pointer;padding:var(--gap-xs);border-radius:var(--small-radius);background-color:rgba(0,0,0,0);transition:background-color 250ms ease-out}.frm-page-skeleton-cat:hover{background-color:var(--grey-100)}.frm-page-skeleton-cat>*{z-index:2}.frm-page-skeleton-cat-text{color:var(--grey-900);text-transform:capitalize}.frm-page-skeleton-cat-count{color:var(--grey-400)}.frm-current .frm-page-skeleton-cat-text,.frm-current .frm-page-skeleton-cat-count{color:var(--primary-500)}.frm-list-grid-layout{display:grid;grid-template-columns:repeat(auto-fill, minmax(303px, 1fr));grid-auto-rows:max-content;gap:var(--gap-sm)}.frm-list-grid-layout>*{grid-column:span 1}#frm-page-skeleton-empty-state{height:100%;margin-top:calc(-1*var(--gap-md))}#frm-page-skeleton-empty-state .frm-page-skeleton-text{max-width:420px}.frm-page-skeleton-divider{border-top:1px solid var(--grey-200);margin:0}.field_type_list .frm_tsubmit{display:none !important}#frm_style_sidebar .accordion-section-title::after,#frm_view_editor_left .accordion-section-title::after{content:""}a[href="#square_settings"] svg.frmsvg{width:23px !important;height:22px !important}#frm_square_test_setup_modal a:focus{box-shadow:none !important}@media only screen and (max-width: 900px){#square_settings .frm_grid_container:has(.frm-card-item){grid-template-columns:repeat(1, 1fr)}#square_settings .frm-card-item+.frm-card-item{margin-top:var(--gap-sm)}}.frm-coupons-upsell-wrapper{display:flex;flex-direction:column;align-items:center}.frm-coupons-upsell-wrapper p{margin-top:var(--gap-xs);max-width:364px;text-align:center}.frm-coupons-upsell-wrapper img{max-width:100%;max-height:300px}.frm-coupons-upsell-wrapper h2{margin-bottom:0}.frm-coupons-upsell{background-color:#f5f5f7;border-radius:16px;border:6px solid #fff;box-shadow:0 .471px 1.412px 0 rgba(16,24,40,.1),0 .471px .941px 0 rgba(16,24,40,.06);text-align:center;width:100%;box-sizing:border-box}.frm-main-coupons-upsell{margin-top:var(--gap-lg)}.frm-main-coupons-upsell img{vertical-align:bottom}.frm-secondary-coupons-upsells{margin-top:var(--gap-md);width:100%}#frm_sale_banner{display:flex;height:90px;flex-direction:row;align-items:center;gap:var(--gap-sm);cursor:pointer;position:relative}#frm_sale_banner>div:first-child{align-self:flex-end;width:150px;height:100%;display:flex;justify-content:center}#frm_sale_banner>div:first-child img{align-self:center}#frm_sale_banner>div:nth-child(3){margin-left:auto;margin-right:50px}#frm_sale_banner>div:nth-child(2)>div:last-child{opacity:.8}#frm_sale_banner a:not(.dismiss){text-shadow:none;border-radius:30px;border:1px rgba(0,0,0,0);font-size:var(--text-sm);padding:7px 16px;height:auto;min-height:28px;outline:none;line-height:var(--leading);box-sizing:border-box;margin-bottom:0;display:inline-block;font-weight:700;background-color:#fff;color:#000}#frm_sale_banner .dismiss{position:absolute;color:#fff;opacity:.6;right:15px;top:10px}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: #fff"]{background-color:#f0f0f0 !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(241, 90, 36, 1)"]{background-color:#e6470f !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(239, 58, 78, 1)"]{background-color:#ed1d34 !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(33, 2, 14, 1)"]{background-color:#3e041a !important}#frm_sale_banner:hover a:not(.dismiss)[style*="background-color: rgba(72, 51, 64, 1)"]{background-color:#362630 !important}.frm-get-free-templates-banner{flex-grow:1}.frm-get-free-templates-banner .frm-banner-image-wrapper{display:flex;justify-content:center;align-items:flex-end;background-color:var(--primary-25);padding:19px 14px 0;border-radius:var(--small-radius)}.frm-get-free-templates-banner[data-direction=vertical]{flex-direction:column;align-items:stretch;gap:12px}.frm-get-free-templates-banner[data-direction=vertical] .frm-banner-content{align-items:center;text-align:center}.frm-lookup-box-label{display:none}.frm-inline-modal[id^=frm-lookup-box]{background-color:rgba(0,0,0,0);border:0;box-shadow:none}.frm-inline-modal[id^=frm-lookup-box] .frm-nav-tabs,.frm-inline-modal[id^=frm-lookup-box] .dismiss{display:none}.frm_single_option a.frm_remove_tag svg,.frm_single_option a.frm_add_opt svg{width:15px;height:15px}#frm_builder_page #frm-options-panel .frm-single-settings.frm-type-ranking .frm_image_styling_frame{margin-left:12px} diff --git a/css/frm_testing_mode.css b/css/frm_testing_mode.css index bde5cf0c9e..56c3c82dc3 100644 --- a/css/frm_testing_mode.css +++ b/css/frm_testing_mode.css @@ -1,2859 +1,3 @@ -/*!********************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./resources/scss/test-mode/frm_testing_mode.scss ***! - \********************************************************************************************************************************************************************************************************************************************/ -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -/** - * Toggle Components - * - * These are the styles for the "Enable Formidable styling" toggle in the visual styler. - * To use this element, you can call the FrmHtmlHelper::toggle function. - */ -.frm_toggle_opt { - padding: 0; - white-space: normal; - display: inline; - vertical-align: middle; - font-weight: 400; -} - -.frm_on_label, -.frm_off_label { - color: var(--grey-700); -} - -.frm_toggle { - position: relative; - display: inline-block; - width: 40px; - height: var(--h-xs); - vertical-align: middle; -} - -.frm_toggle_block { - display: inline-flex !important; - gap: var(--gap-xs); - align-items: center; -} - -.frm_toggle input, -.frm_toggle_block input { - display: none !important; -} - -.frm_toggle_slider { - position: absolute; - cursor: pointer; - top: 0; - left: 0; - right: 0; - bottom: 0; - background-color: var(--grey-200); - transition: 0.4s; - border-radius: 30px; -} - -.frm_toggle_slider::before { - box-sizing: border-box; - content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E"); - position: absolute; - left: 2px; - bottom: 2px; - display: flex; - align-items: center; - justify-content: center; - width: 20px; - height: 20px; - font-size: 20px; - line-height: 20px; - background-color: #fff; - border-radius: 50%; - transition: 0.4s; - box-shadow: var(--box-shadow-md); -} - -input:checked + .frm_toggle .frm_toggle_slider { - background-color: var(--primary-500); -} - -input:focus + .frm_toggle .frm_toggle_slider { - box-shadow: var(--box-shadow-md); -} - -input:checked + .frm_toggle .frm_toggle_slider::before { - transform: translateX(16px); - content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E"); -} - -input[disabled] + .frm_toggle_slider, -input[disabled] + .frm_toggle .frm_toggle_slider { - pointer-events: none; - cursor: text; - opacity: 0.5; -} - -.frm_toggle_opt ~ .frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before { - content: "" !important; /* Don't show x/check if off label included or on builder page */ -} - -.rtl .frm_toggle_opt { - padding: 0 8px; -} - -.rtl .frm_toggle_slider::before { - left: 17px; -} - -.rtl input:checked + .frm_toggle .frm_toggle_slider::before { - transform: none !important; - left: 1px; -} - -/* Deprecated admin toggle */ -.frm_toggle_off, -.frm_toggle_on { - display: none; - color: #fff; - z-index: 999; - position: absolute; - font-size: 10px; - line-height: 20px; - left: 6px; -} - -.frm_toggle_off { - display: inline; - left: auto; - right: 5px; - color: var(--dark-grey); -} - -.frm_toggle_long { - width: 80% !important; - height: 28px; - display: inline-block !important; -} - -.frm_toggle_long .frm_toggle_slider { - background: var(--primary-700); - box-shadow: 0 0 0 2px var(--primary-700); -} - -.frm_toggle_long .frm_toggle_off, -.frm_toggle_long .frm_toggle_on { - width: 50%; - text-align: center; - font-size: 13px; - line-height: 28px; -} - -.frm_toggle_long .frm_toggle_on { - left: 0; -} - -.frm_toggle_long .frm_toggle_off { - right: 0; -} - -.frm_toggle_long .frm_toggle_slider::before { - width: 50%; - left: 0; - top: 0; - border-radius: var(--border-radius) 0 0 var(--border-radius); - height: 100%; - background-color: #fff; - color: var(--primary-color); - content: "" !important; -} - -.frm_toggle_long input:checked + .frm_toggle_slider::before { - transform: translateX(101%); - border-radius: 0 var(--border-radius) var(--border-radius) 0; -} - -input:checked + .frm_toggle_slider + .frm_toggle_on { - display: inline; -} - -input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { - display: none; -} - -.frm_toggle_long .frm_toggle_on, -.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on + .frm_toggle_off { - display: inline; - color: var(--primary-500); - font-weight: 400; -} - -.frm_toggle_long .frm_toggle_off, -.frm_toggle_long input:checked + .frm_toggle_slider + .frm_toggle_on { - color: #fff; - font-weight: 700; -} - -/* End toggle styling */ -/** - * Component: Admin Inputs - */ -.frmdates_add_blackout_date_link, -.frmdates_add_exception_link, -.frm_form_field.frm_scroll_box .frm_opt_container, -.frm-white-body .wrap input[type=text], -.frm-white-body .wrap input[type=search], -.frm-white-body .wrap input[type=number], -.frm-white-body .wrap select, -#frm-form-templates-modal select, -.frm-white-body .wrap textarea, -button.frm_choose_image_box, -#titlediv input[type=text], -.frm-fields button.btn, -.frm_wrap textarea, -.frm_wrap input[type=tel], -.frm_wrap input[type=text], -.frm_wrap input[type=email] .frm_wrap input[type=search], -.frm_wrap input[type=number], -.frm_wrap input[type=date], -.frm_wrap select, -.wp-admin .frm_wrap select, -.field-group textarea, -.field-group input[type=text], -.field-group select, -.frm-fields .frm-input-field { - outline: 0; - box-shadow: var(--box-shadow-xs); - border-radius: var(--small-radius); - padding: 5px 14px; - border-color: var(--grey-300); - color: var(--grey-800); - font-size: var(--text-md); - margin: 0; - background-color: #fff; - line-height: var(--leading); -} - -.frm_input_with_suffix { - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - display: inline-block; - padding-right: 14px; -} - -.frm_input_with_suffix input { - border: 0 !important; - padding-right: 5px !important; -} - -.frm_wrap ::-webkit-datetime-edit { - line-height: var(--leading); -} - -.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus, -.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus, -.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus, -.frm_wrap input:focus, -.frm_wrap select:focus, -.wp-core-ui .frm_wrap select:focus, -#frm-form-templates-modal select:focus, -.frm-btn-group .multiselect.dropdown-toggle:focus, -.frm_wrap textarea:focus { - border-color: var(--primary-500) !important; - box-shadow: none !important; -} - -/* -Pages like Entries and Styles need the border-color and box-shadow properties without the !important flag. -To achieve this, we exclude them above and duplicate these rules specifically for those pages without using !important. -*/ -.wp-admin .frm_fields_container textarea:focus, -.wp-admin .frm_fields_container input:focus, -.wp-admin .frm_fields_container select:focus { - border-color: var(--primary-500); - box-shadow: none; -} - -#postbox-container-2 textarea, -.frm_wrap textarea, -.field-group textarea { - line-height: 2; -} - -.frm_wrap input[type=number] { - height: auto; -} - -.frm_wrap select { - padding: 2px; -} - -.wp-admin .frm_wrap select, -#frm-form-templates-modal select { - max-width: 100%; -} - -.frm_form_field.frm_scroll_box .frm_opt_container { - padding: 10px 12px; -} - -.frm_wrap input[disabled], -.frm_wrap select[disabled], -.frm_wrap textarea[disabled], -.frm_wrap input[readonly], -.frm_wrap select[readonly], -.frm_wrap textarea[readonly], -.frm_wrap input::placeholder { - color: var(--grey-500); -} - -textarea[id^=frm_calc_]::placeholder { - font-size: var(--text-sm); - line-height: var(--leading); - font-style: italic; - color: var(--grey-400); - padding-top: 5px; -} - -.frm_wrap .frm-button-primary.frm-disabled { - opacity: 0.5; - cursor: default; -} - -#postcustomstuff table td > div { - /* To override some inline css in add-on */ - padding-top: 0 !important; -} - -.wp-admin .frm_wrap .form-table select { - vertical-align: top; -} - -.frm_wrap .frm_form_builder select { - line-height: var(--leading); - height: var(--text-md); - width: 100%; -} - -#postbox-container-2 select, -.wp-admin .frm_wrap select, -.frm_wrap .frm_form_builder select, -#frm-form-templates-modal select { - height: auto; -} - -.frm-white-body .tablenav select, -.frm-white-body .tablenav input[type=text], -.wp-admin .frm_wrap .tablenav select, -.frm_wrap .tablenav input[type=date], -.frm_wrap .tablenav input[type=text] { - padding-top: 0; - padding-bottom: 0; - line-height: 1; -} - -.frm_wrap .tablenav ::-webkit-datetime-edit { - line-height: 1; -} - -.frm-fields button.btn, -.frm-fields textarea, -.frm-fields input[type=text], -.frm-fields select, -.field-group textarea, -.field-group input[type=text], -.field-group select, -.accordion-container input.hex, -.frm-fields .frm-input-field { - width: 100%; - outline: 0; -} - -.frm-fields button.btn { - height: var(--h-md); - text-align: inherit; -} - -.global-font .field-group input[type=text] { - width: auto; -} - -/** - * Components - Button - */ -.frm_orange_button, -.frm_reverse_button { - font-size: 12px; - border: 1px solid var(--orange); - color: var(--orange); - font-weight: 600; - padding: 1px 4px; - border-radius: 4px; - background: transparent; -} - -.frm_reverse_button:hover, -.frm_reverse_button:active, -.frm_reverse_button:focus { - color: #fff; - background: var(--orange); - border: 1px solid var(--orange); -} - -.frm_reverse_button { - font-size: 1em; - transition: all 0.2s ease; -} - -.frm-button-primary, -.wp-core-ui .button-primary.frm-button-primary, -.wp-core-ui .button.frm-button-primary, -.frm-button-secondary, -.wp-core-ui .button-secondary.frm-button-secondary, -.wp-core-ui .button.frm-button-secondary, -.frm-white-body .frm-search .button, -.frm-white-body .search-box .button, -.frm-white-body .tablenav .button, -.frm_orange_button, -.toplevel_page_formidable #frm_upgrade_modal .button-primary, -.wp-core-ui.frm-white-body .button-primary, -.wp-core-ui.frm-white-body .button-secondary, -.frm-white-body .button-primary, -.frm-white-body .button-secondary, -#frm-form-button button, -.frm-form-button button, -.frm-preview-buttons button, -.frm-button-red, -.frm-button-tertiary { - text-shadow: none; - box-shadow: none; - border-radius: 30px; - border: 1px solid var(--primary-500); - font-size: var(--text-sm); - transition: all 0.2s ease; - padding: 7px 16px; - height: auto; - min-height: 28px; - outline: none; - line-height: var(--leading); - box-sizing: border-box; - font-weight: 500; - margin-bottom: 0; - display: inline-block; -} - -.frm-button-primary.frm-sharp, -.frm-button-secondary.frm-sharp { - border-radius: 12px !important; -} - -#wpcontent .frm-button-secondary.frm-button-gradient { - position: relative; - border-color: transparent !important; - background-clip: padding-box !important; -} -#wpcontent .frm-button-secondary.frm-button-gradient::before { - content: ""; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - z-index: -1; - margin: -1px; - border-radius: inherit; - background: linear-gradient(90deg, #129efd 0%, #a334fd 100%); - transition: opacity 150ms ease-out; -} -#wpcontent .frm-button-secondary:hover::before { - opacity: 0.5; -} - -.no-js.wp-core-ui .frm-search .button.hide-if-no-js, -.js.wp-core-ui .frm-search .button.hide-if-js { - display: none; -} - -.frm-button-tertiary { - border-color: transparent; - color: var(--primary-500); -} - -.frm-button-tertiary:focus { - outline: none; -} - -.frm-button-tertiary.frm_loading_button::before { - border-right-color: var(--grey); - border-bottom-color: var(--grey); -} - -.frm-button-red, -.frm-button-red:focus { - --primary-color: var(--error-500); - --primary-500: var(--error-500); - --primary-700: var(--error-700); -} - -.frm-button-red:not(.frm-button-tertiary), -.frm-button-red:not(.frm-button-tertiary):focus { - color: #fff !important; -} - -.frm-white-body h2 .button, -.post-type-frm_display h2 .frm-button-primary, -.frm-white-body .tablenav .button, -.frm-button-primary.frm-button-sm, -.frm-button-secondary.frm-button-sm, -.frm-button-tertiary.frm-button-sm, -.frm-button-red.frm-button-sm { - padding: 4px 12px !important; - font-size: var(--text-xs) !important; -} - -.frm_no_style_button { - background: transparent; -} - -.frm-with-icon { - display: flex; - gap: var(--gap-xs); - align-items: center; -} - -.frm-with-icon svg { - opacity: 0.65; /* Get close to grey-500 without overriding hover colors */ -} - -.frm-with-icon.button svg { - height: var(--text-sm); - width: var(--text-sm); -} - -.frm-with-icon.frm-button-sm svg { - height: var(--text-xs); - width: var(--text-xs); -} - -.frm-white-body .button.add_media { - /* Media buttons above RTE */ - padding-left: 12px !important; - padding-right: 12px !important; - font-size: var(--text-xs); - border-radius: var(--border-radius); -} - -.wp-core-ui.frm-white-body #post-query-submit.button, -.wp-core-ui.frm-white-body .button.tablenav-pages-navspan, -.wp-core-ui.frm-white-body .button.first-page, -.wp-core-ui.frm-white-body .button.prev-page, -.wp-core-ui.frm-white-body .button.next-page, -.wp-core-ui.frm-white-body .button.last-page, -.wp-core-ui.frm-white-body .button.action { - background-color: transparent; - border-color: var(--grey-300); - color: var(--grey-700); - border-radius: var(--border-radius); -} - -.post-type-frm_display.wp-core-ui .button-primary, -.frm-button-primary, -.wp-core-ui .button-primary.frm-button-primary, -.frm_single_entry_page #frm-publishing .button-primary { - background-color: var(--primary-500) !important; - color: #fff !important; -} - -.frm-button-primary.frm_large, -.frm-button-secondary.frm_large { - height: auto !important; - padding: 12px 16px !important; -} - -.frm-button-secondary.frm-small, -.frm-button-primary.frm-small { - font-size: var(--text-xs) !important; - height: auto !important; - padding: var(--gap-2xs) 12px !important; -} - -.frm-button-primary i::before { - color: #fff; -} - -.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover, -.frm-button-primary:not([disabled]):hover { - background: var(--primary-700) !important; - border-color: var(--primary-700) !important; -} - -.wp-core-ui .button-primary.frm-button-primary:active { - vertical-align: inherit; -} - -.frm-white-body #search-submit, -#frm-form-button .frm_button_submit, -.frm-form-button .frm_button_submit, -.frm-white-body .frm-preview-buttons button, -.frm-white-body .button:not(.frm-button-primary), -.wp-core-ui.frm-white-body .button-secondary, -.wp-core-ui .button-secondary.frm-button-secondary, -.wp-core-ui .button.frm-button-secondary, -.frm-white-body .frm-button-secondary, -.frm-button-secondary { - color: var(--grey-800); - border-color: var(--grey-300); - background-color: #fff; -} - -#wp-content-media-buttons button, -#wp-content-media-buttons a.button { - border-color: var(--grey-300); -} - -.frm_orange_button { - border-color: #da791d !important; - background: var(--orange); - color: #fff; -} - -.frm-white-body .button:not(.frm-button-primary):focus, -.frm-white-body .button:not(.frm-button-primary):active, -.frm-white-body .frm-button-secondary:hover, -.wp-core-ui.frm-white-body .frm-button-secondary:hover, -.wp-core-ui.frm-white-body .button-secondary:hover, -.wp-core-ui.frm-white-body .button-secondary:focus, -.wp-core-ui.frm-white-body .tablenav .button:hover, -.frm_wrap .preview > .button:hover, -.frm-white-body #search-submit:hover { - border-color: var(--grey-300) !important; - color: var(--grey-800); - background: var(--grey-50) !important; - box-shadow: none !important; - outline: none !important; -} - -.frm-button-primary .frmsvg { - color: #fff; -} - -.frm_wrap .preview i { - font-size: inherit; -} - -.frm-white-body .frm-button-primary:focus, -.frm-white-body .frm-button-primary:active, -#frm-addons-page .button-primary:focus, -#form_global_settings .button-primary:focus, -#frm_upgrade_modal .button-primary:focus { - border-color: var(--primary-700) !important; - background-color: var(--primary-700) !important; - box-shadow: none !important; - outline: none !important; -} - -.frm_wrap .preview > .button:focus, -.frm_orange_button:hover, -.frm_orange_button:focus, -.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover, -.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus, -.toplevel_page_formidable .frm_wrap button.button-primary:hover, -.toplevel_page_formidable .frm_wrap button.button-primary:focus { - outline: none; -} - -.frm_orange_button:hover, -.frm_orange_button:focus { - border-color: var(--orange) !important; - background: transparent; - color: var(--orange); - opacity: 1; -} - -.major-publishing-actions.frm_create_form_header { - padding: 8px 0; -} - -.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner { - font-size: 15px; - background: transparent; -} - -.frm-menu-boxes .frm_blank_form_text { - padding-bottom: 26px; -} - -input.frm_insert_in_template { - font-size: 10px; - width: 98%; - font-weight: 400; -} - -.frm-dismissible a.dismiss:focus { - box-shadow: none; -} - -.frm-dismissible a.dismiss { - top: 10px; - right: 10px; - position: absolute; -} - -.frm-dismissible a.dismiss svg { - color: var(--grey-800); -} - -.frm-btn-unstyled { - font: inherit; - background: none; - border: none; - padding: 0; - cursor: pointer; - outline: inherit; -} -.frm-btn-unstyled:hover, .frm-btn-unstyled:focus, .frm-btn-unstyled:active { - text-decoration: none; - background: none; - border: none; - box-shadow: none; -} -.frm-btn-unstyled:disabled, .frm-btn-unstyled[disabled] { - pointer-events: none; - opacity: 0.65; -} - -/*! +:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_toggle_opt{padding:0;white-space:normal;display:inline;vertical-align:middle;font-weight:400}.frm_on_label,.frm_off_label{color:var(--grey-700)}.frm_toggle{position:relative;display:inline-block;width:40px;height:var(--h-xs);vertical-align:middle}.frm_toggle_block{display:inline-flex !important;gap:var(--gap-xs);align-items:center}.frm_toggle input,.frm_toggle_block input{display:none !important}.frm_toggle_slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--grey-200);transition:.4s;border-radius:30px}.frm_toggle_slider::before{box-sizing:border-box;content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m10.063 3.938-6.126 6.124M3.938 3.938l6.124 6.124'/%3E%3C/svg%3E");position:absolute;left:2px;bottom:2px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:20px;line-height:20px;background-color:#fff;border-radius:50%;transition:.4s;box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider{background-color:var(--primary-500)}input:focus+.frm_toggle .frm_toggle_slider{box-shadow:var(--box-shadow-md)}input:checked+.frm_toggle .frm_toggle_slider::before{transform:translateX(16px);content:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none'%3E%3Cpath stroke='%234199FD' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m4.52 7.437 1.313 1.459L9.48 5.104'/%3E%3C/svg%3E")}input[disabled]+.frm_toggle_slider,input[disabled]+.frm_toggle .frm_toggle_slider{pointer-events:none;cursor:text;opacity:.5}.frm_toggle_opt~.frm_toggle:not(#frm_testing_mode .frm_toggle) .frm_toggle_slider::before{content:"" !important}.rtl .frm_toggle_opt{padding:0 8px}.rtl .frm_toggle_slider::before{left:17px}.rtl input:checked+.frm_toggle .frm_toggle_slider::before{transform:none !important;left:1px}.frm_toggle_off,.frm_toggle_on{display:none;color:#fff;z-index:999;position:absolute;font-size:10px;line-height:20px;left:6px}.frm_toggle_off{display:inline;left:auto;right:5px;color:var(--dark-grey)}.frm_toggle_long{width:80% !important;height:28px;display:inline-block !important}.frm_toggle_long .frm_toggle_slider{background:var(--primary-700);box-shadow:0 0 0 2px var(--primary-700)}.frm_toggle_long .frm_toggle_off,.frm_toggle_long .frm_toggle_on{width:50%;text-align:center;font-size:13px;line-height:28px}.frm_toggle_long .frm_toggle_on{left:0}.frm_toggle_long .frm_toggle_off{right:0}.frm_toggle_long .frm_toggle_slider::before{width:50%;left:0;top:0;border-radius:var(--border-radius) 0 0 var(--border-radius);height:100%;background-color:#fff;color:var(--primary-color);content:"" !important}.frm_toggle_long input:checked+.frm_toggle_slider::before{transform:translateX(101%);border-radius:0 var(--border-radius) var(--border-radius) 0}input:checked+.frm_toggle_slider+.frm_toggle_on{display:inline}input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:none}.frm_toggle_long .frm_toggle_on,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on+.frm_toggle_off{display:inline;color:var(--primary-500);font-weight:400}.frm_toggle_long .frm_toggle_off,.frm_toggle_long input:checked+.frm_toggle_slider+.frm_toggle_on{color:#fff;font-weight:700}.frmdates_add_blackout_date_link,.frmdates_add_exception_link,.frm_form_field.frm_scroll_box .frm_opt_container,.frm-white-body .wrap input[type=text],.frm-white-body .wrap input[type=search],.frm-white-body .wrap input[type=number],.frm-white-body .wrap select,#frm-form-templates-modal select,.frm-white-body .wrap textarea,button.frm_choose_image_box,#titlediv input[type=text],.frm-fields button.btn,.frm_wrap textarea,.frm_wrap input[type=tel],.frm_wrap input[type=text],.frm_wrap input[type=email] .frm_wrap input[type=search],.frm_wrap input[type=number],.frm_wrap input[type=date],.frm_wrap select,.wp-admin .frm_wrap select,.field-group textarea,.field-group input[type=text],.field-group select,.frm-fields .frm-input-field{outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;background-color:#fff;line-height:var(--leading)}.frm_input_with_suffix{border-radius:var(--small-radius);border:1px solid var(--grey-300);display:inline-block;padding-right:14px}.frm_input_with_suffix input{border:0 !important;padding-right:5px !important}.frm_wrap ::-webkit-datetime-edit{line-height:var(--leading)}.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) textarea:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) input:focus,.frm-white-body:not(.frm-admin-page-styles):not(.frm-admin-page-entries) select:focus,.frm_wrap input:focus,.frm_wrap select:focus,.wp-core-ui .frm_wrap select:focus,#frm-form-templates-modal select:focus,.frm-btn-group .multiselect.dropdown-toggle:focus,.frm_wrap textarea:focus{border-color:var(--primary-500) !important;box-shadow:none !important}.wp-admin .frm_fields_container textarea:focus,.wp-admin .frm_fields_container input:focus,.wp-admin .frm_fields_container select:focus{border-color:var(--primary-500);box-shadow:none}#postbox-container-2 textarea,.frm_wrap textarea,.field-group textarea{line-height:2}.frm_wrap input[type=number]{height:auto}.frm_wrap select{padding:2px}.wp-admin .frm_wrap select,#frm-form-templates-modal select{max-width:100%}.frm_form_field.frm_scroll_box .frm_opt_container{padding:10px 12px}.frm_wrap input[disabled],.frm_wrap select[disabled],.frm_wrap textarea[disabled],.frm_wrap input[readonly],.frm_wrap select[readonly],.frm_wrap textarea[readonly],.frm_wrap input::placeholder{color:var(--grey-500)}textarea[id^=frm_calc_]::placeholder{font-size:var(--text-sm);line-height:var(--leading);font-style:italic;color:var(--grey-400);padding-top:5px}.frm_wrap .frm-button-primary.frm-disabled{opacity:.5;cursor:default}#postcustomstuff table td>div{padding-top:0 !important}.wp-admin .frm_wrap .form-table select{vertical-align:top}.frm_wrap .frm_form_builder select{line-height:var(--leading);height:var(--text-md);width:100%}#postbox-container-2 select,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,#frm-form-templates-modal select{height:auto}.frm-white-body .tablenav select,.frm-white-body .tablenav input[type=text],.wp-admin .frm_wrap .tablenav select,.frm_wrap .tablenav input[type=date],.frm_wrap .tablenav input[type=text]{padding-top:0;padding-bottom:0;line-height:1}.frm_wrap .tablenav ::-webkit-datetime-edit{line-height:1}.frm-fields button.btn,.frm-fields textarea,.frm-fields input[type=text],.frm-fields select,.field-group textarea,.field-group input[type=text],.field-group select,.accordion-container input.hex,.frm-fields .frm-input-field{width:100%;outline:0}.frm-fields button.btn{height:var(--h-md);text-align:inherit}.global-font .field-group input[type=text]{width:auto}.frm_orange_button,.frm_reverse_button{font-size:12px;border:1px solid var(--orange);color:var(--orange);font-weight:600;padding:1px 4px;border-radius:4px;background:rgba(0,0,0,0)}.frm_reverse_button:hover,.frm_reverse_button:active,.frm_reverse_button:focus{color:#fff;background:var(--orange);border:1px solid var(--orange)}.frm_reverse_button{font-size:1em;transition:all .2s ease}.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.wp-core-ui .button.frm-button-primary,.frm-button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-search .button,.frm-white-body .search-box .button,.frm-white-body .tablenav .button,.frm_orange_button,.toplevel_page_formidable #frm_upgrade_modal .button-primary,.wp-core-ui.frm-white-body .button-primary,.wp-core-ui.frm-white-body .button-secondary,.frm-white-body .button-primary,.frm-white-body .button-secondary,#frm-form-button button,.frm-form-button button,.frm-preview-buttons button,.frm-button-red,.frm-button-tertiary{text-shadow:none;box-shadow:none;border-radius:30px;border:1px solid var(--primary-500);font-size:var(--text-sm);transition:all .2s ease;padding:7px 16px;height:auto;min-height:28px;outline:none;line-height:var(--leading);box-sizing:border-box;font-weight:500;margin-bottom:0;display:inline-block}.frm-button-primary.frm-sharp,.frm-button-secondary.frm-sharp{border-radius:12px !important}#wpcontent .frm-button-secondary.frm-button-gradient{position:relative;border-color:rgba(0,0,0,0) !important;background-clip:padding-box !important}#wpcontent .frm-button-secondary.frm-button-gradient::before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;margin:-1px;border-radius:inherit;background:linear-gradient(90deg, #129efd 0%, #a334fd 100%);transition:opacity 150ms ease-out}#wpcontent .frm-button-secondary:hover::before{opacity:.5}.no-js.wp-core-ui .frm-search .button.hide-if-no-js,.js.wp-core-ui .frm-search .button.hide-if-js{display:none}.frm-button-tertiary{border-color:rgba(0,0,0,0);color:var(--primary-500)}.frm-button-tertiary:focus{outline:none}.frm-button-tertiary.frm_loading_button::before{border-right-color:var(--grey);border-bottom-color:var(--grey)}.frm-button-red,.frm-button-red:focus{--primary-color: var(--error-500);--primary-500: var(--error-500);--primary-700: var(--error-700)}.frm-button-red:not(.frm-button-tertiary),.frm-button-red:not(.frm-button-tertiary):focus{color:#fff !important}.frm-white-body h2 .button,.post-type-frm_display h2 .frm-button-primary,.frm-white-body .tablenav .button,.frm-button-primary.frm-button-sm,.frm-button-secondary.frm-button-sm,.frm-button-tertiary.frm-button-sm,.frm-button-red.frm-button-sm{padding:4px 12px !important;font-size:var(--text-xs) !important}.frm_no_style_button{background:rgba(0,0,0,0)}.frm-with-icon{display:flex;gap:var(--gap-xs);align-items:center}.frm-with-icon svg{opacity:.65}.frm-with-icon.button svg{height:var(--text-sm);width:var(--text-sm)}.frm-with-icon.frm-button-sm svg{height:var(--text-xs);width:var(--text-xs)}.frm-white-body .button.add_media{padding-left:12px !important;padding-right:12px !important;font-size:var(--text-xs);border-radius:var(--border-radius)}.wp-core-ui.frm-white-body #post-query-submit.button,.wp-core-ui.frm-white-body .button.tablenav-pages-navspan,.wp-core-ui.frm-white-body .button.first-page,.wp-core-ui.frm-white-body .button.prev-page,.wp-core-ui.frm-white-body .button.next-page,.wp-core-ui.frm-white-body .button.last-page,.wp-core-ui.frm-white-body .button.action{background-color:rgba(0,0,0,0);border-color:var(--grey-300);color:var(--grey-700);border-radius:var(--border-radius)}.post-type-frm_display.wp-core-ui .button-primary,.frm-button-primary,.wp-core-ui .button-primary.frm-button-primary,.frm_single_entry_page #frm-publishing .button-primary{background-color:var(--primary-500) !important;color:#fff !important}.frm-button-primary.frm_large,.frm-button-secondary.frm_large{height:auto !important;padding:12px 16px !important}.frm-button-secondary.frm-small,.frm-button-primary.frm-small{font-size:var(--text-xs) !important;height:auto !important;padding:var(--gap-2xs) 12px !important}.frm-button-primary i::before{color:#fff}.wp-core-ui .button-primary.frm-button-primary:not([disabled]):hover,.frm-button-primary:not([disabled]):hover{background:var(--primary-700) !important;border-color:var(--primary-700) !important}.wp-core-ui .button-primary.frm-button-primary:active{vertical-align:inherit}.frm-white-body #search-submit,#frm-form-button .frm_button_submit,.frm-form-button .frm_button_submit,.frm-white-body .frm-preview-buttons button,.frm-white-body .button:not(.frm-button-primary),.wp-core-ui.frm-white-body .button-secondary,.wp-core-ui .button-secondary.frm-button-secondary,.wp-core-ui .button.frm-button-secondary,.frm-white-body .frm-button-secondary,.frm-button-secondary{color:var(--grey-800);border-color:var(--grey-300);background-color:#fff}#wp-content-media-buttons button,#wp-content-media-buttons a.button{border-color:var(--grey-300)}.frm_orange_button{border-color:#da791d !important;background:var(--orange);color:#fff}.frm-white-body .button:not(.frm-button-primary):focus,.frm-white-body .button:not(.frm-button-primary):active,.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .frm-button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:hover,.wp-core-ui.frm-white-body .button-secondary:focus,.wp-core-ui.frm-white-body .tablenav .button:hover,.frm_wrap .preview>.button:hover,.frm-white-body #search-submit:hover{border-color:var(--grey-300) !important;color:var(--grey-800);background:var(--grey-50) !important;box-shadow:none !important;outline:none !important}.frm-button-primary .frmsvg{color:#fff}.frm_wrap .preview i{font-size:inherit}.frm-white-body .frm-button-primary:focus,.frm-white-body .frm-button-primary:active,#frm-addons-page .button-primary:focus,#form_global_settings .button-primary:focus,#frm_upgrade_modal .button-primary:focus{border-color:var(--primary-700) !important;background-color:var(--primary-700) !important;box-shadow:none !important;outline:none !important}.frm_wrap .preview>.button:focus,.frm_orange_button:hover,.frm_orange_button:focus,.toplevel_page_formidable #frm_upgrade_modal .button-primary:hover,.toplevel_page_formidable #frm_upgrade_modal .button-primary:focus,.toplevel_page_formidable .frm_wrap button.button-primary:hover,.toplevel_page_formidable .frm_wrap button.button-primary:focus{outline:none}.frm_orange_button:hover,.frm_orange_button:focus{border-color:var(--orange) !important;background:rgba(0,0,0,0);color:var(--orange);opacity:1}.major-publishing-actions.frm_create_form_header{padding:8px 0}.major-publishing-actions.frm_create_form_header .frm_create_form_header_inner{font-size:15px;background:rgba(0,0,0,0)}.frm-menu-boxes .frm_blank_form_text{padding-bottom:26px}input.frm_insert_in_template{font-size:10px;width:98%;font-weight:400}.frm-dismissible a.dismiss:focus{box-shadow:none}.frm-dismissible a.dismiss{top:10px;right:10px;position:absolute}.frm-dismissible a.dismiss svg{color:var(--grey-800)}.frm-btn-unstyled{font:inherit;background:none;border:none;padding:0;cursor:pointer;outline:inherit}.frm-btn-unstyled:hover,.frm-btn-unstyled:focus,.frm-btn-unstyled:active{text-decoration:none;background:none;border:none;box-shadow:none}.frm-btn-unstyled:disabled,.frm-btn-unstyled[disabled]{pointer-events:none;opacity:.65}/*! * Bootstrap v4.6.1 - */ -.tooltip { - /* Copied from Bootstrap */ - position: absolute; - display: block; - margin: 0; - font-style: normal; - font-weight: 400; - line-height: 1.5; - text-align: left; - text-align: start; - text-decoration: none; - text-shadow: none; - text-transform: none; - letter-spacing: normal; - word-break: normal; - word-spacing: normal; - white-space: normal; - line-break: auto; - font-size: 0.875rem; - word-wrap: break-word; - opacity: 0; - /* Custom rules */ - z-index: 9999999; - pointer-events: none; -} - -.tooltip.show { - opacity: 0.9; -} - -.tooltip .arrow { - position: absolute; - display: block; - width: 0.8rem; - height: 0.4rem; - margin-left: 0 !important; -} - -.tooltip .arrow::before { - position: absolute; - content: ""; - border-color: transparent; - border-style: solid; -} - -.bs-tooltip-top, -.bs-tooltip-auto[x-placement^=top] { - padding: 0.4rem 0; -} - -.bs-tooltip-top .arrow, -.bs-tooltip-auto[x-placement^=top] .arrow { - bottom: 0; -} - -.bs-tooltip-top .arrow::before, -.bs-tooltip-auto[x-placement^=top] .arrow::before { - top: 0; - border-width: 0.4rem 0.4rem 0; - border-top-color: #000; -} - -.bs-tooltip-right, -.bs-tooltip-auto[x-placement^=right] { - padding: 0 0.4rem; -} - -.bs-tooltip-right .arrow, -.bs-tooltip-auto[x-placement^=right] .arrow { - left: 0; - width: 0.4rem; - height: 0.8rem; -} - -.bs-tooltip-right .arrow::before, -.bs-tooltip-auto[x-placement^=right] .arrow::before { - right: 0; - border-width: 0.4rem 0.4rem 0.4rem 0; - border-right-color: #000; -} - -.bs-tooltip-bottom, -.bs-tooltip-auto[x-placement^=bottom] { - padding: 0.4rem 0; -} - -.bs-tooltip-bottom .arrow, -.bs-tooltip-auto[x-placement^=bottom] .arrow { - top: 0; -} - -.bs-tooltip-bottom .arrow::before, -.bs-tooltip-auto[x-placement^=bottom] .arrow::before { - bottom: 0; - border-width: 0 0.4rem 0.4rem; - border-bottom-color: #000; -} - -.bs-tooltip-left, -.bs-tooltip-auto[x-placement^=left] { - padding: 0 0.4rem; -} - -.bs-tooltip-left .arrow, -.bs-tooltip-auto[x-placement^=left] .arrow { - right: 0; - width: 0.4rem; - height: 0.8rem; -} - -.bs-tooltip-left .arrow::before, -.bs-tooltip-auto[x-placement^=left] .arrow::before { - left: 0; - border-width: 0.4rem 0 0.4rem 0.4rem; - border-left-color: #000; -} - -.tooltip-inner { - max-width: 200px; - padding: 0.25rem 0.5rem; - color: #fff; - text-align: center; - background-color: #000; - border-radius: 0.25rem; -} - -.frm-dropdown-menu.show { - display: block; -} - -.frm-single-settings .frm-dropdown-menu.show { - background: #fff; -} - -/* End Bootstrap */ -.preview.dropdown .dropdown-menu { - min-width: 205px; -} - -.frm_clear { - clear: both; -} - -.frm_clearfix::after { - content: "."; - display: block; - clear: both; - visibility: hidden; - line-height: 0; - height: 0; -} - -.frm_clearfix { - display: block; -} - -.frm_admin_progress { - overflow: hidden; - height: 20px; - margin-bottom: 20px; - background-color: #f5f5f5; - border-radius: 4px; - box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1); -} - -.frm_admin_progress_bar { - float: left; - width: 0; - height: 100%; - font-size: 12px; - line-height: 20px; - color: #fff; - text-align: center; - box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.15); - transition: width 0.6s ease; - background-color: #04a4cc; -} - -.tooltip.frm_tooltip { - position: fixed; - top: auto !important; - bottom: 0 !important; - left: 0 !important; - max-width: none; - width: 100% !important; - z-index: 99999; -} - -.tooltip.frm_tooltip.bottom { - padding: 0; -} - -.frm_tooltip .tooltip-inner { - max-width: none; - min-height: 40px !important; - text-align: left; - box-shadow: 5px 5px 25px rgba(0, 0, 0, 0.5); - padding: 10px 40px; - border-top-color: #ccc; - background: var(--sidebar-color); - color: var(--grey-700); - border-radius: 0; - opacity: 1; - font-size: var(--text-sm); -} - -#frm_custom_css_box { - width: 100%; -} - -/** - * Components - Dropdown - */ -/*Switch form dropdown*/ -h1 .fa-caret-down { - font-size: 18px; -} - -.caret { - display: inline-block; - width: 19px; - height: 9px; - margin-right: -8px; - vertical-align: middle; -} - -.caret, -.wp-admin .frm_wrap select, -.frm_wrap .frm_form_builder select, -.frm_wrap .ui-autocomplete-input { - background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; - padding-right: var(--gap-lg) !important; -} - -.caret { - padding-right: var(--gap-xs) !important; - background-position-x: 5px; -} - -.frm-btn-group .caret { - float: right; - margin-top: calc(var(--text-md) / 2); -} - -.dropdown { - position: relative; -} - -.dropdown-toggle:focus { - outline: 0; -} - -.frm_wrap .ui-autocomplete, -#frm_adv_info.frm-dropdown-menu, -.frm-dropdown-menu { - /* Copied from .dropdown-menu rules from Bootstrap */ - position: absolute; - top: 100%; - left: 0; - z-index: 1000; - display: none; - padding-left: 4px; - padding-right: 4px; - margin: var(--gap-xs) 0 0; - text-align: left; - list-style: none; - background: none; - background-color: #fff; - background-clip: padding-box; - border: 1px solid var(--grey-100); - border-radius: 0.25rem; - box-shadow: var(--box-shadow-lg); - /* Custom rules */ - max-height: 200px; - overflow-y: auto; - overflow-x: hidden; - font-size: var(--text-md); - width: auto; - min-width: 160px; -} - -.frm6 .frm-dropdown-menu { - min-width: 100px; - max-width: 99%; -} - -#frm_bs_dropdown .frm-dropdown-menu { - max-width: 400px; -} - -.field_type_list .frm-dropdown-menu { - min-width: 150px !important; -} - -#frm_field_group_controls .frm-dropdown-menu, -.frm-field-action-icons .frm-dropdown-menu { - min-width: 180px !important; -} - -.frm-field-action-icons .frm-dropdown-toggle svg, -#frm_field_group_controls .frm-dropdown-toggle svg { - color: #9ea9b8; -} - -.multiselect-container.frm-dropdown-menu, -#search-submit .frm-dropdown-menu { - min-width: 200px !important; -} - -.preview .frm-dropdown-menu { - min-width: 230px !important; -} - -.frm-dropdown-menu.dropdown-menu-right { - right: 0; - left: auto; -} - -.frm-dropdown-menu .divider { - height: 1px; - margin: 9px 0; - overflow: hidden; - background-color: #e5e5e5; -} - -.frm-dropdown-menu > .dropdown-item { - margin: 0; -} - -.frm-select-list-item, -.frm_wrap .ui-autocomplete li > div, -.multiselect-container button.multiselect-option, -.frm-dropdown-menu > .dropdown-item > a, -.frm-dropdown-menu .frm_dropdown_li { - clear: both; - font-weight: 400; - white-space: nowrap; - text-decoration: none; - border-radius: var(--small-radius); -} - -.frm-dropdown-menu > .active > a, -.frm-dropdown-menu > .active > a:hover, -.frm-dropdown-menu > .active > a:focus { - text-decoration: none; - outline: 0; -} - -.frm-select-list-item.disabled, -.frm-dropdown-menu > .disabled > a, -.frm-dropdown-menu > .disabled > a:hover, -.frm-dropdown-menu > .disabled > a:focus { - color: #999; -} - -.frm-select-list-item.disabled:hover, -.frm-dropdown-menu > .disabled > a:hover, -.frm-dropdown-menu > .disabled > a:focus { - text-decoration: none; - background-color: transparent; - background-image: none; - cursor: not-allowed; -} - -.open > .frm-dropdown-menu { - display: block; -} - -.open > a { - outline: 0; -} - -.dropdown-header { - display: block; - padding: 3px 10px; - font-size: var(--text-xs); - color: var(--grey-400); -} - -.dropdown-backdrop { - position: fixed; - left: 0; - right: 0; - bottom: 0; - top: 0; - z-index: 990; -} - -.dropdown-menu-right > .frm-dropdown-menu, -.pull-right > .frm-dropdown-menu { - right: 0; - left: auto; -} - -.navbar-fixed-bottom .dropdown .caret { - border-top: 0 dotted; - border-bottom: 4px solid #000; - content: ""; -} - -.navbar-fixed-bottom .dropdown .frm-dropdown-menu { - top: auto; - bottom: 100%; - margin-bottom: 1px; -} - -.btn { - border: 1px solid #ddd; - background: #fff; - height: 28px; - line-height: var(--leading); -} - -a.frm_option_icon::before { - color: var(--primary-500); - font-size: 22px; - width: 22px; - height: 22px; -} - -a.frm_option_icon:focus::before, -a.frm_option_icon:hover::before { - color: var(--primary-700); -} - -.frm_top_left .frm-dropdown-toggle { - color: #999; -} - -.frm-card ol { - margin-left: 15px; -} - -.frm-dropdown-toggle { - text-decoration: none; -} - -.frm-card .frm-dropdown-toggle { - border: 1px solid var(--grey-300); - border-radius: var(--small-radius); - font-size: 13px; - color: var(--grey-700); - padding: 7px 20px; -} - -.frm-dropdown-menu .frm_icon_font { - vertical-align: middle; - color: #5f6c72; - margin-right: 3px; -} - -/* BS Multiselect */ -.multiselect-container.frm-dropdown-menu { - top: auto; - left: auto; - font-size: var(--text-sm); - padding: 4px; - margin-bottom: 3px; -} - -/** - * Components - Multiselect - */ -.multiselect-container { - position: absolute; - list-style-type: none; - margin: 0; - padding: 0; - width: 100%; - max-width: 250px; -} - -.multiselect-container button.multiselect-option { - width: 100%; - text-align: left; - border: none; - margin-bottom: 4px; -} - -.multiselect-container button.multiselect-option label { - margin-left: 5px; -} - -.accordion-container .multiselect-container label { - padding: 3px 19px 3px 7px; -} - -.frm-btn-group.btn-group > .btn-group:nth-child(2) > .multiselect.btn { - border-top-left-radius: 4px; - border-bottom-left-radius: 4px; -} - -.frm-btn-group.btn-group, -.frm-btn-group.btn-group-vertical { - display: block; -} - -.multiselect-option label { - max-width: calc(100% - 22px); - text-overflow: ellipsis; - overflow: hidden; - white-space: nowrap; -} - -/** - * Field multiselect popup - */ -#frm_field_multiselect_popup { - background: white; - height: 48px; - position: fixed; - border-radius: 4px; - box-shadow: 0 8px 24px rgba(40, 47, 54, 0.15); - color: rgba(40, 47, 54, 0.85); - font-size: 13px; - right: 30px; - bottom: 10px; - z-index: 2; -} - -#frm_field_multiselect_popup > div { - display: inline-block; - line-height: 48px; - vertical-align: top; -} - -#frm_field_multiselect_popup.frm-unmergable > .frm-merge-fields-into-row, -#frm_field_multiselect_popup.frm-unmergable > .frm-multiselect-popup-separator { - display: none; -} - -#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator) { - padding: 0 20px; - cursor: pointer; -} - -#frm_field_multiselect_popup > div:not(.frm-multiselect-popup-separator):hover { - background: rgba(245, 245, 245, 0.9607843137); -} - -.frm-builder-popup-heading { - font-weight: 600; - font-size: 11px; - line-height: 15px; - text-transform: uppercase; - color: rgba(40, 47, 54, 0.45); - margin-bottom: 7px; -} - -.frm-builder-popup-subheading { - font-size: 12px; - line-height: 16px; - color: rgba(40, 47, 54, 0.45); -} - -#frm_field_group_popup input[type=text] { - height: 30px; - border-radius: 3px; - font-size: 14px; - padding: 8px; - color: rgb(84, 95, 110); - border-color: rgba(40, 47, 54, 0.2); -} - -.frm-multiselect-popup-separator { - height: 36px; - width: 1px; - position: relative; - top: 6px; - background: #c4c4c4; -} - -.frm-sortable-helper, -.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider) { - pointer-events: none; -} - -.frm-sortable-helper { - /* Make sure the item being dragged appears above other form builder fields */ - z-index: 99; -} - -/** - * Component: Code List - */ -.frm_code_list a.button { - display: block; - text-align: center; - font-size: 11px; - overflow: hidden; -} - -#frm-navbarDrop + .frm_code_list.frm-full-hover { - margin: var(--gap-xs) 0 0; - min-width: 300px; - max-height: 256px; -} - -.frm_code_list.frm-full-hover li { - margin: 0; -} - -.frm-select-list-item, -.frm_wrap .ui-autocomplete li > div, -.multiselect-container button.multiselect-option, -.frm-dropdown-menu > .dropdown-item > a, -.frm-dropdown-menu > .dropdown-item > a:visited, -.frm-dropdown-menu > .dropdown-item > a:link, -.frm-dropdown-menu .frm_dropdown_li, -.frm_code_list.frm-full-hover a { - display: flex; - color: var(--grey-700); - padding: 5px 10px; - font-size: var(--text-md); - gap: var(--gap-xs); - align-items: center; -} - -.multiselect-container button.multiselect-option.disabled { - opacity: 0.5; -} - -.frm_code_list.frm-full-hover a span { - max-width: 83px; - margin-right: var(--gap-xs); - margin-left: auto; -} - -.frm_code_list.frm-full-hover a { - border-radius: var(--small-radius); -} -.frm_code_list.frm-full-hover a:not(#frm-insert-condition), -.frm_code_list.frm-full-hover a span { - white-space: nowrap; - overflow: hidden; - text-overflow: ellipsis; -} -.frm_code_list.frm-full-hover a:focus span:last-child { - outline: 1px solid var(--primary-500); - outline-offset: var(--gap-2xs); -} - -.frm_code_list.frm-full-hover.frmcenter a { - display: block; -} - -#frm-layout-classes frm-full-hover a span { - max-width: 45%; -} - -.frm-select-list-item.active, -.frm-select-list-item:hover, -.frm_wrap .ui-autocomplete li div.ui-state-active, -.frm_wrap .ui-autocomplete li.ui-state-focus, -.multiselect-container button.multiselect-option.active, -.multiselect-container button.multiselect-option:hover, -.frm-dropdown-menu > .dropdown-item > a:hover, -.frm_code_list.frm-full-hover a:hover span, -.frm_code_list.frm-full-hover a:hover { - background: var(--primary-25); - color: var(--primary-500); -} - -.frm-select-list-item .frmsvg, -.frm-dropdown-menu > .dropdown-item > a .frmsvg { - opacity: 0.8; -} - -.frm-select-list-item:hover .frmsvg, -.frm-dropdown-menu > .dropdown-item > a:hover .frmsvg { - opacity: 1; -} - -.frm-dropdown-menu.frm_code_list > li > a { - padding: 3px 15px; - width: 300px; -} - -#frm_edit_box_content_modal .frm-with-search, -.frm-dropdown-menu .frm-with-search { - padding: var(--gap-xs) 10px 0; -} - -.frm-dropdown-menu .subsubsub { - padding: 0 10px; -} - -.frm_grid_container { - overflow: visible; -} - -.frm_code_list.frm_grid_container { - grid-gap: var(--gap-xs); -} - -.frm_code_list.frm_grid_container li { - width: auto; - margin: 0; -} - -.frm_code_list.frm_grid_container a { - display: block; - font-size: var(--text-md) !important; - font-weight: 500; - text-align: center; - color: var(--primary-500); - background-color: var(--light-blue); - border: 1px solid var(--primary-300); - border-radius: var(--small-radius); - padding: 10px 0; - box-shadow: var(--box-shadow-sm); -} -.frm_code_list.frm_grid_container a:hover { - background-color: var(--primary-500); - color: #fff; -} -.frm_code_list.frm_grid_container a:focus-visible { - outline: 2px solid var(--primary-500); - outline-offset: -1px; -} - -.frm-single-settings .frm_code_list.frm-full-hover, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { - padding: 0; - margin: var(--gap-xs) -10px 0; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a { - font-size: var(--text-md); - color: var(--grey-900); - padding: var(--gap-xs) 12px; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a span, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span { - margin: 0; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a span:first-child, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:first-child { - max-width: 130px; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a span:last-child, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a span:last-child { - max-width: 120px; - margin-left: auto; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover { - font-weight: 500; -} -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover, -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover .frmsvg, -.frm-single-settings .frm_code_list.frm-full-hover > li > a:hover span, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover .frmsvg, -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover > li > a:hover span { - color: var(--primary-500); -} - -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover { - margin: var(--gap-xs) 0 0; -} -#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg { - width: 20px; - height: 20px; -} - -/** - * Accordion - */ -#post-body-content + .frm-right-panel h3.accordion-section-title { - padding: 7px 10px 8px 14px; - font-size: var(--text-md); - color: var(--grey-700); -} - -.frm-with-line, -.accordion-section-content h4 { - font-size: var(--text-md); - font-weight: 400; - margin: 20px -20px 10px; - padding: 0 20px; - color: var(--grey-700); - position: relative; - border: none !important; -} - -.frm-with-line span, -.accordion-section-content h4 span { - background: #fff; - padding: 0 var(--gap-xs); - position: relative; - display: inline-block; - z-index: 2; -} - -.accordion-section-content h4 span { - background: var(--sidebar-color); -} - -.frm-right-panel .frm-with-line span { - background: var(--sidebar-color) !important; - margin-left: -4px; -} - -.frm-right-panel .frm-inline-modal .frm-with-line span { - background: #fff !important; -} - -.frm-with-line::before, -.accordion-section-content h4::before { - content: ""; - display: block; - position: absolute; - border-bottom: 1px solid var(--grey-300); - left: 0; - width: 100%; - top: 50%; -} - -.control-section .accordion-section-title::after, -.customize-pane-child .accordion-section-title::after { - top: 15px; -} - -.accordion-container .frm-dropdown-menu { - min-width: 40px; -} - -.frm-btn-group .multiselect.dropdown-toggle { - box-sizing: border-box; - min-height: unset; - cursor: pointer; -} - -.accordion-container .frm-dropdown-menu::before, -.accordion-container .multiselect.dropdown-toggle::before { - font-family: "s11-fp" !important; -} - -/** - * Search Inputs - */ -.frm-search input[name=s], -.frm-search .dropdown-toggle, -.frm-search input.frm-search-input { - color: var(--grey-800); - border-color: var(--grey-300); - border-radius: var(--small-radius); - box-shadow: var(--box-shadow-xs); -} -.frm-search input[type=search], -.frm-search input[type=text] { - padding-left: var(--gap-lg) !important; -} -.frm-search .dropdown-toggle { - width: 100%; - float: none; - max-width: 200px; - background: transparent; - padding: 7px; - padding-left: 33px !important; - min-height: 32px; - text-align: inherit; - overflow: hidden; - text-overflow: ellipsis; -} -.frm-search #search-submit a { - color: var(--grey-800); -} -.frm-search #search-submit .caret { - opacity: 0.7; -} - -.frm-white-body .search-box input[name=s], -#wpwrap .frm-search input[type=search] { - flex: 1; - font-size: var(--text-md); - line-height: var(--text-xl); - padding: var(--gap-xs); -} - -span.multiselect-selected-text { - white-space: nowrap; - display: inline-block; - max-width: calc(90% - var(--gap-xs)); - text-overflow: ellipsis; - overflow: hidden; -} - -/** - * Component: Call-to-Action - */ -.frm_pro_tip, -.frm-cta { - justify-content: space-between; - align-items: center; - gap: var(--gap-2xl); - padding: var(--gap-xs) var(--gap-sm); - border-radius: var(--small-radius); - background: var(--primary-25); -} - -.frm-cta.frm-cta-border { - border: 1px solid var(--primary-200); -} - -.frm-cta.frm-cta-border .frm-cta-footer { - background-color: #fff; - padding: 12px var(--gap-sm); - border-top: 1px solid var(--primary-200); - border-bottom-left-radius: var(--small-radius); - border-bottom-right-radius: var(--small-radius); - margin-top: 12px; - margin-bottom: calc(-1 * var(--gap-sm)); - margin-left: calc(-1 * var(--gap-sm)); - margin-right: calc(-1 * var(--gap-sm)); -} - -.frm-cta h4 { - font-weight: 600; - margin-top: 0; - margin-bottom: var(--gap-2xs); -} - -.frm-cta-green { - background-color: var(--success-25); -} - -.frm-cta-green .frm-banner-title { - gap: calc(var(--gap-2xs) + 1px); - color: var(--grey-700); -} - -.frm-cta-green.frm-cta-border { - border-color: var(--success-100); -} - -.frm-cta-green.frm-cta-border .frm-cta-footer { - border-color: var(--success-100); -} - -.frm-cta-red { - background-color: var(--error-25); -} - -.frm-cta-red.frm-cta-border { - border-color: var(--error-100); -} - -.frm-cta-icon { - padding: 3px 15px 3px 0; - border-right: 1px solid currentColor; -} - -#frm-upgrade-banner { - gap: 0; -} - -#frm-upgrade-banner .frm-cta-icon + .frm-cta-content { - margin-right: auto; - padding-left: 15px; -} - -#frm-upgrade-banner.frm-gradient h4, -#frm-upgrade-banner.frm-gradient p { - color: currentColor; -} - -#frm-upgrade-banner.frm-gradient h4 { - font-size: 16px; - font-weight: 600; -} - -#frm-upgrade-banner.frm-gradient p { - font-size: 14px; -} - -.frm-right-panel .inside .frm_pro_tip, -.frm_pro_tip { - color: var(--grey-700); - background: #ffe7de; - margin: 0 auto; - display: flex; - gap: var(--gap-xs); -} - -.frm_field_list .frm_pro_tip { - margin: 10px 15px; - position: relative; - width: calc(100% - 30px); - box-sizing: border-box; - font-size: 14px; -} - -.frm_pro_tip .frmsvg, -.frm_pro_tip i { - color: var(--orange); -} - -.frm-tip-info { - flex: 1; - text-align: left; -} - -.frm-tip-cta { - color: var(--orange); -} - -.frm-gradient .frm-tip-cta, -.frm-light-tip .frm-gradient .frm-tip-cta { - color: currentColor; - font-weight: 700; -} - -.frm-tip-badge { - font-size: 9px; - font-weight: 700; - text-transform: uppercase; - color: #1e63d5; - background-color: #fff; - line-height: 1; - border-radius: 4px; - padding: 3px 4px; -} - -.frm-light-tip .frm_pro_tip { - background: var(--primary-25); -} - -.frm-light-tip .frm_pro_tip .frmsvg, -.frm-light-tip .frm_pro_tip i, -.frm-light-tip .frm-tip-cta { - color: var(--primary-500); -} - -.nav-tab-wrapper .frm_pro_tip { - float: right; -} - -/** - * Components - Upgrade Bar - */ -.frm-gradient, -.frm-upgrade-bar { - background: linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important; - color: #fff !important; - border: 0 !important; -} - -.frm-gradient.frm-button-primary:not([disabled]), -.frm-gradient.frm-button-primary:not([disabled]):hover, -.frm-gradient.frm-button-primary:not([disabled]):focus { - background: linear-gradient(90deg, #1961d5, #816cfa) !important; -} - -.frm-upgrade-bar, -.frm-gradient { - position: relative; -} - -.frm-upgrade-bar::before, -.frm-gradient::before { - content: ""; - display: none; - position: absolute; - top: 0; - right: 0; - bottom: 0; - left: 0; - background-color: rgba(255, 255, 255, 0.1); - z-index: 0; -} - -.frm-upgrade-bar:hover::before, -.frm-gradient:hover::before, -.frm-gradient:focus::before { - display: block; -} - -.frm-upgrade-bar-inner, -.frm-gradient > * { - position: relative; - z-index: 1; -} - -.frm-upgrade-bar { - border-bottom: 1px solid var(--sidebar-hover); - padding: 9px 0; - font-size: 12px; - text-align: center; -} - -.frm-upgrade-bar a { - color: currentColor !important; - text-decoration: underline; -} - -.frm-upgrade-bar a:focus { - outline: 1px dotted var(--sidebar-hover); -} - -.frm-upgrade-bar span { - opacity: 0.9; -} - -/** - * Components - Message Styles - */ -.toplevel_page_formidable #wpbody-content > .error { - margin: 1px; - padding: 5px 12px; -} - -.frm_error_style, -.frm_warning_style, -.frm_note_style2, -.frm_note_style, -.frm_message, -#post-body-content .frm_updated_message, -div.frm_updated_message { - border-radius: var(--small-radius); - background-color: #d5f2dc; - color: #1e561f; - padding: var(--gap-sm) var(--gap-md); - font-size: var(--text-sm); - margin: var(--gap-sm) 0; - text-align: left; -} - -.frm_note_style2 { - background: linear-gradient(90deg, #e9effa, #fcf6fe) padding-box, linear-gradient(90deg, #1961d5, #e8abef) border-box; - border: 1px solid transparent; -} - -#frm_top_bar + .wrap > .frm_updated_message, -#frm_top_bar + .wrap > .frm_warning_style { - display: inline-block; - width: 100%; - box-sizing: border-box; -} - -#post-body-content > .frm_updated_message { - margin: 5px 65px; -} - -#form_global_settings #post-body-content > .frm_updated_message, -#form_global_settings #post-body-content > .frm_warning_style { - margin: 5px 25px; -} - -.frm_error_style { - color: #973937; - background-color: #ebcccc; - clear: both; -} - -.frm_error_style a { - text-decoration: underline; - font-weight: 600; -} - -.frm_error_style svg { - opacity: 0.7; -} - -.frm_warning_style { - color: #7a4d05; - background-color: #fff2d2; -} - -.frm_warning_heading { - font-weight: 700; - margin-bottom: 4px; -} - -/* Warning message dismiss */ -.frm_warning_style { - position: relative; - padding-right: calc(var(--gap-md) + 15px); -} - -body.rtl .frm_warning_style { - padding-right: var(--gap-md); - padding-left: calc(var(--gap-md) + 15px); -} - -.frm-warning-dismiss { - position: absolute; - top: 10px; - right: 10px; - display: flex; - cursor: pointer; - transition: opacity 0.2s ease-out; -} - -body.rtl .frm-warning-dismiss { - left: 10px; - right: auto; -} - -.frm-warning-dismiss:hover { - opacity: 0.8; -} - -.frm-warning-dismiss.frmsvg, -.frm-warning-dismiss.frmsvg svg { - width: 15px; - height: 15px; -} - -.frm_note_style { - background: rgba(188, 224, 253, 0.23); - color: var(--grey-700); -} - -.frm-banner-alert { - text-align: left; - margin: 0; - border-radius: 0; - padding: 10px 0 10px 40px; -} - -.frm-banner-alert a { - color: var(--primary-500); - font-weight: 400; - text-decoration: none; -} - -.frm_updated_message ul, -.frm_updated_message li, -.frm_warning_style ul, -.frm_warning_style li, -.frm_error_style ul, -.frm_error_style li { - margin: 0; -} - -.frm-inline-message { - border: 1px solid var(--primary-700); - border-radius: var(--small-radius); - color: var(--primary-700); - background: #fff; - text-align: center; - padding: 20px; - font-size: var(--text-sm); - line-height: var(--leading); -} - -.frm-inline-message a { - text-decoration: underline; - font-weight: 600; - color: var(--primary-700); -} - -.frm_pro_heading span { - margin-top: 10px; -} - -.frm_pro_heading .alignright { - text-align: right; -} - -.frm-yes { - color: var(--green); - font-size: var(--text-xl); -} - -.frm-nope { - color: var(--grey-400); - font-size: var(--text-xl); -} - -/** - * Components - Modal - */ -.frm-modal:not(#frm-dismissable-cta) .postbox { - max-height: 600px; - overflow: hidden; - margin-bottom: 0; -} - -.frm-modal .postbox .frm_modal_top, -.frm-dialog .frm_common_modal .postbox > div:first-child, -.frm-error-modal .frm_modal_top { - padding: var(--gap-md) var(--gap-md) 0; - position: relative; -} - -.frm-modal h2, -.frm-modal .postbox .inside h2, -.frm-modal .postbox .frm-modal-title, -.frm-dialog .frm_common_modal .postbox > div:first-child > div:first-child, -.frm-error-modal .frm-modal-title { - display: inline-block; - font-size: var(--text-lg); - color: var(--grey-900); - font-weight: 600; - margin: 0; - padding: 0; -} - -.frm-modal h3 { - font-weight: 500; -} - -/* Dismiss icon button */ -.frm-inline-modal > a.dismiss, -.frm-modal .postbox > a.dismiss, -.frm-modal .postbox .frm-modal-title + div:last-child, -.frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { - position: absolute; - top: 19px; - right: 19px; - display: flex; - z-index: 2; -} - -body.rtl .frm-inline-modal > a.dismiss, -body.rtl .frm-modal .postbox > a.dismiss, -body.rtl .frm-modal .postbox .frm-modal-title + div:last-child, -body.rtl .frm-dialog .frm_common_modal .postbox > div:first-child > div:last-child { - right: unset; - left: 30px; -} - -.frm-info-modal .postbox > a.dismiss, -.frm-inline-modal > a.dismiss { - right: 13px; - top: 13px; -} - -.frm-modal .postbox .frm-modal-title + div:last-child a, -.frm-modal a.dismiss .frmsvg, -.frm_common_modal .frm_modal_top a .frmsvg { - color: var(--grey-500); -} - -.frm-modal .postbox .frm-modal-title + div:last-child a:hover, -.frm-modal a.dismiss .frmsvg:hover, -.frm_common_modal .frm_modal_top a .frmsvg:hover { - color: var(--grey-700); -} - -.frm-modal .frm_modal_content > div.inside, -.frm_common_modal .frm_modal_content > div.inside { - padding: var(--gap-md); - margin: 0; - font-size: var(--text-sm); - color: var(--grey-700); -} - -.frm-modal p { - color: var(--grey-900); -} - -.frm_common_modal .postbox { - display: flex; - flex-direction: column; -} - -.frm-modal .postbox > div.inside .cta-inside { - overflow-y: auto; - height: auto; -} - -.frm_modal_footer { - padding: 0 var(--gap-md) var(--gap-sm); - text-align: right; -} - -body.frm-body-with-open-modal { - overflow-y: hidden; -} - -/** - * Component: Dialog - */ -.frm-dialog { - z-index: 100; - padding: 0 !important; - border-radius: 16px; - border: none; - background-color: #fff; - max-width: 100% !important; -} - -.frm-dialog .postbox { - background: transparent; - box-shadow: none; - border: none; - line-height: var(--leading); -} - -.frm-dialog input[type=text], -.frm-dialog textarea { - font-size: var(--text-md); -} - -.frm-dialog textarea { - height: 75px; -} - -.frm-dialog button.frm-button-primary { - margin-right: 10px; -} - -.frm-dialog .frm-sub-label, -.frm-sub-label { - color: var(--grey); - text-transform: none; - padding-left: 8px; -} - -h2 .frm-sub-label { - font-size: var(--text-md); -} - -.frm-views-editor-body .ui-widget-overlay, -.frm-white-body .ui-widget-overlay, -.toplevel_page_formidable .ui-widget-overlay, -body[class*=formidable-payments] .ui-widget-overlay, -body.plugins-php .ui-widget-overlay { - position: fixed; - width: 100%; - height: 100%; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: var(--grey-500); - opacity: 0.5; - z-index: 2; -} - -/** - * Component: Circled Icons - */ -.frm-circled-icon { - width: 60px; - height: 60px; - border-radius: 50%; - background-color: var(--primary-25); -} - -.frm-circled-icon-large { - width: 80px; - height: 80px; -} - -.frm-circled-icon-green { - background-color: var(--success-50); -} - -.frm-circled-icon .frmsvg { - width: 21px; - height: 24px; -} -.frm-circled-icon .frmsvg.frm_svg32 { - width: 32px !important; - height: 32px !important; -} - -.frm-circled-icon-large .frmsvg { - width: 24px; -} - -.frm-circled-icon .frmsvg use { - color: var(--primary-500); -} - -.frm-circled-icon-green .frmsvg use { - color: var(--success-500); -} - -.frm-border-icon { - display: flex; - align-items: center; - justify-content: center; - width: 40px; - height: 40px; - border: 1px solid var(--grey-300); - border-radius: var(--small-radius); -} - -.frm-upgrade-message img { - max-width: 100%; -} - -/** - * Utilities - Flex - */ -.frm-inline-flex, -#wpbody-content .frm-inline-flex { - display: inline-flex; -} - -.frm-flex { - display: flex; -} - -.frm-force-flex { - display: flex !important; -} - -.frm_hidden, -.js .frm-hide-js { - display: none; -} - -.frm-flex-box { - display: flex; - gap: var(--gap-sm); -} - -.frm-flex-col { - display: flex; - flex-direction: column; -} - -.frm-flex-full { - flex: 1; -} - -.frm-force-flex-center, .frm-flex-center { - justify-content: center; - align-items: center; -} - -.frm-flex-center { - display: flex; -} - -.frm-force-flex-center { - display: flex !important; -} - -.frm-shrink-0 { - flex-shrink: 0; -} - -.frm-gap-0 { - gap: 0 !important; -} - -.frm-gap-2xs { - gap: var(--gap-2xs); -} - -.frm-gap-xs { - gap: var(--gap-xs); -} - -.frm-gap-sm { - gap: var(--gap-sm); -} - -.frm-gap-md { - gap: var(--gap-md); -} - -.frm-gap-xl { - gap: var(--gap-xl); -} - -.frm-justify-start { - justify-content: start !important; -} - -.frm-justify-center { - justify-content: center !important; -} - -.frm-justify-between { - justify-content: space-between; -} - -.frm-justify-end { - justify-content: end; -} - -.frm-items-start { - align-items: flex-start; -} - -.frm-items-center { - align-items: center; -} - -.frm-items-stretch { - align-items: stretch; -} - -.frm-self-normal { - align-self: normal; -} - -#wpbody-content .frm-flex-wrap { - flex-wrap: wrap; -} - -.frm-grow { - flex-grow: 1; -} - -.frm-order-first { - order: -9999; -} - -.frm-order-last { - order: 9999; -} - -.frm-order-none { - order: 0; -} - -.frm-h-stack-sm, .frm-h-stack-xs, .frm-h-stack { - display: flex !important; - align-items: center; -} -.frm-h-stack-sm > input[type=checkbox], .frm-h-stack-xs > input[type=checkbox], .frm-h-stack > input[type=checkbox], -.frm-h-stack-sm > input[type=radio], -.frm-h-stack-xs > input[type=radio], -.frm-h-stack > input[type=radio] { - margin: 0 !important; -} - -.frm-h-stack { - gap: var(--gap-2xs); -} - -.frm-h-stack-xs { - gap: var(--gap-xs); -} - -.frm-h-stack-sm { - gap: var(--gap-sm); -} - -.frm-flex-row-reverse { - flex-direction: row-reverse; -} - -/** - * Component: Info Modals - */ -.frm-info-modal a, -.frm-info-modal ul, -.frm-info-modal p, -.frm-info-modal, -.settings-lite-cta a, -.settings-lite-cta ul, -.settings-lite-cta { - color: var(--grey-500); - font-size: var(--text-md); - box-shadow: none !important; -} - -.frm-info-modal h3, -.settings-lite-cta h3 { - font-size: 17px !important; -} - -.frm-green-icons .frmsvg { - color: var(--green); -} - -.frm-info-modal .postbox .inside, -.settings-lite-cta .postbox .inside { - padding: var(--gap-md); - margin: 0; -} - -.cta-inside a { - color: var(--orange); -} - -.info-modal-inside a.frm-standard-link { - color: var(--primary-500); -} - -.info-modal-inside a.frm-standard-link:hover { - color: var(--primary-700); -} - -.frm_no_p_margin > p { - margin: 0; -} - -/** - * Components - Loading - */ -.frm_spinner.frm-wait, -.frm_spinner.spinner { - float: left; - visibility: hidden; - margin: 0 10px; -} - -.frm_visible_spinner.frm-wait, -.frm_visible_spinner.spinner { - visibility: visible; - float: none; -} - -.frm_form_action_settings .frm_spinner.frm-wait, -.frm_form_action_settings .frm_spinner.spinner { - visibility: visible; - float: none; - vertical-align: bottom; -} - -.frm_form_action_settings .frm_loading { - font-size: 15px; - text-align: center; -} - -.frm_ajax_settings_tab .frm-wait, -.frm_ajax_settings_tab .spinner { - visibility: visible; - float: none; - margin-top: 20px; -} - -.wp-core-ui .frm_loading_button.button-primary.frm-button-primary, -.frm_loading_button, -.frm_loading_form.frm_button_submit { - position: relative !important; - opacity: 0.8; - color: transparent !important; - text-shadow: none !important; -} - -.frm_loading_button:hover, -.frm_loading_button:active, -.frm_loading_button:focus, -.frm_loading_form.frm_button_submit:hover, -.frm_loading_form.frm_button_submit:active, -.frm_loading_form.frm_button_submit:focus { - cursor: not-allowed; - color: transparent !important; - outline: none !important; - box-shadow: none; -} - -.frm-wait { - margin: 20px; - width: 20px; - height: 20px; - position: relative; - display: inline-block; -} - -#frm-show-fields .frm-wait:only-child { - position: absolute; - left: 50px; - top: 30px; -} - -.frm-wait::before, -.frm_loading_button::before, -.frm_loading_form.frm_button_submit::before { - content: ""; - display: inline-block; - position: absolute; - background: transparent; - border: 1px solid #fff; - border-top-color: transparent; - border-left-color: transparent; - border-radius: 50%; - box-sizing: border-box; - top: 50%; - left: 50%; - margin-top: -10px; - margin-left: -10px; - width: 20px; - height: 20px; - animation: spin 2s linear infinite; -} - -.frm-wait::before { - border-bottom-color: var(--primary-700); - border-right-color: var(--primary-700); -} - -.frm_loading_button.frm-button-secondary::before { - border-bottom-color: var(--primary-500); - border-right-color: var(--primary-500); -} - -input[type=submit]:focus { - outline: none !important; -} - -/* Effects */ -@keyframes spin { - 0% { - transform: rotate(0deg); - } - 100% { - transform: rotate(360deg); - } -} -.frmsvg { - fill: currentColor; - width: 18px; - height: 18px; - vertical-align: middle; -} - -body.frm_preview_page .ui-widget-overlay { - position: fixed; - width: 100%; - height: 100%; - top: 0; - left: 0; - right: 0; - bottom: 0; - background: var(--grey-500); - opacity: 0.5; - z-index: 2; -} - -#frm_testing_mode { - border-radius: 1rem; - background-color: #fff; - border-color: rgba(0, 0, 0, 0.1019607843); - border-width: 1px; - border-style: solid; - padding: 16px 20px; - margin-bottom: 40px; - position: relative; -} -#frm_testing_mode h2 { - font-size: 18px; - font-weight: 600; - color: rgb(0, 0, 0); - margin-bottom: 0; -} -#frm_testing_mode label { - font-size: 12px; - font-weight: 600; -} -#frm_testing_mode label span.frm_toggle_opt { - color: var(--grey-800); - font-weight: 600; -} -#frm_testing_mode label:not(:first-child) { - margin-left: var(--gap-xs); -} -#frm_testing_mode a.frm_button { - margin-left: auto; - border-radius: 20px; - font-size: 14px; -} -#frm_testing_mode hr { - color: unset; - background: var(--grey-200); - height: 1px; - border: none; -} -#frm_testing_mode > div:nth-of-type(2) { - display: flex; - align-items: center; -} -#frm_testing_mode .multiselect.dropdown-toggle::after { - border: none; -} -#frm_testing_mode .frmsvg { - width: 11px; - height: 11px; - margin-right: var(--gap-2xs); - position: relative; - top: 1px; -} -#frm_testing_mode .frm_toggle_block { - gap: var(--gap-xs); -} -#frm_testing_mode label:not(.frm_toggle_block) { - margin-right: 2px; -} -#frm_testing_mode select { - width: auto !important; - min-height: auto !important; - outline: 0; - box-shadow: var(--box-shadow-xs); - border-radius: var(--small-radius); - border-width: 1px; - padding: 5px 14px; - border-color: var(--grey-300); - color: var(--grey-800); - font-size: var(--text-md); - margin: 0; - line-height: var(--leading); - appearance: none; - background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; - padding-right: var(--gap-lg) !important; -} -#frm_testing_mode select:focus { - background-color: transparent !important; -} -#frm_testing_mode select, -#frm_testing_mode .btn-group button.multiselect.dropdown-toggle { - border-radius: var(--medium-radius); - font-size: 12px; - font-weight: 600; - height: 30px; -} -#frm_testing_mode .btn-group button.multiselect.dropdown-toggle { - padding-top: 0; - padding-bottom: 0; -} -#frm_testing_mode .multiselect-selected-text { - position: relative; - top: 2px; -} -#frm_testing_mode #frm_testmode_fill_in_empty_form_fields { - background-color: var(--primary-500); - color: #fff; - padding: 8px 18px; -} -#frm_testing_mode .frm_help { - vertical-align: top; -} - -#frm_testing_mode .frm-button-secondary:hover, -#frm_testmode_disable_required_fields_modal .frm-button-secondary:hover, -#frm_ai_autofill_error_modal .frm-button-secondary:hover { - border-color: var(--grey-300) !important; - color: var(--grey-800); - background: var(--grey-50) !important; - box-shadow: none !important; - outline: none !important; -} -#frm_testing_mode a, -#frm_testmode_disable_required_fields_modal a, -#frm_ai_autofill_error_modal a { - text-decoration: none; -} - -#frm_testmode_disable_required_fields_modal p { - font-size: 16px; -} - -#frm_test_mode_pagination { - display: inline-block; - margin-left: var(--gap-xs); -} -#frm_test_mode_pagination input[type=button] { - border: 1px solid var(--grey-300); - padding: 8px 12px; - border-radius: 8px; - font-size: 12px; - background-color: #fff; -} -#frm_test_mode_pagination input[type=button].frm_test_mode_active_page { - background-color: var(--primary-500); - border-color: var(--primary-500); - color: #fff; -} -#frm_test_mode_pagination input[type=button]:not(.frm_noallow) { - cursor: pointer; -} - -#frm_testmode_start_over { - position: absolute; - right: 20px; - top: 20px; - background-color: #fff; - color: var(--grey-800); - border-radius: 20px; - padding: 4px 12px; - border-color: var(--grey-300); - font-weight: 600; -} -#frm_testmode_start_over img { - vertical-align: middle; - position: relative; - bottom: 2px; -} - -.frm_noallow { - opacity: 0.5; -} - -#frm_testmode_enabled_form_actions_container { - vertical-align: middle; - display: inline-block; - max-width: 200px; -} - -#frm_testmode_upgrade { - padding: var(--gap-xs) var(--gap-sm); - text-align: center; - font-size: var(--text-xs); - margin-top: var(--gap-sm); - line-height: var(--text-xs); - font-weight: 500; - text-decoration: none; - display: block; - margin-left: -20px; - margin-right: -20px; - margin-bottom: -16px; - border-radius: 0 0 16px 16px; -} - -.frm_warning_style:has(.frm-addon-button) { - display: flex; - padding: var(--gap-sm); - line-height: 40px; -} - -.frm_warning_style .frm-addon-button, -#frm_upgrade_modal a.frm-button-primary { - text-decoration: none; -} - -#frm_upgrade_modal a.frm-button-primary { - cursor: pointer; -} - -.frm-dialog { - z-index: 1001; -} - -.frm-dialog + .ui-widget-overlay { - z-index: 1000; -} - -@media (max-width: 1024px) { - #frm_testing_mode > div > label:not(#frm_quick_jump_label) { - width: 100%; - display: block !important; - margin-left: 0 !important; - } - #frm_testing_mode > div > label:not(#frm_quick_jump_label) { - margin-top: var(--gap-sm); - } - #frm_testmode_fill_in_empty_form_fields { - display: block; - } - #frm_testing_mode > div:nth-of-type(2) { - flex-direction: column; - align-items: normal; - } - #frm_test_mode_pagination { - margin-left: 0; - } -} - -/*# sourceMappingURL=frm_testing_mode.css.map*/ \ No newline at end of file + */.tooltip{position:absolute;display:block;margin:0;font-style:normal;font-weight:400;line-height:1.5;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;white-space:normal;line-break:auto;font-size:.875rem;word-wrap:break-word;opacity:0;z-index:9999999;pointer-events:none}.tooltip.show{opacity:.9}.tooltip .arrow{position:absolute;display:block;width:.8rem;height:.4rem;margin-left:0 !important}.tooltip .arrow::before{position:absolute;content:"";border-color:rgba(0,0,0,0);border-style:solid}.bs-tooltip-top,.bs-tooltip-auto[x-placement^=top]{padding:.4rem 0}.bs-tooltip-top .arrow,.bs-tooltip-auto[x-placement^=top] .arrow{bottom:0}.bs-tooltip-top .arrow::before,.bs-tooltip-auto[x-placement^=top] .arrow::before{top:0;border-width:.4rem .4rem 0;border-top-color:#000}.bs-tooltip-right,.bs-tooltip-auto[x-placement^=right]{padding:0 .4rem}.bs-tooltip-right .arrow,.bs-tooltip-auto[x-placement^=right] .arrow{left:0;width:.4rem;height:.8rem}.bs-tooltip-right .arrow::before,.bs-tooltip-auto[x-placement^=right] .arrow::before{right:0;border-width:.4rem .4rem .4rem 0;border-right-color:#000}.bs-tooltip-bottom,.bs-tooltip-auto[x-placement^=bottom]{padding:.4rem 0}.bs-tooltip-bottom .arrow,.bs-tooltip-auto[x-placement^=bottom] .arrow{top:0}.bs-tooltip-bottom .arrow::before,.bs-tooltip-auto[x-placement^=bottom] .arrow::before{bottom:0;border-width:0 .4rem .4rem;border-bottom-color:#000}.bs-tooltip-left,.bs-tooltip-auto[x-placement^=left]{padding:0 .4rem}.bs-tooltip-left .arrow,.bs-tooltip-auto[x-placement^=left] .arrow{right:0;width:.4rem;height:.8rem}.bs-tooltip-left .arrow::before,.bs-tooltip-auto[x-placement^=left] .arrow::before{left:0;border-width:.4rem 0 .4rem .4rem;border-left-color:#000}.tooltip-inner{max-width:200px;padding:.25rem .5rem;color:#fff;text-align:center;background-color:#000;border-radius:.25rem}.frm-dropdown-menu.show{display:block}.frm-single-settings .frm-dropdown-menu.show{background:#fff}.preview.dropdown .dropdown-menu{min-width:205px}.frm_clear{clear:both}.frm_clearfix::after{content:".";display:block;clear:both;visibility:hidden;line-height:0;height:0}.frm_clearfix{display:block}.frm_admin_progress{overflow:hidden;height:20px;margin-bottom:20px;background-color:#f5f5f5;border-radius:4px;box-shadow:inset 0 1px 2px rgba(0,0,0,.1)}.frm_admin_progress_bar{float:left;width:0;height:100%;font-size:12px;line-height:20px;color:#fff;text-align:center;box-shadow:inset 0 -1px 0 rgba(0,0,0,.15);transition:width .6s ease;background-color:#04a4cc}.tooltip.frm_tooltip{position:fixed;top:auto !important;bottom:0 !important;left:0 !important;max-width:none;width:100% !important;z-index:99999}.tooltip.frm_tooltip.bottom{padding:0}.frm_tooltip .tooltip-inner{max-width:none;min-height:40px !important;text-align:left;box-shadow:5px 5px 25px rgba(0,0,0,.5);padding:10px 40px;border-top-color:#ccc;background:var(--sidebar-color);color:var(--grey-700);border-radius:0;opacity:1;font-size:var(--text-sm)}#frm_custom_css_box{width:100%}h1 .fa-caret-down{font-size:18px}.caret{display:inline-block;width:19px;height:9px;margin-right:-8px;vertical-align:middle}.caret,.wp-admin .frm_wrap select,.frm_wrap .frm_form_builder select,.frm_wrap .ui-autocomplete-input{background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;padding-right:var(--gap-lg) !important}.caret{padding-right:var(--gap-xs) !important;background-position-x:5px}.frm-btn-group .caret{float:right;margin-top:calc(var(--text-md)/2)}.dropdown{position:relative}.dropdown-toggle:focus{outline:0}.frm_wrap .ui-autocomplete,#frm_adv_info.frm-dropdown-menu,.frm-dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;padding-left:4px;padding-right:4px;margin:var(--gap-xs) 0 0;text-align:left;list-style:none;background:none;background-color:#fff;background-clip:padding-box;border:1px solid var(--grey-100);border-radius:.25rem;box-shadow:var(--box-shadow-lg);max-height:200px;overflow-y:auto;overflow-x:hidden;font-size:var(--text-md);width:auto;min-width:160px}.frm6 .frm-dropdown-menu{min-width:100px;max-width:99%}#frm_bs_dropdown .frm-dropdown-menu{max-width:400px}.field_type_list .frm-dropdown-menu{min-width:150px !important}#frm_field_group_controls .frm-dropdown-menu,.frm-field-action-icons .frm-dropdown-menu{min-width:180px !important}.frm-field-action-icons .frm-dropdown-toggle svg,#frm_field_group_controls .frm-dropdown-toggle svg{color:#9ea9b8}.multiselect-container.frm-dropdown-menu,#search-submit .frm-dropdown-menu{min-width:200px !important}.preview .frm-dropdown-menu{min-width:230px !important}.frm-dropdown-menu.dropdown-menu-right{right:0;left:auto}.frm-dropdown-menu .divider{height:1px;margin:9px 0;overflow:hidden;background-color:#e5e5e5}.frm-dropdown-menu>.dropdown-item{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu .frm_dropdown_li{clear:both;font-weight:400;white-space:nowrap;text-decoration:none;border-radius:var(--small-radius)}.frm-dropdown-menu>.active>a,.frm-dropdown-menu>.active>a:hover,.frm-dropdown-menu>.active>a:focus{text-decoration:none;outline:0}.frm-select-list-item.disabled,.frm-dropdown-menu>.disabled>a,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{color:#999}.frm-select-list-item.disabled:hover,.frm-dropdown-menu>.disabled>a:hover,.frm-dropdown-menu>.disabled>a:focus{text-decoration:none;background-color:rgba(0,0,0,0);background-image:none;cursor:not-allowed}.open>.frm-dropdown-menu{display:block}.open>a{outline:0}.dropdown-header{display:block;padding:3px 10px;font-size:var(--text-xs);color:var(--grey-400)}.dropdown-backdrop{position:fixed;left:0;right:0;bottom:0;top:0;z-index:990}.dropdown-menu-right>.frm-dropdown-menu,.pull-right>.frm-dropdown-menu{right:0;left:auto}.navbar-fixed-bottom .dropdown .caret{border-top:0 dotted;border-bottom:4px solid #000;content:""}.navbar-fixed-bottom .dropdown .frm-dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.btn{border:1px solid #ddd;background:#fff;height:28px;line-height:var(--leading)}a.frm_option_icon::before{color:var(--primary-500);font-size:22px;width:22px;height:22px}a.frm_option_icon:focus::before,a.frm_option_icon:hover::before{color:var(--primary-700)}.frm_top_left .frm-dropdown-toggle{color:#999}.frm-card ol{margin-left:15px}.frm-dropdown-toggle{text-decoration:none}.frm-card .frm-dropdown-toggle{border:1px solid var(--grey-300);border-radius:var(--small-radius);font-size:13px;color:var(--grey-700);padding:7px 20px}.frm-dropdown-menu .frm_icon_font{vertical-align:middle;color:#5f6c72;margin-right:3px}.multiselect-container.frm-dropdown-menu{top:auto;left:auto;font-size:var(--text-sm);padding:4px;margin-bottom:3px}.multiselect-container{position:absolute;list-style-type:none;margin:0;padding:0;width:100%;max-width:250px}.multiselect-container button.multiselect-option{width:100%;text-align:left;border:none;margin-bottom:4px}.multiselect-container button.multiselect-option label{margin-left:5px}.accordion-container .multiselect-container label{padding:3px 19px 3px 7px}.frm-btn-group.btn-group>.btn-group:nth-child(2)>.multiselect.btn{border-top-left-radius:4px;border-bottom-left-radius:4px}.frm-btn-group.btn-group,.frm-btn-group.btn-group-vertical{display:block}.multiselect-option label{max-width:calc(100% - 22px);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}#frm_field_multiselect_popup{background:#fff;height:48px;position:fixed;border-radius:4px;box-shadow:0 8px 24px rgba(40,47,54,.15);color:rgba(40,47,54,.85);font-size:13px;right:30px;bottom:10px;z-index:2}#frm_field_multiselect_popup>div{display:inline-block;line-height:48px;vertical-align:top}#frm_field_multiselect_popup.frm-unmergable>.frm-merge-fields-into-row,#frm_field_multiselect_popup.frm-unmergable>.frm-multiselect-popup-separator{display:none}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator){padding:0 20px;cursor:pointer}#frm_field_multiselect_popup>div:not(.frm-multiselect-popup-separator):hover{background:rgba(245,245,245,.9607843137)}.frm-builder-popup-heading{font-weight:600;font-size:11px;line-height:15px;text-transform:uppercase;color:rgba(40,47,54,.45);margin-bottom:7px}.frm-builder-popup-subheading{font-size:12px;line-height:16px;color:rgba(40,47,54,.45)}#frm_field_group_popup input[type=text]{height:30px;border-radius:3px;font-size:14px;padding:8px;color:#545f6e;border-color:rgba(40,47,54,.2)}.frm-multiselect-popup-separator{height:36px;width:1px;position:relative;top:6px;background:#c4c4c4}.frm-sortable-helper,.frm-multiselect-key-is-down li.form-field:not(.edit_field_type_divider){pointer-events:none}.frm-sortable-helper{z-index:99}.frm_code_list a.button{display:block;text-align:center;font-size:11px;overflow:hidden}#frm-navbarDrop+.frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0;min-width:300px;max-height:256px}.frm_code_list.frm-full-hover li{margin:0}.frm-select-list-item,.frm_wrap .ui-autocomplete li>div,.multiselect-container button.multiselect-option,.frm-dropdown-menu>.dropdown-item>a,.frm-dropdown-menu>.dropdown-item>a:visited,.frm-dropdown-menu>.dropdown-item>a:link,.frm-dropdown-menu .frm_dropdown_li,.frm_code_list.frm-full-hover a{display:flex;color:var(--grey-700);padding:5px 10px;font-size:var(--text-md);gap:var(--gap-xs);align-items:center}.multiselect-container button.multiselect-option.disabled{opacity:.5}.frm_code_list.frm-full-hover a span{max-width:83px;margin-right:var(--gap-xs);margin-left:auto}.frm_code_list.frm-full-hover a{border-radius:var(--small-radius)}.frm_code_list.frm-full-hover a:not(#frm-insert-condition),.frm_code_list.frm-full-hover a span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frm_code_list.frm-full-hover a:focus span:last-child{outline:1px solid var(--primary-500);outline-offset:var(--gap-2xs)}.frm_code_list.frm-full-hover.frmcenter a{display:block}#frm-layout-classes frm-full-hover a span{max-width:45%}.frm-select-list-item.active,.frm-select-list-item:hover,.frm_wrap .ui-autocomplete li div.ui-state-active,.frm_wrap .ui-autocomplete li.ui-state-focus,.multiselect-container button.multiselect-option.active,.multiselect-container button.multiselect-option:hover,.frm-dropdown-menu>.dropdown-item>a:hover,.frm_code_list.frm-full-hover a:hover span,.frm_code_list.frm-full-hover a:hover{background:var(--primary-25);color:var(--primary-500)}.frm-select-list-item .frmsvg,.frm-dropdown-menu>.dropdown-item>a .frmsvg{opacity:.8}.frm-select-list-item:hover .frmsvg,.frm-dropdown-menu>.dropdown-item>a:hover .frmsvg{opacity:1}.frm-dropdown-menu.frm_code_list>li>a{padding:3px 15px;width:300px}#frm_edit_box_content_modal .frm-with-search,.frm-dropdown-menu .frm-with-search{padding:var(--gap-xs) 10px 0}.frm-dropdown-menu .subsubsub{padding:0 10px}.frm_grid_container{overflow:visible}.frm_code_list.frm_grid_container{grid-gap:var(--gap-xs)}.frm_code_list.frm_grid_container li{width:auto;margin:0}.frm_code_list.frm_grid_container a{display:block;font-size:var(--text-md) !important;font-weight:500;text-align:center;color:var(--primary-500);background-color:var(--light-blue);border:1px solid var(--primary-300);border-radius:var(--small-radius);padding:10px 0;box-shadow:var(--box-shadow-sm)}.frm_code_list.frm_grid_container a:hover{background-color:var(--primary-500);color:#fff}.frm_code_list.frm_grid_container a:focus-visible{outline:2px solid var(--primary-500);outline-offset:-1px}.frm-single-settings .frm_code_list.frm-full-hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{padding:0;margin:var(--gap-xs) -10px 0}.frm-single-settings .frm_code_list.frm-full-hover>li>a,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a{font-size:var(--text-md);color:var(--grey-900);padding:var(--gap-xs) 12px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span{margin:0}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:first-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:first-child{max-width:130px}.frm-single-settings .frm_code_list.frm-full-hover>li>a span:last-child,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a span:last-child{max-width:120px;margin-left:auto}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover{font-weight:500}.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover .frmsvg,.frm-single-settings .frm_code_list.frm-full-hover>li>a:hover span,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover .frmsvg,#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover>li>a:hover span{color:var(--primary-500)}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover{margin:var(--gap-xs) 0 0}#frm_builder_page #frm_adv_info .frm_code_list.frm-full-hover a .frmsvg{width:20px;height:20px}#post-body-content+.frm-right-panel h3.accordion-section-title{padding:7px 10px 8px 14px;font-size:var(--text-md);color:var(--grey-700)}.frm-with-line,.accordion-section-content h4{font-size:var(--text-md);font-weight:400;margin:20px -20px 10px;padding:0 20px;color:var(--grey-700);position:relative;border:none !important}.frm-with-line span,.accordion-section-content h4 span{background:#fff;padding:0 var(--gap-xs);position:relative;display:inline-block;z-index:2}.accordion-section-content h4 span{background:var(--sidebar-color)}.frm-right-panel .frm-with-line span{background:var(--sidebar-color) !important;margin-left:-4px}.frm-right-panel .frm-inline-modal .frm-with-line span{background:#fff !important}.frm-with-line::before,.accordion-section-content h4::before{content:"";display:block;position:absolute;border-bottom:1px solid var(--grey-300);left:0;width:100%;top:50%}.control-section .accordion-section-title::after,.customize-pane-child .accordion-section-title::after{top:15px}.accordion-container .frm-dropdown-menu{min-width:40px}.frm-btn-group .multiselect.dropdown-toggle{box-sizing:border-box;min-height:unset;cursor:pointer}.accordion-container .frm-dropdown-menu::before,.accordion-container .multiselect.dropdown-toggle::before{font-family:"s11-fp" !important}.frm-search input[name=s],.frm-search .dropdown-toggle,.frm-search input.frm-search-input{color:var(--grey-800);border-color:var(--grey-300);border-radius:var(--small-radius);box-shadow:var(--box-shadow-xs)}.frm-search input[type=search],.frm-search input[type=text]{padding-left:var(--gap-lg) !important}.frm-search .dropdown-toggle{width:100%;float:none;max-width:200px;background:rgba(0,0,0,0);padding:7px;padding-left:33px !important;min-height:32px;text-align:inherit;overflow:hidden;text-overflow:ellipsis}.frm-search #search-submit a{color:var(--grey-800)}.frm-search #search-submit .caret{opacity:.7}.frm-white-body .search-box input[name=s],#wpwrap .frm-search input[type=search]{flex:1;font-size:var(--text-md);line-height:var(--text-xl);padding:var(--gap-xs)}span.multiselect-selected-text{white-space:nowrap;display:inline-block;max-width:calc(90% - var(--gap-xs));text-overflow:ellipsis;overflow:hidden}.frm_pro_tip,.frm-cta{justify-content:space-between;align-items:center;gap:var(--gap-2xl);padding:var(--gap-xs) var(--gap-sm);border-radius:var(--small-radius);background:var(--primary-25)}.frm-cta.frm-cta-border{border:1px solid var(--primary-200)}.frm-cta.frm-cta-border .frm-cta-footer{background-color:#fff;padding:12px var(--gap-sm);border-top:1px solid var(--primary-200);border-bottom-left-radius:var(--small-radius);border-bottom-right-radius:var(--small-radius);margin-top:12px;margin-bottom:calc(-1*var(--gap-sm));margin-left:calc(-1*var(--gap-sm));margin-right:calc(-1*var(--gap-sm))}.frm-cta h4{font-weight:600;margin-top:0;margin-bottom:var(--gap-2xs)}.frm-cta-green{background-color:var(--success-25)}.frm-cta-green .frm-banner-title{gap:calc(var(--gap-2xs) + 1px);color:var(--grey-700)}.frm-cta-green.frm-cta-border{border-color:var(--success-100)}.frm-cta-green.frm-cta-border .frm-cta-footer{border-color:var(--success-100)}.frm-cta-red{background-color:var(--error-25)}.frm-cta-red.frm-cta-border{border-color:var(--error-100)}.frm-cta-icon{padding:3px 15px 3px 0;border-right:1px solid currentColor}#frm-upgrade-banner{gap:0}#frm-upgrade-banner .frm-cta-icon+.frm-cta-content{margin-right:auto;padding-left:15px}#frm-upgrade-banner.frm-gradient h4,#frm-upgrade-banner.frm-gradient p{color:currentColor}#frm-upgrade-banner.frm-gradient h4{font-size:16px;font-weight:600}#frm-upgrade-banner.frm-gradient p{font-size:14px}.frm-right-panel .inside .frm_pro_tip,.frm_pro_tip{color:var(--grey-700);background:#ffe7de;margin:0 auto;display:flex;gap:var(--gap-xs)}.frm_field_list .frm_pro_tip{margin:10px 15px;position:relative;width:calc(100% - 30px);box-sizing:border-box;font-size:14px}.frm_pro_tip .frmsvg,.frm_pro_tip i{color:var(--orange)}.frm-tip-info{flex:1;text-align:left}.frm-tip-cta{color:var(--orange)}.frm-gradient .frm-tip-cta,.frm-light-tip .frm-gradient .frm-tip-cta{color:currentColor;font-weight:700}.frm-tip-badge{font-size:9px;font-weight:700;text-transform:uppercase;color:#1e63d5;background-color:#fff;line-height:1;border-radius:4px;padding:3px 4px}.frm-light-tip .frm_pro_tip{background:var(--primary-25)}.frm-light-tip .frm_pro_tip .frmsvg,.frm-light-tip .frm_pro_tip i,.frm-light-tip .frm-tip-cta{color:var(--primary-500)}.nav-tab-wrapper .frm_pro_tip{float:right}.frm-gradient,.frm-upgrade-bar{background:linear-gradient(90deg, #388cf3, #1961d5, #8c7fd8) !important;color:#fff !important;border:0 !important}.frm-gradient.frm-button-primary:not([disabled]),.frm-gradient.frm-button-primary:not([disabled]):hover,.frm-gradient.frm-button-primary:not([disabled]):focus{background:linear-gradient(90deg, #1961d5, #816cfa) !important}.frm-upgrade-bar,.frm-gradient{position:relative}.frm-upgrade-bar::before,.frm-gradient::before{content:"";display:none;position:absolute;top:0;right:0;bottom:0;left:0;background-color:rgba(255,255,255,.1);z-index:0}.frm-upgrade-bar:hover::before,.frm-gradient:hover::before,.frm-gradient:focus::before{display:block}.frm-upgrade-bar-inner,.frm-gradient>*{position:relative;z-index:1}.frm-upgrade-bar{border-bottom:1px solid var(--sidebar-hover);padding:9px 0;font-size:12px;text-align:center}.frm-upgrade-bar a{color:currentColor !important;text-decoration:underline}.frm-upgrade-bar a:focus{outline:1px dotted var(--sidebar-hover)}.frm-upgrade-bar span{opacity:.9}.toplevel_page_formidable #wpbody-content>.error{margin:1px;padding:5px 12px}.frm_error_style,.frm_warning_style,.frm_note_style2,.frm_note_style,.frm_message,#post-body-content .frm_updated_message,div.frm_updated_message{border-radius:var(--small-radius);background-color:#d5f2dc;color:#1e561f;padding:var(--gap-sm) var(--gap-md);font-size:var(--text-sm);margin:var(--gap-sm) 0;text-align:left}.frm_note_style2{background:linear-gradient(90deg, #e9effa, #fcf6fe) padding-box,linear-gradient(90deg, #1961d5, #e8abef) border-box;border:1px solid rgba(0,0,0,0)}#frm_top_bar+.wrap>.frm_updated_message,#frm_top_bar+.wrap>.frm_warning_style{display:inline-block;width:100%;box-sizing:border-box}#post-body-content>.frm_updated_message{margin:5px 65px}#form_global_settings #post-body-content>.frm_updated_message,#form_global_settings #post-body-content>.frm_warning_style{margin:5px 25px}.frm_error_style{color:#973937;background-color:#ebcccc;clear:both}.frm_error_style a{text-decoration:underline;font-weight:600}.frm_error_style svg{opacity:.7}.frm_warning_style{color:#7a4d05;background-color:#fff2d2}.frm_warning_heading{font-weight:700;margin-bottom:4px}.frm_warning_style{position:relative;padding-right:calc(var(--gap-md) + 15px)}body.rtl .frm_warning_style{padding-right:var(--gap-md);padding-left:calc(var(--gap-md) + 15px)}.frm-warning-dismiss{position:absolute;top:10px;right:10px;display:flex;cursor:pointer;transition:opacity .2s ease-out}body.rtl .frm-warning-dismiss{left:10px;right:auto}.frm-warning-dismiss:hover{opacity:.8}.frm-warning-dismiss.frmsvg,.frm-warning-dismiss.frmsvg svg{width:15px;height:15px}.frm_note_style{background:rgba(188,224,253,.23);color:var(--grey-700)}.frm-banner-alert{text-align:left;margin:0;border-radius:0;padding:10px 0 10px 40px}.frm-banner-alert a{color:var(--primary-500);font-weight:400;text-decoration:none}.frm_updated_message ul,.frm_updated_message li,.frm_warning_style ul,.frm_warning_style li,.frm_error_style ul,.frm_error_style li{margin:0}.frm-inline-message{border:1px solid var(--primary-700);border-radius:var(--small-radius);color:var(--primary-700);background:#fff;text-align:center;padding:20px;font-size:var(--text-sm);line-height:var(--leading)}.frm-inline-message a{text-decoration:underline;font-weight:600;color:var(--primary-700)}.frm_pro_heading span{margin-top:10px}.frm_pro_heading .alignright{text-align:right}.frm-yes{color:var(--green);font-size:var(--text-xl)}.frm-nope{color:var(--grey-400);font-size:var(--text-xl)}.frm-modal:not(#frm-dismissable-cta) .postbox{max-height:600px;overflow:hidden;margin-bottom:0}.frm-modal .postbox .frm_modal_top,.frm-dialog .frm_common_modal .postbox>div:first-child,.frm-error-modal .frm_modal_top{padding:var(--gap-md) var(--gap-md) 0;position:relative}.frm-modal h2,.frm-modal .postbox .inside h2,.frm-modal .postbox .frm-modal-title,.frm-dialog .frm_common_modal .postbox>div:first-child>div:first-child,.frm-error-modal .frm-modal-title{display:inline-block;font-size:var(--text-lg);color:var(--grey-900);font-weight:600;margin:0;padding:0}.frm-modal h3{font-weight:500}.frm-inline-modal>a.dismiss,.frm-modal .postbox>a.dismiss,.frm-modal .postbox .frm-modal-title+div:last-child,.frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{position:absolute;top:19px;right:19px;display:flex;z-index:2}body.rtl .frm-inline-modal>a.dismiss,body.rtl .frm-modal .postbox>a.dismiss,body.rtl .frm-modal .postbox .frm-modal-title+div:last-child,body.rtl .frm-dialog .frm_common_modal .postbox>div:first-child>div:last-child{right:unset;left:30px}.frm-info-modal .postbox>a.dismiss,.frm-inline-modal>a.dismiss{right:13px;top:13px}.frm-modal .postbox .frm-modal-title+div:last-child a,.frm-modal a.dismiss .frmsvg,.frm_common_modal .frm_modal_top a .frmsvg{color:var(--grey-500)}.frm-modal .postbox .frm-modal-title+div:last-child a:hover,.frm-modal a.dismiss .frmsvg:hover,.frm_common_modal .frm_modal_top a .frmsvg:hover{color:var(--grey-700)}.frm-modal .frm_modal_content>div.inside,.frm_common_modal .frm_modal_content>div.inside{padding:var(--gap-md);margin:0;font-size:var(--text-sm);color:var(--grey-700)}.frm-modal p{color:var(--grey-900)}.frm_common_modal .postbox{display:flex;flex-direction:column}.frm-modal .postbox>div.inside .cta-inside{overflow-y:auto;height:auto}.frm_modal_footer{padding:0 var(--gap-md) var(--gap-sm);text-align:right}body.frm-body-with-open-modal{overflow-y:hidden}.frm-dialog{z-index:100;padding:0 !important;border-radius:16px;border:none;background-color:#fff;max-width:100% !important}.frm-dialog .postbox{background:rgba(0,0,0,0);box-shadow:none;border:none;line-height:var(--leading)}.frm-dialog input[type=text],.frm-dialog textarea{font-size:var(--text-md)}.frm-dialog textarea{height:75px}.frm-dialog button.frm-button-primary{margin-right:10px}.frm-dialog .frm-sub-label,.frm-sub-label{color:var(--grey);text-transform:none;padding-left:8px}h2 .frm-sub-label{font-size:var(--text-md)}.frm-views-editor-body .ui-widget-overlay,.frm-white-body .ui-widget-overlay,.toplevel_page_formidable .ui-widget-overlay,body[class*=formidable-payments] .ui-widget-overlay,body.plugins-php .ui-widget-overlay{position:fixed;width:100%;height:100%;top:0;left:0;right:0;bottom:0;background:var(--grey-500);opacity:.5;z-index:2}.frm-circled-icon{width:60px;height:60px;border-radius:50%;background-color:var(--primary-25)}.frm-circled-icon-large{width:80px;height:80px}.frm-circled-icon-green{background-color:var(--success-50)}.frm-circled-icon .frmsvg{width:21px;height:24px}.frm-circled-icon .frmsvg.frm_svg32{width:32px !important;height:32px !important}.frm-circled-icon-large .frmsvg{width:24px}.frm-circled-icon .frmsvg use{color:var(--primary-500)}.frm-circled-icon-green .frmsvg use{color:var(--success-500)}.frm-border-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--grey-300);border-radius:var(--small-radius)}.frm-upgrade-message img{max-width:100%}.frm-inline-flex,#wpbody-content .frm-inline-flex{display:inline-flex}.frm-flex{display:flex}.frm-force-flex{display:flex !important}.frm_hidden,.js .frm-hide-js{display:none}.frm-flex-box{display:flex;gap:var(--gap-sm)}.frm-flex-col{display:flex;flex-direction:column}.frm-flex-full{flex:1}.frm-force-flex-center,.frm-flex-center{justify-content:center;align-items:center}.frm-flex-center{display:flex}.frm-force-flex-center{display:flex !important}.frm-shrink-0{flex-shrink:0}.frm-gap-0{gap:0 !important}.frm-gap-2xs{gap:var(--gap-2xs)}.frm-gap-xs{gap:var(--gap-xs)}.frm-gap-sm{gap:var(--gap-sm)}.frm-gap-md{gap:var(--gap-md)}.frm-gap-xl{gap:var(--gap-xl)}.frm-justify-start{justify-content:start !important}.frm-justify-center{justify-content:center !important}.frm-justify-between{justify-content:space-between}.frm-justify-end{justify-content:end}.frm-items-start{align-items:flex-start}.frm-items-center{align-items:center}.frm-items-stretch{align-items:stretch}.frm-self-normal{align-self:normal}#wpbody-content .frm-flex-wrap{flex-wrap:wrap}.frm-grow{flex-grow:1}.frm-order-first{order:-9999}.frm-order-last{order:9999}.frm-order-none{order:0}.frm-h-stack-sm,.frm-h-stack-xs,.frm-h-stack{display:flex !important;align-items:center}.frm-h-stack-sm>input[type=checkbox],.frm-h-stack-xs>input[type=checkbox],.frm-h-stack>input[type=checkbox],.frm-h-stack-sm>input[type=radio],.frm-h-stack-xs>input[type=radio],.frm-h-stack>input[type=radio]{margin:0 !important}.frm-h-stack{gap:var(--gap-2xs)}.frm-h-stack-xs{gap:var(--gap-xs)}.frm-h-stack-sm{gap:var(--gap-sm)}.frm-flex-row-reverse{flex-direction:row-reverse}.frm-info-modal a,.frm-info-modal ul,.frm-info-modal p,.frm-info-modal,.settings-lite-cta a,.settings-lite-cta ul,.settings-lite-cta{color:var(--grey-500);font-size:var(--text-md);box-shadow:none !important}.frm-info-modal h3,.settings-lite-cta h3{font-size:17px !important}.frm-green-icons .frmsvg{color:var(--green)}.frm-info-modal .postbox .inside,.settings-lite-cta .postbox .inside{padding:var(--gap-md);margin:0}.cta-inside a{color:var(--orange)}.info-modal-inside a.frm-standard-link{color:var(--primary-500)}.info-modal-inside a.frm-standard-link:hover{color:var(--primary-700)}.frm_no_p_margin>p{margin:0}.frm_spinner.frm-wait,.frm_spinner.spinner{float:left;visibility:hidden;margin:0 10px}.frm_visible_spinner.frm-wait,.frm_visible_spinner.spinner{visibility:visible;float:none}.frm_form_action_settings .frm_spinner.frm-wait,.frm_form_action_settings .frm_spinner.spinner{visibility:visible;float:none;vertical-align:bottom}.frm_form_action_settings .frm_loading{font-size:15px;text-align:center}.frm_ajax_settings_tab .frm-wait,.frm_ajax_settings_tab .spinner{visibility:visible;float:none;margin-top:20px}.wp-core-ui .frm_loading_button.button-primary.frm-button-primary,.frm_loading_button,.frm_loading_form.frm_button_submit{position:relative !important;opacity:.8;color:rgba(0,0,0,0) !important;text-shadow:none !important}.frm_loading_button:hover,.frm_loading_button:active,.frm_loading_button:focus,.frm_loading_form.frm_button_submit:hover,.frm_loading_form.frm_button_submit:active,.frm_loading_form.frm_button_submit:focus{cursor:not-allowed;color:rgba(0,0,0,0) !important;outline:none !important;box-shadow:none}.frm-wait{margin:20px;width:20px;height:20px;position:relative;display:inline-block}#frm-show-fields .frm-wait:only-child{position:absolute;left:50px;top:30px}.frm-wait::before,.frm_loading_button::before,.frm_loading_form.frm_button_submit::before{content:"";display:inline-block;position:absolute;background:rgba(0,0,0,0);border:1px solid #fff;border-top-color:rgba(0,0,0,0);border-left-color:rgba(0,0,0,0);border-radius:50%;box-sizing:border-box;top:50%;left:50%;margin-top:-10px;margin-left:-10px;width:20px;height:20px;animation:spin 2s linear infinite}.frm-wait::before{border-bottom-color:var(--primary-700);border-right-color:var(--primary-700)}.frm_loading_button.frm-button-secondary::before{border-bottom-color:var(--primary-500);border-right-color:var(--primary-500)}input[type=submit]:focus{outline:none !important}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.frmsvg{fill:currentColor;width:18px;height:18px;vertical-align:middle}body.frm_preview_page .ui-widget-overlay{position:fixed;width:100%;height:100%;top:0;left:0;right:0;bottom:0;background:var(--grey-500);opacity:.5;z-index:2}#frm_testing_mode{border-radius:1rem;background-color:#fff;border-color:rgba(0,0,0,.1019607843);border-width:1px;border-style:solid;padding:16px 20px;margin-bottom:40px;position:relative}#frm_testing_mode h2{font-size:18px;font-weight:600;color:#000;margin-bottom:0}#frm_testing_mode label{font-size:12px;font-weight:600}#frm_testing_mode label span.frm_toggle_opt{color:var(--grey-800);font-weight:600}#frm_testing_mode label:not(:first-child){margin-left:var(--gap-xs)}#frm_testing_mode a.frm_button{margin-left:auto;border-radius:20px;font-size:14px}#frm_testing_mode hr{color:unset;background:var(--grey-200);height:1px;border:none}#frm_testing_mode>div:nth-of-type(2){display:flex;align-items:center}#frm_testing_mode .multiselect.dropdown-toggle::after{border:none}#frm_testing_mode .frmsvg{width:11px;height:11px;margin-right:var(--gap-2xs);position:relative;top:1px}#frm_testing_mode .frm_toggle_block{gap:var(--gap-xs)}#frm_testing_mode label:not(.frm_toggle_block){margin-right:2px}#frm_testing_mode select{width:auto !important;min-height:auto !important;outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);border-width:1px;padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;line-height:var(--leading);appearance:none;background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;padding-right:var(--gap-lg) !important}#frm_testing_mode select:focus{background-color:rgba(0,0,0,0) !important}#frm_testing_mode select,#frm_testing_mode .btn-group button.multiselect.dropdown-toggle{border-radius:var(--medium-radius);font-size:12px;font-weight:600;height:30px}#frm_testing_mode .btn-group button.multiselect.dropdown-toggle{padding-top:0;padding-bottom:0}#frm_testing_mode .multiselect-selected-text{position:relative;top:2px}#frm_testing_mode #frm_testmode_fill_in_empty_form_fields{background-color:var(--primary-500);color:#fff;padding:8px 18px}#frm_testing_mode .frm_help{vertical-align:top}#frm_testing_mode .frm-button-secondary:hover,#frm_testmode_disable_required_fields_modal .frm-button-secondary:hover,#frm_ai_autofill_error_modal .frm-button-secondary:hover{border-color:var(--grey-300) !important;color:var(--grey-800);background:var(--grey-50) !important;box-shadow:none !important;outline:none !important}#frm_testing_mode a,#frm_testmode_disable_required_fields_modal a,#frm_ai_autofill_error_modal a{text-decoration:none}#frm_testmode_disable_required_fields_modal p{font-size:16px}#frm_test_mode_pagination{display:inline-block;margin-left:var(--gap-xs)}#frm_test_mode_pagination input[type=button]{border:1px solid var(--grey-300);padding:8px 12px;border-radius:8px;font-size:12px;background-color:#fff}#frm_test_mode_pagination input[type=button].frm_test_mode_active_page{background-color:var(--primary-500);border-color:var(--primary-500);color:#fff}#frm_test_mode_pagination input[type=button]:not(.frm_noallow){cursor:pointer}#frm_testmode_start_over{position:absolute;right:20px;top:20px;background-color:#fff;color:var(--grey-800);border-radius:20px;padding:4px 12px;border-color:var(--grey-300);font-weight:600}#frm_testmode_start_over img{vertical-align:middle;position:relative;bottom:2px}.frm_noallow{opacity:.5}#frm_testmode_enabled_form_actions_container{vertical-align:middle;display:inline-block;max-width:200px}#frm_testmode_upgrade{padding:var(--gap-xs) var(--gap-sm);text-align:center;font-size:var(--text-xs);margin-top:var(--gap-sm);line-height:var(--text-xs);font-weight:500;text-decoration:none;display:block;margin-left:-20px;margin-right:-20px;margin-bottom:-16px;border-radius:0 0 16px 16px}.frm_warning_style:has(.frm-addon-button){display:flex;padding:var(--gap-sm);line-height:40px}.frm_warning_style .frm-addon-button,#frm_upgrade_modal a.frm-button-primary{text-decoration:none}#frm_upgrade_modal a.frm-button-primary{cursor:pointer}.frm-dialog{z-index:1001}.frm-dialog+.ui-widget-overlay{z-index:1000}@media(max-width: 1024px){#frm_testing_mode>div>label:not(#frm_quick_jump_label){width:100%;display:block !important;margin-left:0 !important}#frm_testing_mode>div>label:not(#frm_quick_jump_label){margin-top:var(--gap-sm)}#frm_testmode_fill_in_empty_form_fields{display:block}#frm_testing_mode>div:nth-of-type(2){flex-direction:column;align-items:normal}#frm_test_mode_pagination{margin-left:0}} diff --git a/js/addons-page.js b/js/addons-page.js index 84a8b7026f..a95f680f96 100644 --- a/js/addons-page.js +++ b/js/addons-page.js @@ -1,4845 +1 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": -/*!*****************************************************************!*\ - !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ domReady) -/* harmony export */ }); -/** - * @typedef {() => void} Callback - * - * TODO: Remove this typedef and inline `() => void` type. - * - * This typedef is used so that a descriptive type is provided in our - * automatically generated documentation. - * - * An in-line type `() => void` would be preferable, but the generated - * documentation is `null` in that case. - * - * @see https://github.com/WordPress/gutenberg/issues/18045 - */ - -/** - * Specify a function to execute when the DOM is fully loaded. - * - * @param {Callback} callback A function to execute after the DOM is ready. - * - * @example - * ```js - * import domReady from '@wordpress/dom-ready'; - * - * domReady( function() { - * //do something after DOM loads. - * } ); - * ``` - * - * @return {void} - */ -function domReady(callback) { - if (typeof document === 'undefined') { - return; - } - - if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. - document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. - ) { - return void callback(); - } // DOMContentLoaded has not fired yet, delay callback until then. - - - document.addEventListener('DOMContentLoaded', callback); -} -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/addons-page/addons/categorizeAddons.js": -/*!*******************************************************!*\ - !*** ./js/src/addons-page/addons/categorizeAddons.js ***! - \*******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ buildCategorizedAddons: () => (/* binding */ buildCategorizedAddons), -/* harmony export */ categorizedAddons: () => (/* binding */ categorizedAddons) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); -/** - * Internal dependencies - */ - - -var categorizedAddons = {}; -categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.AVAILABLE] = []; -categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ACTIVE] = []; - -/** - * Builds a categorized list of addons. - * - * @return {void} - */ -function buildCategorizedAddons() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - addons = _getElements.addons; - addons.forEach(function (addon) { - // Extract and split the categories from data attribute - var dataCategories = addon.getAttribute('data-categories'); - if (!dataCategories) { - return; - } - var categories = dataCategories.split(','); - categories.forEach(function (category) { - // Initialize the category array if not already done - if (!categorizedAddons[category]) { - categorizedAddons[category] = []; - } - - // Add the addon to the appropriate category - categorizedAddons[category].push(addon); - }); - }); -} - -/***/ }), - -/***/ "./js/src/addons-page/addons/index.js": -/*!********************************************!*\ - !*** ./js/src/addons-page/addons/index.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ buildCategorizedAddons: () => (/* reexport safe */ _categorizeAddons__WEBPACK_IMPORTED_MODULE_0__.buildCategorizedAddons), -/* harmony export */ categorizedAddons: () => (/* reexport safe */ _categorizeAddons__WEBPACK_IMPORTED_MODULE_0__.categorizedAddons) -/* harmony export */ }); -/* harmony import */ var _categorizeAddons__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./categorizeAddons */ "./js/src/addons-page/addons/categorizeAddons.js"); - - -/***/ }), - -/***/ "./js/src/addons-page/constants.js": -/*!*****************************************!*\ - !*** ./js/src/addons-page/constants.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ PLANS: () => (/* binding */ PLANS), -/* harmony export */ PREFIX: () => (/* binding */ PREFIX), -/* harmony export */ VIEWS: () => (/* binding */ VIEWS), -/* harmony export */ addonRequestURL: () => (/* binding */ addonRequestURL) -/* harmony export */ }); -var addonRequestURL = window.frmAddonsVars.addonRequestURL; - -var PREFIX = 'frm-addons'; -var VIEWS = { - AVAILABLE: 'available-addons', - ACTIVE: 'active-addons' -}; -var PLANS = { - BASIC: 'basic', - PLUS: 'plus', - BUSINESS: 'business', - ELITE: 'elite' -}; - -/***/ }), - -/***/ "./js/src/addons-page/elements/elements.js": -/*!*************************************************!*\ - !*** ./js/src/addons-page/elements/elements.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - -var _getElements = (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - bodyContent = _getElements.bodyContent, - sidebar = _getElements.sidebar; -if (bodyContent) { - bodyContent.querySelectorAll('.frm-card-item:not(.plugin-card-formidable-pro)').forEach(function (addon) { - var categories = addon.dataset.categories; - switch (true) { - case categories.includes(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS): - addon.setAttribute('data-categories', "".concat(categories, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE)); - break; - case categories.includes(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.PLUS): - addon.setAttribute('data-categories', "".concat(categories, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE)); - break; - case categories.includes(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BASIC): - addon.setAttribute('data-categories', "".concat(categories, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.PLUS, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS, ",").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE)); - break; - } - }); -} -(0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements)({ - // Body elements - upgradeBanner: document.getElementById('frm-upgrade-banner'), - // Category elements - availableCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.AVAILABLE, "\"]")), - activeCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ACTIVE, "\"]")), - categoriesTopDivider: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-divider")), - basicPlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BASIC, "\"]")), - plusPlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.PLUS, "\"]")), - businessPlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.BUSINESS, "\"]")), - elitePlanCategory: sidebar.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PLANS.ELITE, "\"]")), - // Card elements - addonsList: document.getElementById("".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-list")), - addons: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.querySelectorAll('.frm-card-item'), - availableAddons: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.querySelectorAll('.frm-card-item:not(.frm-locked-item)'), - addonsToggle: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.querySelectorAll('.frm_toggle_block'), - // Add children of the bodyContent to the elements object - bodyContentChildren: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.children -}); - - -/***/ }), - -/***/ "./js/src/addons-page/elements/index.js": -/*!**********************************************!*\ - !*** ./js/src/addons-page/elements/index.js ***! - \**********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/addons-page/elements/elements.js"); - - -/***/ }), - -/***/ "./js/src/addons-page/events/addonToggleListener.js": -/*!**********************************************************!*\ - !*** ./js/src/addons-page/events/addonToggleListener.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _ui___WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../ui/ */ "./js/src/addons-page/ui/index.js"); -function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } -function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } -function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -/** - * Internal dependencies - */ - - -var targetButton; - -/** - * Manages event handling for addons toggle. - * - * @return {void} - */ -function addAddonToggleEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - addonsToggle = _getElements.addonsToggle; - addonsToggle.forEach(function (addonToggle) { - return addonToggle.addEventListener('click', onAddonToggleClick); - }); - wp.hooks.addAction('frm_update_addon_state', 'frmAddonPage', function () { - (0,_ui___WEBPACK_IMPORTED_MODULE_1__.setupActiveCategory)(); - }); -} - -/** - * Handles the click event on the addon toggle. - * - * @private - * @param {Event} event The click event object. - * @return {void} - */ -var onAddonToggleClick = function onAddonToggleClick(event) { - var _targetButton; - if ((_targetButton = targetButton) !== null && _targetButton !== void 0 && _targetButton.classList.contains('frm_loading_button')) { - return; - } - var addonToggle = event.currentTarget; - var addon = addonToggle.closest('.frm-card-item'); - var actionMap = new Map([['frm-addon-not-installed', '.frm-install-addon'], ['frm-addon-installed', '.frm-activate-addon'], ['frm-addon-active', '.frm-deactivate-addon']]); - var _iterator = _createForOfIteratorHelper(actionMap.entries()), - _step; - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var _step$value = _slicedToArray(_step.value, 2), - className = _step$value[0], - selector = _step$value[1]; - if (addon.classList.contains(className)) { - targetButton = addon.querySelector(selector); - targetButton.click(); - break; - } - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addAddonToggleEvents); - -/***/ }), - -/***/ "./js/src/addons-page/events/index.js": -/*!********************************************!*\ - !*** ./js/src/addons-page/events/index.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../ui */ "./js/src/addons-page/ui/index.js"); -/* harmony import */ var _addonToggleListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./addonToggleListener */ "./js/src/addons-page/events/addonToggleListener.js"); -/* harmony import */ var _searchListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./searchListener */ "./js/src/addons-page/events/searchListener.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - -/** - * Attaches event listeners for handling user interactions. - * - * @return {void} - */ -function addEventListeners() { - (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addCategoryEvents)(); - wp.hooks.addAction('frmPage.onCategoryClick', 'frmAddonsPage', function (selectedCategory) { - (0,_ui__WEBPACK_IMPORTED_MODULE_1__.showSelectedCategory)(selectedCategory); - }); - (0,_addonToggleListener__WEBPACK_IMPORTED_MODULE_2__["default"])(); - (0,_searchListener__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - -/***/ }), - -/***/ "./js/src/addons-page/events/searchListener.js": -/*!*****************************************************!*\ - !*** ./js/src/addons-page/events/searchListener.js ***! - \*****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/addons-page/shared/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../ui */ "./js/src/addons-page/ui/index.js"); -/** - * Internal dependencies - */ - - - -var initSearch = window.frmDom.search.init; - -/** - * Adds search-related event listeners by calling the 'initSearch' function. - * - * @see frmDom.search method - * @return {void} - */ -function addSearchEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - searchInput = _getElements.searchInput; - initSearch(searchInput, 'frm-card-item', { - handleSearchResult: handleSearchResult - }); -} - -/** - * Manages UI state based on search results and input value. - * - * @private - * @param {Object} args Contains flags for search status. - * @param {boolean} args.foundSomething True if search yielded results. - * @param {boolean} args.notEmptySearchText True if search input is not empty. - * @param {Event} event The event object (input, search, or change event). - * @return {void} - */ -function handleSearchResult(_ref, event) { - var foundSomething = _ref.foundSomething, - notEmptySearchText = _ref.notEmptySearchText; - // Prevent double calls as window.frmDom.search.init attaches both 'input' and 'search' events, - // triggering this method twice on 'x' button click. - if (event && event.type === 'search' && event.target.value === '') { - return; - } - var state = (0,_shared__WEBPACK_IMPORTED_MODULE_1__.getState)(); - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - allItemsCategory = _getElements2.allItemsCategory; - (0,_shared__WEBPACK_IMPORTED_MODULE_1__.setSingleState)('notEmptySearchText', notEmptySearchText); - - // Revert to 'All Templates' if search and selected category are both empty - if (!state.notEmptySearchText && !state.selectedCategory) { - allItemsCategory.dispatchEvent(new Event('click', { - bubbles: true - })); - return; - } - - // Display search state if a category is selected - if (state.selectedCategory) { - (0,_ui__WEBPACK_IMPORTED_MODULE_2__.showSearchState)(notEmptySearchText); - - // Setting "selectedCategory" to an empty string as a flag for search state - if (notEmptySearchText) { - (0,_shared__WEBPACK_IMPORTED_MODULE_1__.setSingleState)('selectedCategory', ''); - } - } - (0,_ui__WEBPACK_IMPORTED_MODULE_2__.displaySearchElements)(foundSomething); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addSearchEvents); - -/***/ }), - -/***/ "./js/src/addons-page/shared/index.js": -/*!********************************************!*\ - !*** ./js/src/addons-page/shared/index.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setState) -/* harmony export */ }); -/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageState */ "./js/src/addons-page/shared/pageState.js"); - - -/***/ }), - -/***/ "./js/src/addons-page/shared/pageState.js": -/*!************************************************!*\ - !*** ./js/src/addons-page/shared/pageState.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setState) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/** - * External dependencies - */ - - -// NOTE: -// Use setState() here to add new states on the Add-Ons page. -// Check the 'core/page-skeleton' package for shared states you can use. - - - -/***/ }), - -/***/ "./js/src/addons-page/ui/index.js": -/*!****************************************!*\ - !*** ./js/src/addons-page/ui/index.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ displaySearchElements: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_2__.displaySearchElements), -/* harmony export */ setupActiveCategory: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__.setupActiveCategory), -/* harmony export */ setupInitialView: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__.setupInitialView), -/* harmony export */ showEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_3__.showEmptyState), -/* harmony export */ showSearchState: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_2__.showSearchState), -/* harmony export */ showSelectedCategory: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_1__.showSelectedCategory) -/* harmony export */ }); -/* harmony import */ var _setupInitialView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupInitialView */ "./js/src/addons-page/ui/setupInitialView.js"); -/* harmony import */ var _showSelectedCategory__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./showSelectedCategory */ "./js/src/addons-page/ui/showSelectedCategory.js"); -/* harmony import */ var _searchState__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./searchState */ "./js/src/addons-page/ui/searchState.js"); -/* harmony import */ var _showEmptyState__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./showEmptyState */ "./js/src/addons-page/ui/showEmptyState.js"); - - - - - -/***/ }), - -/***/ "./js/src/addons-page/ui/searchState.js": -/*!**********************************************!*\ - !*** ./js/src/addons-page/ui/searchState.js ***! - \**********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ displaySearchElements: () => (/* binding */ displaySearchElements), -/* harmony export */ showSearchState: () => (/* binding */ showSearchState) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../shared */ "./js/src/addons-page/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! . */ "./js/src/addons-page/ui/index.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - -/** - * Updates the UI to display the search state. - * - * @param {boolean} notEmptySearchText True if search input is not empty. - * @return {void} - */ -function showSearchState(notEmptySearchText) { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - bodyContent = _getElements.bodyContent, - bodyContentChildren = _getElements.bodyContentChildren, - addonsList = _getElements.addonsList; - - // Remove highlighting from the currently selected category if the search text is not empty - if (notEmptySearchText) { - (0,_shared__WEBPACK_IMPORTED_MODULE_4__.getSingleState)('selectedCategoryEl').classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_1__.CURRENT_CLASS); - } - - // Hide non-relevant elements in the body content - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hideElements)(bodyContentChildren); - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.show)(addonsList); - - // Smoothly display the updated UI elements - new core_utils__WEBPACK_IMPORTED_MODULE_2__.frmAnimate(bodyContent).fadeIn(); -} - -/** - * Displays search results based on search outcome. - * - * @param {boolean} foundSomething True if search yielded results. - * @return {void} - */ -function displaySearchElements(foundSomething) { - // Show empty state if no templates found - if (!foundSomething) { - (0,___WEBPACK_IMPORTED_MODULE_5__.showEmptyState)(); - return; - } - - // Hide empty state if currently displayed - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - emptyState = _getElements2.emptyState; - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_2__.isVisible)(emptyState)) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hide)(emptyState); - } -} - -/***/ }), - -/***/ "./js/src/addons-page/ui/setupInitialView.js": -/*!***************************************************!*\ - !*** ./js/src/addons-page/ui/setupInitialView.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ setupActiveCategory: () => (/* binding */ setupActiveCategory), -/* harmony export */ setupInitialView: () => (/* binding */ setupInitialView) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _addons__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../addons */ "./js/src/addons-page/addons/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); -/** - * External dependencies - */ - - - - -/** - * Internal dependencies - */ - - - -var CAT_COUNT_CLASS = ".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-cat-count"); - -/** - * Sets up the initial view, performing any required - * DOM manipulations for proper element presentation. - * - * @return {void} - */ -function setupInitialView() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - sidebar = _getElements.sidebar, - searchInput = _getElements.searchInput, - bodyContent = _getElements.bodyContent; - var bodyContentAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent); - searchInput.value = ''; - setupActiveCategory(); - setupAvailableCategory(); - setupAllAddonsCategory(); - setupPlansCategory(); - - // Smoothly display the updated UI elements - bodyContent.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); - sidebar.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); - bodyContentAnimate.fadeIn(); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(sidebar); -} - -/** - * Sets up the "Active" category, updating the - * categorizedAddons object and the category count. - * - * @return {void} - */ -function setupActiveCategory() { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - activeCategory = _getElements2.activeCategory, - availableCategory = _getElements2.availableCategory, - categoriesTopDivider = _getElements2.categoriesTopDivider; - var activeAddons = document.querySelectorAll('.frm-addon-active:not(.frm-locked-item)'); - if (activeAddons.length === 0) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([activeCategory, availableCategory, categoriesTopDivider]); - return; - } - _addons__WEBPACK_IMPORTED_MODULE_4__.categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_5__.VIEWS.ACTIVE] = activeAddons; - - // Set "Active" category count - activeCategory.querySelector(CAT_COUNT_CLASS).textContent = activeAddons.length; -} - -/** - * Sets up the "Available" category, updating the - * categorizedAddons object and the category count. - * - * @private - * @return {void} - */ -function setupAvailableCategory() { - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - bodyContent = _getElements3.bodyContent, - availableCategory = _getElements3.availableCategory, - availableAddons = _getElements3.availableAddons; - _addons__WEBPACK_IMPORTED_MODULE_4__.categorizedAddons[_constants__WEBPACK_IMPORTED_MODULE_5__.VIEWS.AVAILABLE] = availableAddons; - - // Set "Available" category count - if (availableCategory) { - availableCategory.querySelector(CAT_COUNT_CLASS).textContent = availableAddons.length; - var upgradeBannerAvailableCount = bodyContent.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_5__.PREFIX, "-available-count")); - if (upgradeBannerAvailableCount) { - upgradeBannerAvailableCount.textContent = availableAddons.length; - } - } -} - -/** - * Sets up the "All Add-Ons" category, updating the - * category count. - * - * @private - * @return {void} - */ -function setupAllAddonsCategory() { - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - allItemsCategory = _getElements4.allItemsCategory, - addons = _getElements4.addons; - - // Set "All Add-Ons" category count - allItemsCategory.querySelector(CAT_COUNT_CLASS).textContent = addons.length; -} - -/** - * Sets up the "All Add-Ons" category, updating the - * category count. - * - * @private - * @return {void} - */ -function setupPlansCategory() { - var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - basicPlanCategory = _getElements5.basicPlanCategory, - plusPlanCategory = _getElements5.plusPlanCategory, - businessPlanCategory = _getElements5.businessPlanCategory, - elitePlanCategory = _getElements5.elitePlanCategory; - var getCount = function getCount(category) { - return parseInt(category.querySelector(CAT_COUNT_CLASS).textContent, 10) || 0; - }; - - // The "Formidable Pro" add-on is included in all plans, so we just consider that in the basicCount - var basicCount = getCount(basicPlanCategory); - var plusCount = getCount(plusPlanCategory) - 1; - var businessCount = getCount(businessPlanCategory) - 1; - var eliteCount = getCount(elitePlanCategory) - 1; - - // Update the text content for each category - plusPlanCategory.querySelector(CAT_COUNT_CLASS).textContent = basicCount + plusCount; - businessPlanCategory.querySelector(CAT_COUNT_CLASS).textContent = basicCount + plusCount + businessCount; - elitePlanCategory.querySelector(CAT_COUNT_CLASS).textContent = basicCount + plusCount + businessCount + eliteCount; -} - -/***/ }), - -/***/ "./js/src/addons-page/ui/showEmptyState.js": -/*!*************************************************!*\ - !*** ./js/src/addons-page/ui/showEmptyState.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showEmptyState: () => (/* binding */ showEmptyState) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/addons-page/shared/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../constants */ "./js/src/addons-page/constants.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - -/** - * Display the search-empty state. - * - * @return {void} - */ -function showEmptyState() { - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - selectedCategory = _getState.selectedCategory; - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - emptyState = _getElements.emptyState, - emptyStateButton = _getElements.emptyStateButton, - emptyStateTitle = _getElements.emptyStateTitle, - emptyStateText = _getElements.emptyStateText; - emptyState.setAttribute('data-view', selectedCategory); - emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No add-ons found', 'formidable'); - emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Sorry, we didn\'t find any add-ons that match your criteria.', 'formidable'); - emptyStateButton.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Request Add-On', 'formidable'); - emptyStateButton.href = _constants__WEBPACK_IMPORTED_MODULE_4__.addonRequestURL; - emptyStateButton.setAttribute('target', '_blank'); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.showElements)([emptyState, emptyStateButton]); -} - -/***/ }), - -/***/ "./js/src/addons-page/ui/showSelectedCategory.js": -/*!*******************************************************!*\ - !*** ./js/src/addons-page/ui/showSelectedCategory.js ***! - \*******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ showSelectedCategory: () => (/* binding */ showSelectedCategory) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/addons-page/elements/index.js"); -/* harmony import */ var _addons__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../addons */ "./js/src/addons-page/addons/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! . */ "./js/src/addons-page/ui/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - -/** - * Show addons based on selected category. - * - * @param {string} selectedCategory The selected category to display addons for. - * @return {void} - */ -function showSelectedCategory(selectedCategory) { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - bodyContent = _getElements.bodyContent, - addons = _getElements.addons, - emptyState = _getElements.emptyState, - upgradeBanner = _getElements.upgradeBanner; - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(emptyState); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.show)(upgradeBanner); - bodyContent.dataset.category = selectedCategory; - if (core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS === selectedCategory) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)(addons); - return; - } - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(addons); - if (_addons__WEBPACK_IMPORTED_MODULE_3__.categorizedAddons[selectedCategory].length === 0) { - (0,___WEBPACK_IMPORTED_MODULE_4__.showEmptyState)(); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(upgradeBanner); - } else { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)(_addons__WEBPACK_IMPORTED_MODULE_3__.categorizedAddons[selectedCategory]); - } -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (showSelectedCategory); - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/factory/createPageElements.js": -/*!***************************************************!*\ - !*** ./js/src/core/factory/createPageElements.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* binding */ createPageElements) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page elements manager. - * - * @param {Object} [initialElements={}] An object containing initial DOM elements. - * @throws {Error} Throws an error if the `initialElements` is not an object. - * @return {Object} An object with methods to get and add elements. - */ -function createPageElements() { - var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialElements) !== 'object' || initialElements === null) { - throw new Error('createPageElements: initialElements must be a non-null object'); - } - var elements = initialElements; - - /** - * Retrieve the initialized essential DOM elements. - * - * @return {Object} The initialized elements object. - */ - function getElements() { - return elements; - } - - /** - * Add new elements to the elements object. - * - * @param {Object} newElements An object containing new elements to be added. - * @throws {Error} Throws an error if the `newElements` is not a non-null object. - * @return {void} Updates the elements object by merging the new elements into it. - */ - function addElements(newElements) { - if (_typeof(newElements) !== 'object' || newElements === null) { - throw new Error('addElements: newElements must be a non-null object'); - } - elements = _objectSpread(_objectSpread({}, elements), newElements); - } - return { - getElements: getElements, - addElements: addElements - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/createPageState.js": -/*!************************************************!*\ - !*** ./js/src/core/factory/createPageState.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageState: () => (/* binding */ createPageState) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page state manager. - * - * @param {Object} [initialState={}] An object containing the initial state. - * @throws {Error} Throws an error if the `initialState` is not a plain object. - * @return {Object} An object with methods to initialize, get, and set the page state. - */ -function createPageState() { - var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialState) !== 'object' || initialState === null) { - throw new Error('createPageState: initialState must be a non-null object'); - } - var state = initialState; - - /** - * Returns the current page state. - * - * @return {Object|null} The current state of the page or null if not initialized. - */ - var getState = function getState() { - return state; - }; - - /** - * Returns a specific property from the current page state. - * - * @param {string} propertyName The name of the property to retrieve. - * @return {*} The value of the specified property, or null if it doesn't exist. - */ - var getSingleState = function getSingleState(propertyName) { - var value = Reflect.get(state, propertyName); - - // We convert `undefined` to `null` for a consistent API. - // This makes it easier for users to handle the results since all missing properties return `null`. - return value === undefined ? null : value; - }; - - /** - * Updates the page state with new values. - * - * @param {Object} newState The new values to update the state with. - * @throws {Error} Throws an error if `newState` is not a plain object. - * @return {void} - */ - var setState = function setState(newState) { - if (_typeof(newState) !== 'object' || newState === null) { - throw new Error('setState: newState must be a non-null object'); - } - state = _objectSpread(_objectSpread({}, state), newState); - }; - - /** - * Updates a specific property in the page state with a new value. - * - * @param {string} propertyName The name of the property to update. - * @param {*} value The new value to set for the property. - * @return {void} - */ - var setSingleState = function setSingleState(propertyName, value) { - if (Reflect.has(state, propertyName)) { - Reflect.set(state, propertyName, value); - } - }; - return { - getState: getState, - getSingleState: getSingleState, - setState: setState, - setSingleState: setSingleState - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/index.js": -/*!**************************************!*\ - !*** ./js/src/core/factory/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), -/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) -/* harmony export */ }); -/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); -/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); - - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/constants.js": -/*!************************************************!*\ - !*** ./js/src/core/page-skeleton/constants.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ PREFIX: () => (/* binding */ PREFIX), -/* harmony export */ SEARCH_RESULT_ITEM: () => (/* binding */ SEARCH_RESULT_ITEM), -/* harmony export */ VIEWS: () => (/* binding */ VIEWS) -/* harmony export */ }); -var PREFIX = 'frm-page-skeleton'; -var SEARCH_RESULT_ITEM = 'frm-card-item'; -var VIEWS = { - ALL_ITEMS: 'all-items' -}; - -/***/ }), - -/***/ "./js/src/core/page-skeleton/elements/elements.js": -/*!********************************************************!*\ - !*** ./js/src/core/page-skeleton/elements/elements.js ***! - \********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* binding */ addElements), -/* harmony export */ getElements: () => (/* binding */ getElements) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); -/* harmony import */ var _emptyStateElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./emptyStateElement */ "./js/src/core/page-skeleton/elements/emptyStateElement.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -var bodyContent = document.getElementById('post-body-content'); -var sidebar = document.getElementById("".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-sidebar")); - -// Append empty state elements to body content -var emptyState = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.createEmptyStateElement)(); -bodyContent === null || bodyContent === void 0 || bodyContent.append(emptyState); -var emptyStateElements = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.getEmptyStateElements)(); -var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)(_objectSpread({ - bodyContent: bodyContent, - // Sidebar elements - sidebar: sidebar, - searchInput: sidebar.querySelector('.frm-search-input'), - categoryItems: sidebar.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat")), - allItemsCategory: sidebar.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS, "\"]")) - }, emptyStateElements)), - getElements = _createPageElements.getElements, - addElements = _createPageElements.addElements; - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/elements/emptyStateElement.js": -/*!*****************************************************************!*\ - !*** ./js/src/core/page-skeleton/elements/emptyStateElement.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createEmptyStateElement: () => (/* binding */ createEmptyStateElement), -/* harmony export */ getEmptyStateElements: () => (/* binding */ getEmptyStateElements) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - -var _window$frmDom = window.frmDom, - tag = _window$frmDom.tag, - div = _window$frmDom.div, - a = _window$frmDom.a, - img = _window$frmDom.img; - -/** - * Create and return the Empty State HTML element. - * - * @return {HTMLElement} The Empty State element. - */ -function createEmptyStateElement() { - var button = a({ - className: 'button button-primary frm-button-primary' - }); - button.setAttribute('role', 'button'); - return div({ - id: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state"), - className: "frm-flex-col frm-flex-center frm-gap-md ".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS), - children: [img({ - src: "".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.PLUGIN_URL, "/images/page-skeleton/empty-state.svg"), - alt: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Empty State', 'formidable') - }), div({ - className: 'frmcenter', - children: [tag('h2', { - className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title frm-mb-0") - }), tag('p', { - className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text frm-mb-0") - })] - }), button] - }); -} - -/** - * Return the elements related to the Empty State. - * - * @return {Object} Object containing Empty State related DOM elements. - */ -function getEmptyStateElements() { - var emptyState = document.querySelector("#".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state")); - return { - emptyState: emptyState, - emptyStateTitle: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title")), - emptyStateText: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text")), - emptyStateButton: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector('.button') - }; -} - -/***/ }), - -/***/ "./js/src/core/page-skeleton/elements/index.js": -/*!*****************************************************!*\ - !*** ./js/src/core/page-skeleton/elements/index.js ***! - \*****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/elements.js"); - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/events/categoryListener.js": -/*!**************************************************************!*\ - !*** ./js/src/core/page-skeleton/events/categoryListener.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addCategoryEvents: () => (/* binding */ addCategoryEvents) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/core/page-skeleton/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! . */ "./js/src/core/page-skeleton/events/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - -/** - * Manages event handling for sidebar category links. - * - * @return {void} - */ -function addCategoryEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - categoryItems = _getElements.categoryItems; - - // Attach click and keyboard event listeners to each sidebar category - categoryItems.forEach(function (category) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(category, onCategoryClick); - category.addEventListener('keydown', onCategoryKeydown); - }); -} - -/** - * Handles the click event on a category item. - * - * @private - * @param {Event} event The click event object. - */ -var onCategoryClick = function onCategoryClick(event) { - var clickedCategory = event.currentTarget; - var newSelectedCategory = clickedCategory.getAttribute('data-category'); - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - selectedCategory = _getState.selectedCategory, - selectedCategoryEl = _getState.selectedCategoryEl, - notEmptySearchText = _getState.notEmptySearchText; - - // If the selected category hasn't changed, return early - if (selectedCategory === newSelectedCategory) { - return; - } - - /** - * Filter hook to modify the selected category. - * - * @param {string} selectedCategory The selected category - */ - selectedCategory = wp.hooks.applyFilters('frmPage.selectedCategory', newSelectedCategory); - - // Highlight the newly clicked category and update the application state - selectedCategoryEl.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - selectedCategoryEl = clickedCategory; - selectedCategoryEl.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setState)({ - selectedCategory: selectedCategory, - selectedCategoryEl: selectedCategoryEl - }); - - // Reset the search input if it contains text - if (notEmptySearchText) { - (0,___WEBPACK_IMPORTED_MODULE_4__.resetSearchInput)(); - } - - /** - * Trigger custom action to update category content. - * - * @param {string} selectedCategory The selected category. - */ - wp.hooks.doAction('frmPage.onCategoryClick', selectedCategory); - - // Smoothly display the updated UI elements - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - bodyContent = _getElements2.bodyContent; - new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent).fadeIn(); -}; - -/** - * Handles the keyboard event on a category item. - * - * @param {KeyboardEvent} event The keyboard event object. - * @return {void} - */ -function onCategoryKeydown(event) { - // Only respond to 'Enter' or 'Space' key presses - if (event.key === 'Enter' || event.key === ' ') { - event.preventDefault(); - onCategoryClick(event); - } -} - -/***/ }), - -/***/ "./js/src/core/page-skeleton/events/index.js": -/*!***************************************************!*\ - !*** ./js/src/core/page-skeleton/events/index.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _categoryListener__WEBPACK_IMPORTED_MODULE_1__.addCategoryEvents), -/* harmony export */ resetSearchInput: () => (/* binding */ resetSearchInput) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _categoryListener__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./categoryListener */ "./js/src/core/page-skeleton/events/categoryListener.js"); -/** - * Internal dependencies - */ - - -/** - * Resets the value of the search input and triggers an input event. - * - * @return {void} - */ -function resetSearchInput() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - searchInput = _getElements.searchInput; - searchInput.value = ''; - searchInput.dispatchEvent(new Event('input', { - bubbles: true - })); -} - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/index.js": -/*!********************************************!*\ - !*** ./js/src/core/page-skeleton/index.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), -/* harmony export */ SEARCH_RESULT_ITEM: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.SEARCH_RESULT_ITEM), -/* harmony export */ VIEWS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.VIEWS), -/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.addCategoryEvents), -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.getElements), -/* harmony export */ getSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getState), -/* harmony export */ resetSearchInput: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.resetSearchInput), -/* harmony export */ setSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setState) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/core/page-skeleton/constants.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./shared */ "./js/src/core/page-skeleton/shared/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./events */ "./js/src/core/page-skeleton/events/index.js"); - - - - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/shared/index.js": -/*!***************************************************!*\ - !*** ./js/src/core/page-skeleton/shared/index.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setState) -/* harmony export */ }); -/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageState */ "./js/src/core/page-skeleton/shared/pageState.js"); - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/shared/pageState.js": -/*!*******************************************************!*\ - !*** ./js/src/core/page-skeleton/shared/pageState.js ***! - \*******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* binding */ getSingleState), -/* harmony export */ getState: () => (/* binding */ getState), -/* harmony export */ setSingleState: () => (/* binding */ setSingleState), -/* harmony export */ setState: () => (/* binding */ setState) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - allItemsCategory = _getElements.allItemsCategory; -var _createPageState = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageState)({ - notEmptySearchText: false, - selectedCategory: _constants__WEBPACK_IMPORTED_MODULE_2__.VIEWS.ALL_ITEMS, - selectedCategoryEl: allItemsCategory - }), - getState = _createPageState.getState, - getSingleState = _createPageState.getSingleState, - setState = _createPageState.setState, - setSingleState = _createPageState.setSingleState; - - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. -(() => { -"use strict"; -/*!*************************************!*\ - !*** ./js/src/addons-page/index.js ***! - \*************************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/addons-page/ui/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./js/src/addons-page/events/index.js"); -/* harmony import */ var _addons__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./addons */ "./js/src/addons-page/addons/index.js"); -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - - - -(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_3__["default"])(function () { - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.setupInitialView)(); - (0,_addons__WEBPACK_IMPORTED_MODULE_2__.buildCategorizedAddons)(); - (0,_events__WEBPACK_IMPORTED_MODULE_1__.addEventListeners)(); -}); -})(); - -/******/ })() -; -//# sourceMappingURL=addons-page.js.map \ No newline at end of file +(()=>{var t={8616:t=>{t.exports=function(t,e){var n,r,o=0;function i(){var i,a,c=n,l=arguments.length;t:for(;c;){if(c.args.length===arguments.length){for(a=0;a{var r;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function i(t){return function(t,e){var n,r,a,c,l,s,u,f,d,p=1,y=t.length,m="";for(r=0;r=0),c.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,c.width?parseInt(c.width):0);break;case"e":n=c.precision?parseFloat(n).toExponential(c.precision):parseFloat(n).toExponential();break;case"f":n=c.precision?parseFloat(n).toFixed(c.precision):parseFloat(n);break;case"g":n=c.precision?String(Number(n.toPrecision(c.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=c.precision?n.substring(0,c.precision):n;break;case"t":n=String(!!n),n=c.precision?n.substring(0,c.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=c.precision?n.substring(0,c.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=c.precision?n.substring(0,c.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}o.json.test(c.type)?m+=n:(!o.number.test(c.type)||f&&!c.sign?d="":(d=f?"+":"-",n=n.toString().replace(o.sign,"")),s=c.pad_char?"0"===c.pad_char?"0":c.pad_char.charAt(1):" ",u=c.width-(d+n).length,l=c.width&&u>0?s.repeat(u):"",m+=c.align?d+n+l:"0"===s?d+l+n:l+d+n)}return m}(function(t){if(c[t])return c[t];for(var e,n=t,r=[],i=0;n;){if(null!==(e=o.text.exec(n)))r.push(e[0]);else if(null!==(e=o.modulo.exec(n)))r.push("%");else{if(null===(e=o.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){i|=1;var a=[],l=e[2],s=[];if(null===(s=o.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(s[1]);""!==(l=l.substring(s[0].length));)if(null!==(s=o.key_access.exec(l)))a.push(s[1]);else{if(null===(s=o.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(s[1])}e[2]=a}else i|=2;if(3===i)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}n=n.substring(e[0].length)}return c[t]=r}(t),arguments)}function a(t,e){return i.apply(null,[t].concat(e||[]))}var c=Object.create(null);"undefined"!=typeof window&&(window.sprintf=i,window.vsprintf=a,void 0===(r=function(){return{sprintf:i,vsprintf:a}}.call(e,n,e,t))||(t.exports=r))}()}},e={};function n(r){var o=e[r];if(void 0!==o)return o.exports;var i=e[r]={exports:{}};return t[r](i,i.exports,n),i.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t=window.frmGlobal,e=t.url,r=(t.nonce,"frm_hidden"),o="frm-hide-js",i="frm-current";function a(t){return a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},a(t)}function c(t,e){for(var n=0;n1&&void 0!==arguments[1]?arguments[1]:"default";!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.elements=e,this.type=n,this.prepareElements()},e=[{key:"fadeIn",value:function(){var t=this;this.applyStyleToElements(function(e){e.classList.add("frm-fadein-up"),e.addEventListener("animationend",function(){t.resetOpacity(),e.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){t.applyStyleToElements(function(t,n){t.classList.remove("frm-animate"),t.style.transitionDelay="".concat((n+1)*e,"s")})},200)}},{key:"prepareElements",value:function(){var t=this;this.applyStyleToElements(function(e){"default"===t.type&&(e.style.opacity="0.0"),"cascade"===t.type&&e.classList.add("frm-init-cascade-animation"),"cascade-3d"===t.type&&e.classList.add("frm-init-fadein-3d"),e.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(t){return t.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(t){this.elements instanceof Element?t(this.elements,0):0":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},j=["(","?"],E={")":["("],":":["?","?:"]},P=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var F={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,n){if(t)throw e;return n}};var I={contextDelimiter:"",onMissingKey:null};function D(t,e){var n;for(n in this.data=t,this.pluralForms={},this.options={},I)this.options[n]=void 0!==e&&n in e?e[n]:I[n]}function L(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function q(t){for(var e=1;e=0||_[o]<_[n]){a.push(o);break}i.push(o)}E[n]||a.push(n),t=t.substr(e.index+n.length)}return(t=t.trim())&&i.push(t),i.concat(a.reverse())}(t);return function(t){return function(t,e){var n,r,o,i,a,c,l=[];for(n=0;n3&&void 0!==arguments[3]?arguments[3]:10,a=t[e];if(B(n)&&z(r))if("function"==typeof o)if("number"==typeof i){var c={callback:o,priority:i,namespace:r};if(a[n]){var l,s=a[n].handlers;for(l=s.length;l>0&&!(i>=s[l-1].priority);l--);l===s.length?s[l]=c:s.splice(l,0,c),a.__current.forEach(function(t){t.name===n&&t.currentIndex>=l&&t.currentIndex++})}else a[n]={handlers:[c],runs:0};"hookAdded"!==n&&t.doAction("hookAdded",n,r,o,i)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},$=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,o){var i=t[e];if(B(r)&&(n||z(o))){if(!i[r])return 0;var a=0;if(n)a=i[r].handlers.length,i[r]={runs:i[r].runs,handlers:[]};else for(var c=i[r].handlers,l=function(t){c[t].namespace===o&&(c.splice(t,1),a++,i.__current.forEach(function(e){e.name===r&&e.currentIndex>=t&&e.currentIndex--}))},s=c.length-1;s>=0;s--)l(s);return"hookRemoved"!==r&&t.doAction("hookRemoved",r,o),a}}},U=function(t,e){return function(n,r){var o=t[e];return void 0!==r?n in o&&o[n].handlers.some(function(t){return t.namespace===r}):n in o}},Z=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var o=t[e];o[r]||(o[r]={handlers:[],runs:0}),o[r].runs++;for(var i=o[r].handlers,a=arguments.length,c=new Array(a>1?a-1:0),l=1;l1&&void 0!==arguments[1]?arguments[1]:"default";r.data[e]=q(q(q({},R),r.data[e]),t),r.data[e][""]=q(q({},R[""]),r.data[e][""])},c=function(t,e){a(t,e),i()},l=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;return r.data[t]||a(void 0,t),r.dcnpgettext(t,e,n,o,i)},s=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},u=function(t,e,r){var o=l(r,e,t);return n?(o=n.applyFilters("i18n.gettext_with_context",o,t,e,r),n.applyFilters("i18n.gettext_with_context_"+s(r),o,t,e,r)):o};if(n){var f=function(t){N.test(t)&&i()};n.addAction("hookAdded","core/i18n",f),n.addAction("hookRemoved","core/i18n",f)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[t]},setLocaleData:c,resetLocaleData:function(t,e){r.data={},r.pluralForms={},c(t,e)},subscribe:function(t){return o.add(t),function(){return o.delete(t)}},__:function(t,e){var r=l(e,void 0,t);return n?(r=n.applyFilters("i18n.gettext",r,t,e),n.applyFilters("i18n.gettext_"+s(e),r,t,e)):r},_x:u,_n:function(t,e,r,o){var i=l(o,void 0,t,e,r);return n?(i=n.applyFilters("i18n.ngettext",i,t,e,r,o),n.applyFilters("i18n.ngettext_"+s(o),i,t,e,r,o)):i},_nx:function(t,e,r,o,i){var a=l(i,o,t,e,r);return n?(a=n.applyFilters("i18n.ngettext_with_context",a,t,e,r,o,i),n.applyFilters("i18n.ngettext_with_context_"+s(i),a,t,e,r,o,i)):a},isRTL:function(){return"rtl"===u("ltr","text direction")},hasTranslation:function(t,e,o){var i,a,c=e?e+""+t:t,l=!(null===(i=r.data)||void 0===i||null===(a=i[null!=o?o:"default"])||void 0===a||!a[c]);return n&&(l=n.applyFilters("i18n.has_translation",l,t,e,o),l=n.applyFilters("i18n.has_translation_"+s(o),l,t,e,o)),l}}}(0,0,V));G.getLocaleData.bind(G),G.setLocaleData.bind(G),G.resetLocaleData.bind(G),G.subscribe.bind(G);var H=G.__.bind(G),Q=(G._x.bind(G),G._n.bind(G),G._nx.bind(G),G.isRTL.bind(G),G.hasTranslation.bind(G),window.frmDom),W=Q.tag,Y=Q.div,tt=Q.a,et=Q.img;function nt(t){return nt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},nt(t)}function rt(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function ot(t,e,n){return(e=function(t){var e=function(t){if("object"!=nt(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=nt(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==nt(e)?e:e+""}(e))in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var it,at=document.getElementById("post-body-content"),ct=document.getElementById("".concat(h,"-sidebar")),lt=((it=tt({className:"button button-primary frm-button-primary"})).setAttribute("role","button"),Y({id:"".concat(h,"-empty-state"),className:"frm-flex-col frm-flex-center frm-gap-md ".concat(r),children:[et({src:"".concat(e,"/images/page-skeleton/empty-state.svg"),alt:H("Empty State","formidable")}),Y({className:"frmcenter",children:[W("h2",{className:"".concat(h,"-title frm-mb-0")}),W("p",{className:"".concat(h,"-text frm-mb-0")})]}),it]}));null==at||at.append(lt);var st=function(){var t=document.querySelector("#".concat(h,"-empty-state"));return{emptyState:t,emptyStateTitle:null==t?void 0:t.querySelector(".".concat(h,"-title")),emptyStateText:null==t?void 0:t.querySelector(".".concat(h,"-text")),emptyStateButton:null==t?void 0:t.querySelector(".button")}}(),ut=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==O(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var e=t;return{getElements:function(){return e},addElements:function(t){if("object"!==O(t)||null===t)throw new Error("addElements: newElements must be a non-null object");e=w(w({},e),t)}}}(function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==vt(t)||null===t)throw new Error("createPageState: initialState must be a non-null object");var e=t;return{getState:function(){return e},getSingleState:function(t){var n=Reflect.get(e,t);return void 0===n?null:n},setState:function(t){if("object"!==vt(t)||null===t)throw new Error("setState: newState must be a non-null object");e=yt(yt({},e),t)},setSingleState:function(t,n){Reflect.has(e,t)&&Reflect.set(e,t,n)}}}({notEmptySearchText:!1,selectedCategory:g,selectedCategoryEl:bt}),gt=ht.getState,St=ht.getSingleState,wt=ht.setState,xt=ht.setSingleState,Ot=function(t){var e,n=t.currentTarget,r=n.getAttribute("data-category"),o=gt(),a=o.selectedCategory,c=o.selectedCategoryEl,l=o.notEmptySearchText;if(a!==r){a=wp.hooks.applyFilters("frmPage.selectedCategory",r),c.classList.remove(i),(c=n).classList.add(i),wt({selectedCategory:a,selectedCategoryEl:c}),l&&((e=ft().searchInput).value="",e.dispatchEvent(new Event("input",{bubbles:!0}))),wp.hooks.doAction("frmPage.onCategoryClick",a);var u=ft().bodyContent;new s(u).fadeIn()}};function _t(t){"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),Ot(t))}var jt=window.frmAddonsVars.addonRequestURL,Et="frm-addons",Pt="available-addons",kt="active-addons",At="basic",Ct="plus",Tt="business",Ft="elite",It=ft(),Dt=It.bodyContent,Lt=It.sidebar;Dt&&Dt.querySelectorAll(".frm-card-item:not(.plugin-card-formidable-pro)").forEach(function(t){var e=t.dataset.categories;switch(!0){case e.includes(Tt):t.setAttribute("data-categories","".concat(e,",").concat(Ft));break;case e.includes(Ct):t.setAttribute("data-categories","".concat(e,",").concat(Tt,",").concat(Ft));break;case e.includes(At):t.setAttribute("data-categories","".concat(e,",").concat(Ct,",").concat(Tt,",").concat(Ft))}}),dt({upgradeBanner:document.getElementById("frm-upgrade-banner"),availableCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Pt,'"]')),activeCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(kt,'"]')),categoriesTopDivider:Lt.querySelector(".".concat(h,"-divider")),basicPlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(At,'"]')),plusPlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Ct,'"]')),businessPlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Tt,'"]')),elitePlanCategory:Lt.querySelector(".".concat(h,'-cat[data-category="').concat(Ft,'"]')),addonsList:document.getElementById("".concat(Et,"-list")),addons:null==Dt?void 0:Dt.querySelectorAll(".frm-card-item"),availableAddons:null==Dt?void 0:Dt.querySelectorAll(".frm-card-item:not(.frm-locked-item)"),addonsToggle:null==Dt?void 0:Dt.querySelectorAll(".frm_toggle_block"),bodyContentChildren:null==Dt?void 0:Dt.children});var qt={};qt[Pt]=[],qt[kt]=[];var Rt,Nt=".".concat(h,"-cat-count");function zt(){var t=ft(),e=t.activeCategory,n=t.availableCategory,r=t.categoriesTopDivider,o=document.querySelectorAll(".frm-addon-active:not(.frm-locked-item)");0!==o.length?(qt[kt]=o,e.querySelector(Nt).textContent=o.length):m([e,n,r])}function Bt(){var t=gt().selectedCategory,e=ft(),n=e.emptyState,r=e.emptyStateButton,o=e.emptyStateTitle,i=e.emptyStateText;n.setAttribute("data-view",t),o.textContent=H("No add-ons found","formidable"),i.textContent=H("Sorry, we didn't find any add-ons that match your criteria.","formidable"),r.textContent=H("Request Add-On","formidable"),r.href=jt,r.setAttribute("target","_blank"),y([n,r])}function Mt(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=null==t?null:"undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(null!=n){var r,o,i,a,c=[],l=!0,s=!1;try{if(i=(n=n.call(t)).next,0===e){if(Object(n)!==n)return;l=!1}else for(;!(l=(r=i.call(n)).done)&&(c.push(r.value),c.length!==e);l=!0);}catch(t){s=!0,o=t}finally{try{if(!l&&null!=n.return&&(a=n.return(),Object(a)!==a))return}finally{if(s)throw o}}return c}}(t,e)||$t(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function $t(t,e){if(t){if("string"==typeof t)return Ut(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?Ut(t,e):void 0}}function Ut(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:r}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var o,i=!0,a=!1;return{s:function(){e=e.call(t)},n:function(){var t=e.next();return i=t.done,t},e:function(t){a=!0,o=t},f:function(){try{i||null==e.return||e.return()}finally{if(a)throw o}}}}(new Map([["frm-addon-not-installed",".frm-install-addon"],["frm-addon-installed",".frm-activate-addon"],["frm-addon-active",".frm-deactivate-addon"]]).entries());try{for(o.s();!(n=o.n()).done;){var i=Mt(n.value,2),a=i[0],c=i[1];if(r.classList.contains(a)){(Rt=r.querySelector(c)).click();break}}}catch(t){o.e(t)}finally{o.f()}}};var Kt=window.frmDom.search.init;function Xt(t,e){var n=t.foundSomething,r=t.notEmptySearchText;if(!e||"search"!==e.type||""!==e.target.value){var o=gt(),a=ft().allItemsCategory;xt("notEmptySearchText",r),o.notEmptySearchText||o.selectedCategory?(o.selectedCategory&&(function(t){var e=ft(),n=e.bodyContent,r=e.bodyContentChildren,o=e.addonsList;t&&St("selectedCategoryEl").classList.remove(i),m(r),v(o),new s(n).fadeIn()}(r),r&&xt("selectedCategory","")),function(t){if(t){var e,n=ft().emptyState;e=n,"none"!==window.getComputedStyle(e).getPropertyValue("display")&&b(n)}else Bt()}(n)):a.dispatchEvent(new Event("click",{bubbles:!0}))}}function Jt(){var t;ft().categoryItems.forEach(function(t){p(t,Ot),t.addEventListener("keydown",_t)}),wp.hooks.addAction("frmPage.onCategoryClick","frmAddonsPage",function(t){!function(t){var e=ft(),n=e.bodyContent,r=e.addons,o=e.emptyState,i=e.upgradeBanner;b(o),v(i),n.dataset.category=t,g!==t?(m(r),0===qt[t].length?(Bt(),b(i)):y(qt[t])):y(r)}(t)}),ft().addonsToggle.forEach(function(t){return t.addEventListener("click",Zt)}),wp.hooks.addAction("frm_update_addon_state","frmAddonPage",function(){zt()}),t=ft().searchInput,Kt(t,"frm-card-item",{handleSearchResult:Xt})}var Vt;Vt=function(){(function(){var t,e,n,r,i,a,c,l,u,f,d=ft(),p=d.sidebar,y=d.searchInput,m=d.bodyContent,b=new s(m);y.value="",zt(),function(){var t=ft(),e=t.bodyContent,n=t.availableCategory,r=t.availableAddons;if(qt[Pt]=r,n){n.querySelector(Nt).textContent=r.length;var o=e.querySelector(".".concat(Et,"-available-count"));o&&(o.textContent=r.length)}}(),function(){var t=ft(),e=t.allItemsCategory,n=t.addons;e.querySelector(Nt).textContent=n.length}(),e=(t=ft()).basicPlanCategory,n=t.plusPlanCategory,r=t.businessPlanCategory,i=t.elitePlanCategory,c=(a=function(t){return parseInt(t.querySelector(Nt).textContent,10)||0})(e),l=a(n)-1,u=a(r)-1,f=a(i)-1,n.querySelector(Nt).textContent=c+l,r.querySelector(Nt).textContent=c+l+u,i.querySelector(Nt).textContent=c+l+u+f,m.classList.remove(o),p.classList.remove(o),b.fadeIn(),v(p)})(),ft().addons.forEach(function(t){var e=t.getAttribute("data-categories");e&&e.split(",").forEach(function(e){qt[e]||(qt[e]=[]),qt[e].push(t)})}),Jt()},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",Vt):Vt())})()})(); \ No newline at end of file diff --git a/js/form-templates.js b/js/form-templates.js index 5f2d576f97..d97f74de3e 100644 --- a/js/form-templates.js +++ b/js/form-templates.js @@ -1,6798 +1,2 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": -/*!*****************************************************************!*\ - !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ domReady) -/* harmony export */ }); -/** - * @typedef {() => void} Callback - * - * TODO: Remove this typedef and inline `() => void` type. - * - * This typedef is used so that a descriptive type is provided in our - * automatically generated documentation. - * - * An in-line type `() => void` would be preferable, but the generated - * documentation is `null` in that case. - * - * @see https://github.com/WordPress/gutenberg/issues/18045 - */ - -/** - * Specify a function to execute when the DOM is fully loaded. - * - * @param {Callback} callback A function to execute after the DOM is ready. - * - * @example - * ```js - * import domReady from '@wordpress/dom-ready'; - * - * domReady( function() { - * //do something after DOM loads. - * } ); - * ``` - * - * @return {void} - */ -function domReady(callback) { - if (typeof document === 'undefined') { - return; - } - - if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. - document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. - ) { - return void callback(); - } // DOMContentLoaded has not fired yet, delay callback until then. - - - document.addEventListener('DOMContentLoaded', callback); -} -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/factory/createPageElements.js": -/*!***************************************************!*\ - !*** ./js/src/core/factory/createPageElements.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* binding */ createPageElements) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page elements manager. - * - * @param {Object} [initialElements={}] An object containing initial DOM elements. - * @throws {Error} Throws an error if the `initialElements` is not an object. - * @return {Object} An object with methods to get and add elements. - */ -function createPageElements() { - var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialElements) !== 'object' || initialElements === null) { - throw new Error('createPageElements: initialElements must be a non-null object'); - } - var elements = initialElements; - - /** - * Retrieve the initialized essential DOM elements. - * - * @return {Object} The initialized elements object. - */ - function getElements() { - return elements; - } - - /** - * Add new elements to the elements object. - * - * @param {Object} newElements An object containing new elements to be added. - * @throws {Error} Throws an error if the `newElements` is not a non-null object. - * @return {void} Updates the elements object by merging the new elements into it. - */ - function addElements(newElements) { - if (_typeof(newElements) !== 'object' || newElements === null) { - throw new Error('addElements: newElements must be a non-null object'); - } - elements = _objectSpread(_objectSpread({}, elements), newElements); - } - return { - getElements: getElements, - addElements: addElements - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/createPageState.js": -/*!************************************************!*\ - !*** ./js/src/core/factory/createPageState.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageState: () => (/* binding */ createPageState) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page state manager. - * - * @param {Object} [initialState={}] An object containing the initial state. - * @throws {Error} Throws an error if the `initialState` is not a plain object. - * @return {Object} An object with methods to initialize, get, and set the page state. - */ -function createPageState() { - var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialState) !== 'object' || initialState === null) { - throw new Error('createPageState: initialState must be a non-null object'); - } - var state = initialState; - - /** - * Returns the current page state. - * - * @return {Object|null} The current state of the page or null if not initialized. - */ - var getState = function getState() { - return state; - }; - - /** - * Returns a specific property from the current page state. - * - * @param {string} propertyName The name of the property to retrieve. - * @return {*} The value of the specified property, or null if it doesn't exist. - */ - var getSingleState = function getSingleState(propertyName) { - var value = Reflect.get(state, propertyName); - - // We convert `undefined` to `null` for a consistent API. - // This makes it easier for users to handle the results since all missing properties return `null`. - return value === undefined ? null : value; - }; - - /** - * Updates the page state with new values. - * - * @param {Object} newState The new values to update the state with. - * @throws {Error} Throws an error if `newState` is not a plain object. - * @return {void} - */ - var setState = function setState(newState) { - if (_typeof(newState) !== 'object' || newState === null) { - throw new Error('setState: newState must be a non-null object'); - } - state = _objectSpread(_objectSpread({}, state), newState); - }; - - /** - * Updates a specific property in the page state with a new value. - * - * @param {string} propertyName The name of the property to update. - * @param {*} value The new value to set for the property. - * @return {void} - */ - var setSingleState = function setSingleState(propertyName, value) { - if (Reflect.has(state, propertyName)) { - Reflect.set(state, propertyName, value); - } - }; - return { - getState: getState, - getSingleState: getSingleState, - setState: setState, - setSingleState: setSingleState - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/index.js": -/*!**************************************!*\ - !*** ./js/src/core/factory/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), -/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) -/* harmony export */ }); -/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); -/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); - - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/constants.js": -/*!************************************************!*\ - !*** ./js/src/core/page-skeleton/constants.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ PREFIX: () => (/* binding */ PREFIX), -/* harmony export */ SEARCH_RESULT_ITEM: () => (/* binding */ SEARCH_RESULT_ITEM), -/* harmony export */ VIEWS: () => (/* binding */ VIEWS) -/* harmony export */ }); -var PREFIX = 'frm-page-skeleton'; -var SEARCH_RESULT_ITEM = 'frm-card-item'; -var VIEWS = { - ALL_ITEMS: 'all-items' -}; - -/***/ }), - -/***/ "./js/src/core/page-skeleton/elements/elements.js": -/*!********************************************************!*\ - !*** ./js/src/core/page-skeleton/elements/elements.js ***! - \********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* binding */ addElements), -/* harmony export */ getElements: () => (/* binding */ getElements) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); -/* harmony import */ var _emptyStateElement__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./emptyStateElement */ "./js/src/core/page-skeleton/elements/emptyStateElement.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -var bodyContent = document.getElementById('post-body-content'); -var sidebar = document.getElementById("".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-sidebar")); - -// Append empty state elements to body content -var emptyState = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.createEmptyStateElement)(); -bodyContent === null || bodyContent === void 0 || bodyContent.append(emptyState); -var emptyStateElements = (0,_emptyStateElement__WEBPACK_IMPORTED_MODULE_2__.getEmptyStateElements)(); -var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)(_objectSpread({ - bodyContent: bodyContent, - // Sidebar elements - sidebar: sidebar, - searchInput: sidebar.querySelector('.frm-search-input'), - categoryItems: sidebar.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat")), - allItemsCategory: sidebar.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-cat[data-category=\"").concat(_constants__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS, "\"]")) - }, emptyStateElements)), - getElements = _createPageElements.getElements, - addElements = _createPageElements.addElements; - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/elements/emptyStateElement.js": -/*!*****************************************************************!*\ - !*** ./js/src/core/page-skeleton/elements/emptyStateElement.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createEmptyStateElement: () => (/* binding */ createEmptyStateElement), -/* harmony export */ getEmptyStateElements: () => (/* binding */ getEmptyStateElements) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - -var _window$frmDom = window.frmDom, - tag = _window$frmDom.tag, - div = _window$frmDom.div, - a = _window$frmDom.a, - img = _window$frmDom.img; - -/** - * Create and return the Empty State HTML element. - * - * @return {HTMLElement} The Empty State element. - */ -function createEmptyStateElement() { - var button = a({ - className: 'button button-primary frm-button-primary' - }); - button.setAttribute('role', 'button'); - return div({ - id: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state"), - className: "frm-flex-col frm-flex-center frm-gap-md ".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS), - children: [img({ - src: "".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.PLUGIN_URL, "/images/page-skeleton/empty-state.svg"), - alt: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Empty State', 'formidable') - }), div({ - className: 'frmcenter', - children: [tag('h2', { - className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title frm-mb-0") - }), tag('p', { - className: "".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text frm-mb-0") - })] - }), button] - }); -} - -/** - * Return the elements related to the Empty State. - * - * @return {Object} Object containing Empty State related DOM elements. - */ -function getEmptyStateElements() { - var emptyState = document.querySelector("#".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-empty-state")); - return { - emptyState: emptyState, - emptyStateTitle: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-title")), - emptyStateText: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-text")), - emptyStateButton: emptyState === null || emptyState === void 0 ? void 0 : emptyState.querySelector('.button') - }; -} - -/***/ }), - -/***/ "./js/src/core/page-skeleton/elements/index.js": -/*!*****************************************************!*\ - !*** ./js/src/core/page-skeleton/elements/index.js ***! - \*****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/elements.js"); - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/events/categoryListener.js": -/*!**************************************************************!*\ - !*** ./js/src/core/page-skeleton/events/categoryListener.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addCategoryEvents: () => (/* binding */ addCategoryEvents) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/core/page-skeleton/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! . */ "./js/src/core/page-skeleton/events/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - -/** - * Manages event handling for sidebar category links. - * - * @return {void} - */ -function addCategoryEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - categoryItems = _getElements.categoryItems; - - // Attach click and keyboard event listeners to each sidebar category - categoryItems.forEach(function (category) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(category, onCategoryClick); - category.addEventListener('keydown', onCategoryKeydown); - }); -} - -/** - * Handles the click event on a category item. - * - * @private - * @param {Event} event The click event object. - */ -var onCategoryClick = function onCategoryClick(event) { - var clickedCategory = event.currentTarget; - var newSelectedCategory = clickedCategory.getAttribute('data-category'); - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - selectedCategory = _getState.selectedCategory, - selectedCategoryEl = _getState.selectedCategoryEl, - notEmptySearchText = _getState.notEmptySearchText; - - // If the selected category hasn't changed, return early - if (selectedCategory === newSelectedCategory) { - return; - } - - /** - * Filter hook to modify the selected category. - * - * @param {string} selectedCategory The selected category - */ - selectedCategory = wp.hooks.applyFilters('frmPage.selectedCategory', newSelectedCategory); - - // Highlight the newly clicked category and update the application state - selectedCategoryEl.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - selectedCategoryEl = clickedCategory; - selectedCategoryEl.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setState)({ - selectedCategory: selectedCategory, - selectedCategoryEl: selectedCategoryEl - }); - - // Reset the search input if it contains text - if (notEmptySearchText) { - (0,___WEBPACK_IMPORTED_MODULE_4__.resetSearchInput)(); - } - - /** - * Trigger custom action to update category content. - * - * @param {string} selectedCategory The selected category. - */ - wp.hooks.doAction('frmPage.onCategoryClick', selectedCategory); - - // Smoothly display the updated UI elements - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - bodyContent = _getElements2.bodyContent; - new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent).fadeIn(); -}; - -/** - * Handles the keyboard event on a category item. - * - * @param {KeyboardEvent} event The keyboard event object. - * @return {void} - */ -function onCategoryKeydown(event) { - // Only respond to 'Enter' or 'Space' key presses - if (event.key === 'Enter' || event.key === ' ') { - event.preventDefault(); - onCategoryClick(event); - } -} - -/***/ }), - -/***/ "./js/src/core/page-skeleton/events/index.js": -/*!***************************************************!*\ - !*** ./js/src/core/page-skeleton/events/index.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _categoryListener__WEBPACK_IMPORTED_MODULE_1__.addCategoryEvents), -/* harmony export */ resetSearchInput: () => (/* binding */ resetSearchInput) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _categoryListener__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./categoryListener */ "./js/src/core/page-skeleton/events/categoryListener.js"); -/** - * Internal dependencies - */ - - -/** - * Resets the value of the search input and triggers an input event. - * - * @return {void} - */ -function resetSearchInput() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - searchInput = _getElements.searchInput; - searchInput.value = ''; - searchInput.dispatchEvent(new Event('input', { - bubbles: true - })); -} - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/index.js": -/*!********************************************!*\ - !*** ./js/src/core/page-skeleton/index.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), -/* harmony export */ SEARCH_RESULT_ITEM: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.SEARCH_RESULT_ITEM), -/* harmony export */ VIEWS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.VIEWS), -/* harmony export */ addCategoryEvents: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.addCategoryEvents), -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_1__.getElements), -/* harmony export */ getSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.getState), -/* harmony export */ resetSearchInput: () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_3__.resetSearchInput), -/* harmony export */ setSingleState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _shared__WEBPACK_IMPORTED_MODULE_2__.setState) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/core/page-skeleton/constants.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./shared */ "./js/src/core/page-skeleton/shared/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./events */ "./js/src/core/page-skeleton/events/index.js"); - - - - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/shared/index.js": -/*!***************************************************!*\ - !*** ./js/src/core/page-skeleton/shared/index.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_0__.setState) -/* harmony export */ }); -/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageState */ "./js/src/core/page-skeleton/shared/pageState.js"); - - -/***/ }), - -/***/ "./js/src/core/page-skeleton/shared/pageState.js": -/*!*******************************************************!*\ - !*** ./js/src/core/page-skeleton/shared/pageState.js ***! - \*******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* binding */ getSingleState), -/* harmony export */ getState: () => (/* binding */ getState), -/* harmony export */ setSingleState: () => (/* binding */ setSingleState), -/* harmony export */ setState: () => (/* binding */ setState) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/core/page-skeleton/elements/index.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../constants */ "./js/src/core/page-skeleton/constants.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - allItemsCategory = _getElements.allItemsCategory; -var _createPageState = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageState)({ - notEmptySearchText: false, - selectedCategory: _constants__WEBPACK_IMPORTED_MODULE_2__.VIEWS.ALL_ITEMS, - selectedCategoryEl: allItemsCategory - }), - getState = _createPageState.getState, - getSingleState = _createPageState.getSingleState, - setState = _createPageState.setState, - setSingleState = _createPageState.setSingleState; - - -/***/ }), - -/***/ "./js/src/core/ui/addProgressToCardBoxes.js": -/*!**************************************************!*\ - !*** ./js/src/core/ui/addProgressToCardBoxes.js ***! - \**************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Internal Dependencies - */ -var span = window.frmDom.span; - -/** - * Adds a progress bar to each card box element to visually indicate its position in the sequence. - * - * @param {Element[]} cardBoxes Collection of card box elements to enhance with progress bars. - * @return {void} - */ -function addProgressToCardBoxes(cardBoxes) { - if (!Array.isArray(cardBoxes) || !cardBoxes.length) { - console.warn('addProgressToCardBoxes: Expected a non-empty array of cardBoxes.'); - return; - } - cardBoxes.forEach(function (element, index) { - // Exclude cards that either don't require a progress bar or already include one - if (!element.classList.contains('frm-has-progress-bar') || element.querySelector('.frm-card-box-progress-bar')) { - return; - } - var progressBar = span(); - var widthPercentage = (index + 1) / cardBoxes.length * 100; - progressBar.style.width = "".concat(widthPercentage, "%"); - var progressBarContainer = span({ - className: 'frm-card-box-progress-bar', - child: progressBar - }); - element.prepend(progressBarContainer); - }); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addProgressToCardBoxes); - -/***/ }), - -/***/ "./js/src/core/ui/counter.js": -/*!***********************************!*\ - !*** ./js/src/core/ui/counter.js ***! - \***********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Updates the text content of an element with a counter value using smooth animation. - * - * @param {HTMLElement|string} element The DOM element or selector to update - * @param {number|string} value The new counter value to set - * @param {Object} options Animation options - * @param {number} options.duration Duration in milliseconds (default: 3000) - * @param {Function} options.easing Easing function (default: easeOutQuart) - * @throws {Error} When element is not found or invalid - * @return {HTMLElement} The updated element for method chaining - */ -var counter = function counter(element, value) { - var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - var targetElement = typeof element === 'string' ? document.querySelector(element) : element; - if (!targetElement || !(targetElement instanceof HTMLElement)) { - return null; - } - var targetValue = typeof value === 'number' ? value : parseInt(value, 10); - if (isNaN(targetValue)) { - console.warn('Counter: Invalid value provided, defaulting to 0'); - return setElementValueAndReturn(targetElement, '0'); - } - - // Don't run the animation if the sent value is 0 - if (targetValue === 0) { - return setElementValueAndReturn(targetElement, '0'); - } - var _options$duration = options.duration, - duration = _options$duration === void 0 ? 3000 : _options$duration, - _options$easing = options.easing, - easing = _options$easing === void 0 ? easeOutQuart : _options$easing; - var startValue = parseInt(targetElement.textContent, 10) || 0; - var change = targetValue - startValue; - - // Skip animation if no change needed - if (change === 0) { - return targetElement; - } - - // Cancel any existing animation - if (targetElement._counterAnimation) { - cancelAnimationFrame(targetElement._counterAnimation); - } - - // Start animation - targetElement.classList.add('frm-fadein'); - targetElement._counterAnimation = requestAnimationFrame(function (timestamp) { - return _animateCounter(timestamp, targetElement, startValue, targetValue, duration, change, easing); - }); - return targetElement; -}; - -/** - * Helper function to set element text content and return element - * - * @param {HTMLElement} element Target element - * @param {string|number} value Value to set - * @return {HTMLElement} The element for method chaining - */ -var setElementValueAndReturn = function setElementValueAndReturn(element, value) { - element.textContent = String(value); - return element; -}; - -/** - * Standalone animation function for counter (optimized to prevent redefinition) - * - * @param {number} timestamp Current timestamp from requestAnimationFrame - * @param {HTMLElement} element Target element to animate - * @param {number} startValue Starting counter value - * @param {number} targetValue Target counter value - * @param {number} duration Animation duration in milliseconds - * @param {number} change Total change amount (targetValue - startValue) - * @param {Function} easing Easing function - * @return {void} - */ -var _animateCounter = function animateCounter(timestamp, element, startValue, targetValue, duration, change, easing) { - if (!element._counterStartTime) { - element._counterStartTime = timestamp; - element._counterLastTimestamp = timestamp; - element._counterFrameDropCount = 0; - element._counterLastValue = startValue; - } - var frameDelta = timestamp - element._counterLastTimestamp; - var elapsed = timestamp - element._counterStartTime; - - // Performance monitoring: detect animation stuttering - // If frame gaps exceed 50ms (indicating browser lag/blocking), count as frame drop - if (frameDelta > 50 && element._counterLastTimestamp !== null) { - element._counterFrameDropCount++; - - // Fallback strategy: after 3 frame drops, abandon JS animation for CSS transition - // This prevents choppy animations when browser is under heavy load - if (element._counterFrameDropCount > 3) { - element.style.transition = "opacity ".concat(Math.max(duration - elapsed, 100), "ms ease-out"); - element.textContent = String(targetValue); - delete element._counterAnimation; - return; - } - } - - // Calculate eased progress and current value - var progress = Math.min(elapsed / duration, 1); - var easedProgress = easing(progress); - var currentValue = Math.round(startValue + change * easedProgress); - - // Only update DOM if value actually changed (reduce unnecessary reflows) - if (currentValue !== element._counterLastValue) { - element.textContent = String(currentValue); - element._counterLastValue = currentValue; - } - element._counterLastTimestamp = timestamp; - - // Continue animation or finish - if (progress < 1) { - element._counterAnimation = requestAnimationFrame(function (timestamp) { - return _animateCounter(timestamp, element, startValue, targetValue, duration, change, easing); - }); - return; - } - - // Ensure final value is exact - element.textContent = String(targetValue); - - // Clean up all counter-related properties - ['_counterAnimation', '_counterStartTime', '_counterLastTimestamp', '_counterFrameDropCount', '_counterLastValue'].forEach(function (prop) { - return delete element[prop]; - }); - element.style.removeProperty('transition'); -}; - -/** - * Easing function for smooth animation - * - * @param {number} t Progress from 0 to 1 - * @return {number} Eased value - */ -var easeOutQuart = function easeOutQuart(t) { - return 1 - Math.pow(1 - t, 4); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (counter); - -/***/ }), - -/***/ "./js/src/core/ui/index.js": -/*!*********************************!*\ - !*** ./js/src/core/ui/index.js ***! - \*********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addProgressToCardBoxes: () => (/* reexport safe */ _addProgressToCardBoxes__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ counter: () => (/* reexport safe */ _counter__WEBPACK_IMPORTED_MODULE_1__["default"]) -/* harmony export */ }); -/* harmony import */ var _addProgressToCardBoxes__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./addProgressToCardBoxes */ "./js/src/core/ui/addProgressToCardBoxes.js"); -/* harmony import */ var _counter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./counter */ "./js/src/core/ui/counter.js"); - - - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }), - -/***/ "./js/src/form-templates/elements/applicationTemplatesElement.js": -/*!***********************************************************************!*\ - !*** ./js/src/form-templates/elements/applicationTemplatesElement.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addApplicationTemplatesElement: () => (/* binding */ addApplicationTemplatesElement), -/* harmony export */ createApplicationTemplates: () => (/* binding */ createApplicationTemplates) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./elements */ "./js/src/form-templates/elements/elements.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -var _window$frmDom = window.frmDom, - tag = _window$frmDom.tag, - div = _window$frmDom.div, - span = _window$frmDom.span, - a = _window$frmDom.a, - img = _window$frmDom.img; - -// Application templates element -var applicationTemplates; - -// Base URL for the thumbnail images of applications -var thumbnailBaseURL = "".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.PLUGIN_URL, "/images/applications/thumbnails"); - -/** - * Create and return the application templates HTML element. - * - * @param {Object[]} applications Array of application objects. - * @return {void} - */ -function createApplicationTemplates(applications) { - if (!applications || !applications.length) { - return; - } - var templateItems = applications.map(function (template) { - return createTemplateItem(template); - }); - applicationTemplates = div({ - id: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-applications"), - className: core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS, - children: [tag('h2', { - text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Application Templates'), - className: 'frm-text-sm frm-mb-sm' - }), tag('ul', { - className: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-list frm-list-grid-layout"), - children: templateItems - })] - }); -} - -/** - * Create and return an individual item element for a application template. - * - * @private - * @param {Object} template The application object. - * @return {HTMLElement} Element representing a single application template. - */ -function createTemplateItem(template) { - var name = template.name, - key = template.key, - hasLiteThumbnail = template.hasLiteThumbnail, - isWebp = template.isWebp; - var thumbnailURL = hasLiteThumbnail ? isWebp ? "".concat(thumbnailBaseURL, "/").concat(key, ".webp") : "".concat(thumbnailBaseURL, "/").concat(key, ".png") : "".concat(thumbnailBaseURL, "/placeholder.svg"); - return tag('li', { - className: 'frm-card-item', - data: { - href: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.applicationsUrl, "&triggerViewApplicationModal=1&template=").concat(key), - 'frm-search-text': name.toLowerCase() - }, - children: [div({ - className: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-item-icon"), - child: img({ - src: thumbnailURL - }) - }), div({ - className: "".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-item-body"), - children: [span({ - text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Ready Made Solution', 'formidable'), - className: 'frm-meta-tag frm-orange-tag frm-text-xs' - }), tag('h3', { - text: name, - className: 'frm-text-sm frm-font-medium frm-m-0' - }), a({ - text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('See all applications', 'formidable'), - className: 'frm-text-xs frm-font-semibold', - href: _shared__WEBPACK_IMPORTED_MODULE_2__.applicationsUrl - })] - })] - }); -} - -/** - * Inject application Templates elements into the DOM and the elements object. - * - * @return {void} - */ -function addApplicationTemplatesElement() { - var elements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(); - if (elements.applicationTemplates || undefined === applicationTemplates) { - return; - } - elements.bodyContent.append(applicationTemplates); - (0,_elements__WEBPACK_IMPORTED_MODULE_3__.addElements)({ - applicationTemplates: applicationTemplates, - applicationTemplatesTitle: applicationTemplates.querySelector('h2'), - applicationTemplatesList: applicationTemplates.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-list")), - applicationTemplateItems: applicationTemplates.querySelectorAll('.frm-card-item') - }); -} - -/***/ }), - -/***/ "./js/src/form-templates/elements/elements.js": -/*!****************************************************!*\ - !*** ./js/src/form-templates/elements/elements.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -var _document$getElementB, _document$getElementB2; -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - -var _getElements = (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - bodyContent = _getElements.bodyContent; -var templatesList = document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-list")); -var customTemplatesSection = document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-custom-list-section")); -var favoritesCategory = document.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_shared__WEBPACK_IMPORTED_MODULE_1__.VIEW_SLUGS.FAVORITES, "\"]")); -var modal = document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-modal")); -(0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addElements)({ - // Body elements - headerCancelButton: (_document$getElementB = document.getElementById('frm-publishing')) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.querySelector('a'), - createFormButton: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-create-form")), - pageTitle: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-page-title")), - pageTitleText: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-page-title-text")), - pageTitleDivider: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-page-title-divider")), - upsellBanner: (_document$getElementB2 = document.getElementById('frm-renew-subscription-banner')) !== null && _document$getElementB2 !== void 0 ? _document$getElementB2 : document.getElementById('frm-upgrade-banner'), - extraTemplateCountElements: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-extra-templates-count")), - // Templates elements - templatesList: templatesList, - templateItems: templatesList.querySelectorAll('.frm-card-item'), - availableTemplateItems: templatesList.querySelectorAll(".frm-card-item:not(.".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-locked-item)")), - twinFeaturedTemplateItems: templatesList.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-featured-item")), - featuredTemplatesList: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-featured-list")), - // Custom Templates Section elements - customTemplatesSection: customTemplatesSection, - customTemplateItems: customTemplatesSection.querySelectorAll('.frm-card-item'), - customTemplatesTitle: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-custom-list-title")), - customTemplatesList: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-custom-list")), - // Sidebar elements - favoritesCategory: favoritesCategory, - favoritesCategoryCountEl: favoritesCategory === null || favoritesCategory === void 0 ? void 0 : favoritesCategory.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat-count")), - availableTemplatesCategory: document.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat[data-category=\"").concat(_shared__WEBPACK_IMPORTED_MODULE_1__.VIEW_SLUGS.AVAILABLE_TEMPLATES, "\"]")), - getFreeTemplatesBannerButton: document.querySelector('.frm-get-free-templates-banner .button'), - // Modal elements - modal: modal, - modalItems: modal === null || modal === void 0 ? void 0 : modal.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-modal-item")), - // Create New Template Modal - showCreateTemplateModalButton: document.getElementById('frm-show-create-template-modal'), - createTemplateModal: document.getElementById('frm-create-template-modal'), - createTemplateFormsDropdown: document.getElementById('frm-create-template-modal-forms-select'), - createTemplateName: document.getElementById('frm_create_template_name'), - createTemplateDescription: document.getElementById('frm_create_template_description'), - createTemplateButton: document.getElementById('frm-create-template-button'), - // Renew Account Modal - renewAccountModal: document.getElementById('frm-renew-modal'), - // Leave Email Modal - leaveEmailModal: document.getElementById('frm-leave-email-modal'), - leaveEmailModalInput: document.getElementById('frm_leave_email'), - leaveEmailModalButton: document.getElementById('frm-get-code-button'), - // Upgrade Modal - upgradeModal: document.getElementById('frm-form-upgrade-modal'), - upgradeModalTemplateNames: modal === null || modal === void 0 ? void 0 : modal.querySelectorAll('.frm-upgrade-modal-template-name'), - upgradeModalPlansIcons: modal === null || modal === void 0 ? void 0 : modal.querySelectorAll('.frm-upgrade-modal-plan-icon'), - upgradeModalLink: document.getElementById('frm-upgrade-modal-link'), - // New Template Form elements - newTemplateForm: document.getElementById('frm-new-template'), - newTemplateNameInput: document.getElementById('frm_template_name'), - newTemplateDescriptionInput: document.getElementById('frm_template_desc'), - newTemplateLinkInput: document.getElementById('frm_link'), - newTemplateActionInput: document.getElementById('frm_action_type'), - // Add children of the bodyContent to the elements object. - bodyContentChildren: bodyContent === null || bodyContent === void 0 ? void 0 : bodyContent.children -}); - - -/***/ }), - -/***/ "./js/src/form-templates/elements/index.js": -/*!*************************************************!*\ - !*** ./js/src/form-templates/elements/index.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addApplicationTemplatesElement: () => (/* reexport safe */ _applicationTemplatesElement__WEBPACK_IMPORTED_MODULE_1__.addApplicationTemplatesElement), -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ createApplicationTemplates: () => (/* reexport safe */ _applicationTemplatesElement__WEBPACK_IMPORTED_MODULE_1__.createApplicationTemplates), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/form-templates/elements/elements.js"); -/* harmony import */ var _applicationTemplatesElement__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./applicationTemplatesElement */ "./js/src/form-templates/elements/applicationTemplatesElement.js"); - - - -/***/ }), - -/***/ "./js/src/form-templates/events/applicationTemplateListener.js": -/*!*********************************************************************!*\ - !*** ./js/src/form-templates/events/applicationTemplateListener.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addApplicationTemplateEvents: () => (/* binding */ addApplicationTemplateEvents) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/** - * Internal dependencies - */ - - -/** - * Manages event handling for an application template. - * - * @return {void} - */ -function addApplicationTemplateEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - applicationTemplateItems = _getElements.applicationTemplateItems; - if (undefined === applicationTemplateItems) { - return; - } - - // Attach click event listener - applicationTemplateItems.forEach(function (template) { - template.addEventListener('click', onApplicationTemplateClick); - }); -} - -/** - * Handles the click event on an application template. - * - * @private - * @param {Event} event The click event object. - * @return {void} - */ -var onApplicationTemplateClick = function onApplicationTemplateClick(event) { - // Check if the clicked element is an anchor tag - if (event.target.closest('a')) { - return; - } - var applicationTemplate = event.currentTarget; - window.location.href = applicationTemplate.dataset.href; -}; - -/***/ }), - -/***/ "./js/src/form-templates/events/createFormButtonListener.js": -/*!******************************************************************!*\ - !*** ./js/src/form-templates/events/createFormButtonListener.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -/** - * Manages event handling for the "Create a blank form" button. - * - * @return {void} - */ -function addCreateFormButtonEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - createFormButton = _getElements.createFormButton; - - // Attach click event listener - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(createFormButton, onCreateFormButtonClick); -} - -/** - * Handles the click event on the "Create a blank form" button. - * - * @private - * @return {void} - */ -var onCreateFormButtonClick = function onCreateFormButtonClick() { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - createFormButton = _getElements2.createFormButton, - newTemplateForm = _getElements2.newTemplateForm, - newTemplateNameInput = _getElements2.newTemplateNameInput, - newTemplateActionInput = _getElements2.newTemplateActionInput; - var installNewForm = window.frmAdminBuild.installNewForm; - newTemplateNameInput.value = ''; - newTemplateActionInput.value = 'frm_install_form'; - installNewForm(newTemplateForm, 'frm_install_form', createFormButton); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addCreateFormButtonEvents); - -/***/ }), - -/***/ "./js/src/form-templates/events/createTemplateListeners.js": -/*!*****************************************************************!*\ - !*** ./js/src/form-templates/events/createTemplateListeners.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - - -/** - * Manages event handling for the 'Create New Template' modal. - * - * @return {void} - */ -function addCreateTemplateEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - createTemplateFormsDropdown = _getElements.createTemplateFormsDropdown, - createTemplateButton = _getElements.createTemplateButton, - showCreateTemplateModalButton = _getElements.showCreateTemplateModalButton, - emptyStateButton = _getElements.emptyStateButton; - - // Show the 'Create New Template' modal when either empty state or show modal button is clicked - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(showCreateTemplateModalButton, onShowCreateTemplateModalButtonClick); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(emptyStateButton, onShowCreateTemplateModalButtonClick); - - // Handle changes in the forms selection dropdown for creating a new template - createTemplateFormsDropdown.addEventListener('change', onFormsSelectChange); - - // Create a new template when the create button inside the modal is clicked - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(createTemplateButton, onCreateTemplateButtonClick); -} - -/** - * Handles the click event on the 'Create Template' button, showing the 'Create New Template' modal. - * - * @private - * @return {void} - */ -var onShowCreateTemplateModalButtonClick = function onShowCreateTemplateModalButtonClick() { - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - selectedCategory = _getState.selectedCategory; - if (!(0,_utils__WEBPACK_IMPORTED_MODULE_5__.isCustomCategory)(selectedCategory)) { - return; - } - (0,_ui__WEBPACK_IMPORTED_MODULE_4__.showCreateTemplateModal)(); -}; - -/** - * Handles changes in the forms selection dropdown for creating a new template. - * - * @private - * @return {void} - */ -var onFormsSelectChange = function onFormsSelectChange() { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - formsSelect = _getElements2.createTemplateFormsDropdown; - var formId = formsSelect.value; - if (!formId || formId === 'no-forms') { - toggleDisableModalElements(true); - return; - } - toggleDisableModalElements(false); - var selectedOption = formsSelect.options[formsSelect.selectedIndex]; - var formDescription = selectedOption.dataset.description.trim(); - var formName = selectedOption.dataset.name.trim(); - var templateString = " ".concat((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Template', 'formidable')); - if (!formName.endsWith(templateString)) { - formName += templateString; - } - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - createTemplateName = _getElements3.createTemplateName, - createTemplateDescription = _getElements3.createTemplateDescription; - createTemplateName.value = formName; - createTemplateDescription.value = formDescription; -}; - -/** - * Toggles the disabled state of elements in the 'Create Template' modal. - * - * @private - * @param {boolean} shouldDisable True to disable, false to enable. - * @return {void} - */ -var toggleDisableModalElements = function toggleDisableModalElements(shouldDisable) { - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - createTemplateName = _getElements4.createTemplateName, - createTemplateDescription = _getElements4.createTemplateDescription, - createTemplateButton = _getElements4.createTemplateButton; - - // Toggle the disabled attribute for input and textarea - [createTemplateName, createTemplateDescription].forEach(function (element) { - element.disabled = shouldDisable; - if (shouldDisable) { - element.value = ''; // Clear the content for input and textarea - } - }); - - // Toggle the disabled class for the button - createTemplateButton.classList.toggle('disabled', shouldDisable); -}; - -/** - * Handles the click event on the 'Create Template' button to create a new template. - * - * @private - * @return {void} - */ -var onCreateTemplateButtonClick = function onCreateTemplateButtonClick() { - var installNewForm = window.frmAdminBuild.installNewForm; - var actionName = 'frm_create_template'; - var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - newTemplateForm = _getElements5.newTemplateForm, - newTemplateActionInput = _getElements5.newTemplateActionInput, - newTemplateNameInput = _getElements5.newTemplateNameInput, - newTemplateDescriptionInput = _getElements5.newTemplateDescriptionInput, - newTemplateLinkInput = _getElements5.newTemplateLinkInput, - createTemplateName = _getElements5.createTemplateName, - createTemplateDescription = _getElements5.createTemplateDescription, - createTemplateFormsDropdown = _getElements5.createTemplateFormsDropdown, - createTemplateButton = _getElements5.createTemplateButton; - newTemplateActionInput.value = actionName; - newTemplateNameInput.value = createTemplateName.value.trim(); - newTemplateDescriptionInput.value = createTemplateDescription.value.trim(); - newTemplateLinkInput.value = createTemplateFormsDropdown.value; - - // Install new form template - installNewForm(newTemplateForm, actionName, createTemplateButton); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addCreateTemplateEvents); - -/***/ }), - -/***/ "./js/src/form-templates/events/favoriteButtonListener.js": -/*!****************************************************************!*\ - !*** ./js/src/form-templates/events/favoriteButtonListener.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - -var FAVORITE_BUTTON_CLASS = ".".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-item-favorite-button"); -var HEART_ICON_SELECTOR = "".concat(FAVORITE_BUTTON_CLASS, " use"); -var FILLED_HEART_ICON = '#frm_heart_solid_icon'; -var LINEAR_HEART_ICON = '#frm_heart_icon'; -var OPERATION = { - ADD: 'add', - REMOVE: 'remove' -}; - -/** - * Manages event handling for favorite buttons. - * - * @return {void} - */ -function addFavoriteButtonEvents() { - var favoriteButtons = document.querySelectorAll(FAVORITE_BUTTON_CLASS); - - // Attach click event listeners to each favorite button - favoriteButtons.forEach(function (favoriteButton) { - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(favoriteButton, onFavoriteButtonClick); - }); -} - -/** - * Handles the click event on the add to favorite button. - * - * @private - * @param {Event} event The click event object. - * @return {void} - */ -var onFavoriteButtonClick = function onFavoriteButtonClick(event) { - var _twinFeaturedTemplate; - var favoriteButton = event.currentTarget; - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - templatesList = _getElements.templatesList, - featuredTemplatesList = _getElements.featuredTemplatesList, - favoritesCategoryCountEl = _getElements.favoritesCategoryCountEl, - customTemplatesTitle = _getElements.customTemplatesTitle; - - /** - * Get necessary template information - */ - var template = favoriteButton.closest('.frm-card-item'); - var templateId = template.dataset.id; - var isFavorited = (0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFavoriteTemplate)(template); - var isTemplateCustom = (0,_utils__WEBPACK_IMPORTED_MODULE_4__.isCustomTemplate)(template); - var isTemplateFeatured = (0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFeaturedTemplate)(template); - - /** - * Toggle the favorite status in the UI. - * If template is featured, toggle its twin version in the respective list. - */ - var twinFeaturedTemplate = null; - template.classList.toggle("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-favorite-item"), !isFavorited); - if (isTemplateFeatured) { - var templateList = template.closest("#".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-list")) ? featuredTemplatesList : templatesList; - if (templateList) { - twinFeaturedTemplate = templateList.querySelector(".frm-card-item[data-id=\"".concat(templateId, "\"]")); - // Toggle twin template's favorite status - twinFeaturedTemplate.classList.toggle("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-favorite-item"), !isFavorited); - } - } - - /** - * Update favorite counts and icons based on the new state - */ - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_2__.getState)(), - selectedCategory = _getState.selectedCategory, - favoritesCount = _getState.favoritesCount; - var currentOperation = isFavorited ? OPERATION.REMOVE : OPERATION.ADD; - var heartIcon = template.querySelector(HEART_ICON_SELECTOR); - var twinTemplateHeartIcon = (_twinFeaturedTemplate = twinFeaturedTemplate) === null || _twinFeaturedTemplate === void 0 ? void 0 : _twinFeaturedTemplate.querySelector(HEART_ICON_SELECTOR); - if (OPERATION.ADD === currentOperation) { - // Increment favorite counts - ++favoritesCount.total; - if (isTemplateCustom) { - ++favoritesCount.custom; - } else { - ++favoritesCount.default; - } - // Set heart icon to filled - heartIcon.setAttribute('href', FILLED_HEART_ICON); - twinTemplateHeartIcon === null || twinTemplateHeartIcon === void 0 || twinTemplateHeartIcon.setAttribute('href', FILLED_HEART_ICON); - } else { - // Decrement favorite counts - --favoritesCount.total; - if (isTemplateCustom) { - --favoritesCount.custom; - } else { - --favoritesCount.default; - } - // Set heart icon to outline - heartIcon.setAttribute('href', LINEAR_HEART_ICON); - twinTemplateHeartIcon === null || twinTemplateHeartIcon === void 0 || twinTemplateHeartIcon.setAttribute('href', LINEAR_HEART_ICON); - } - - // Update UI and state to reflect new favorite counts - favoritesCategoryCountEl.textContent = favoritesCount.total; - (0,_shared__WEBPACK_IMPORTED_MODULE_2__.setSingleState)('favoritesCount', favoritesCount); - - /** - * Hide UI elements if 'Favorites' is active and counts are zero. - */ - if ((0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFavoritesCategory)(selectedCategory)) { - if (0 === favoritesCount.total) { - (0,_ui__WEBPACK_IMPORTED_MODULE_3__.showFavoritesEmptyState)(); - } - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(template); - if (0 === favoritesCount.default) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(templatesList); - } - if (0 === favoritesCount.custom || 0 === favoritesCount.default) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(customTemplatesTitle); - } - } - - // Update server-side data for favorite templates - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.addToRequestQueue)(function () { - return updateFavoriteTemplate(templateId, currentOperation, isTemplateCustom); - }); -}; - -/** - * Update server-side data for favorite templates. - * - * @param {string} id The template ID. - * @param {string} operation The operation to perform ('add' or 'remove'). - * @param {boolean} isCustom Flag indicating whether the template is custom. - * @return {Promise} The result of the server-side update. - */ -function updateFavoriteTemplate(id, operation, isCustom) { - var formData = new FormData(); - var doJsonPost = frmDom.ajax.doJsonPost; - formData.append('template_id', id); - formData.append('operation', operation); - formData.append('is_custom_template', isCustom); - return doJsonPost('add_or_remove_favorite_template', formData); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addFavoriteButtonEvents); - -/***/ }), - -/***/ "./js/src/form-templates/events/getFreeTemplatesListener.js": -/*!******************************************************************!*\ - !*** ./js/src/form-templates/events/getFreeTemplatesListener.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * External dependencies - */ - -var tag = window.frmDom.tag; - -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - - - -/** - * Manages event handling for the "Get Templates" button. - * - * @return {void} - */ -function addGetFreeTemplatesEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - leaveEmailModalButton = _getElements.leaveEmailModalButton, - getFreeTemplatesBannerButton = _getElements.getFreeTemplatesBannerButton; - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(leaveEmailModalButton, onGetTemplatesButtonClick); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(getFreeTemplatesBannerButton, _ui__WEBPACK_IMPORTED_MODULE_3__.showLeaveEmailModal); -} - -/** - * Handles the click event on the "Get Templates" button. - * - * @private - * @return {void} - */ -var onGetTemplatesButtonClick = /*#__PURE__*/function () { - var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { - var _getElements2, leaveEmailModalInput, email, _getElements3, leaveEmailModalButton, formData, data, doJsonPost, _t; - return _regenerator().w(function (_context) { - while (1) switch (_context.p = _context.n) { - case 0: - _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), leaveEmailModalInput = _getElements2.leaveEmailModalInput; - email = leaveEmailModalInput.value.trim(); // Check if the email field is empty - if (email) { - _context.n = 1; - break; - } - (0,_ui__WEBPACK_IMPORTED_MODULE_3__.showEmailAddressError)('empty'); - return _context.a(2); - case 1: - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isValidEmail)(email)) { - _context.n = 2; - break; - } - (0,_ui__WEBPACK_IMPORTED_MODULE_3__.showEmailAddressError)('invalid'); - return _context.a(2); - case 2: - // Disable the button - _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), leaveEmailModalButton = _getElements3.leaveEmailModalButton; - leaveEmailModalButton.style.setProperty('cursor', 'not-allowed'); - leaveEmailModalButton.classList.add('frm_loading_button'); - formData = new FormData(); - formData.append('email', email); - doJsonPost = frmDom.ajax.doJsonPost; - _context.p = 3; - _context.n = 4; - return doJsonPost('get_free_templates', formData); - case 4: - data = _context.v; - _context.n = 6; - break; - case 5: - _context.p = 5; - _t = _context.v; - console.error('An error occurred:', _t); - showFailedToGetTemplates(); - return _context.a(2); - case 6: - if (data.success) { - _context.n = 7; - break; - } - showFailedToGetTemplates(); - return _context.a(2); - case 7: - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hasQueryParam)('free-templates')) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.removeQueryParam)('free-templates'); - } - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.setQueryParam)('registered-for-free-templates', '1'); - window.location.reload(); - case 8: - return _context.a(2); - } - }, _callee, null, [[3, 5]]); - })); - return function onGetTemplatesButtonClick() { - return _ref.apply(this, arguments); - }; -}(); - -/** - * Shows a message indicating that templates could not be retrieved. - * - * @private - * @return {void} - */ -function showFailedToGetTemplates() { - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - leaveEmailModal = _getElements4.leaveEmailModal; - leaveEmailModal.querySelector('.inside').replaceChildren(tag('p', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Failed to get templates, please try again later.', 'formidable'))); - leaveEmailModal.querySelector('.frm_modal_footer').classList.add('frm_hidden'); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addGetFreeTemplatesEvents); - -/***/ }), - -/***/ "./js/src/form-templates/events/index.js": -/*!***********************************************!*\ - !*** ./js/src/form-templates/events/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addApplicationTemplateEvents: () => (/* reexport safe */ _applicationTemplateListener__WEBPACK_IMPORTED_MODULE_8__.addApplicationTemplateEvents), -/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _createFormButtonListener__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createFormButtonListener */ "./js/src/form-templates/events/createFormButtonListener.js"); -/* harmony import */ var _favoriteButtonListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./favoriteButtonListener */ "./js/src/form-templates/events/favoriteButtonListener.js"); -/* harmony import */ var _useTemplateButtonListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./useTemplateButtonListener */ "./js/src/form-templates/events/useTemplateButtonListener.js"); -/* harmony import */ var _searchListener__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./searchListener */ "./js/src/form-templates/events/searchListener.js"); -/* harmony import */ var _createTemplateListeners__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createTemplateListeners */ "./js/src/form-templates/events/createTemplateListeners.js"); -/* harmony import */ var _getFreeTemplatesListener__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./getFreeTemplatesListener */ "./js/src/form-templates/events/getFreeTemplatesListener.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); -/* harmony import */ var _applicationTemplateListener__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./applicationTemplateListener */ "./js/src/form-templates/events/applicationTemplateListener.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - - - - - -/** - * Attaches event listeners for handling user interactions. - * - * @return {void} - */ -function addEventListeners() { - (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.addCategoryEvents)(); - wp.hooks.addAction('frmPage.onCategoryClick', 'frmFormTemplates', function (selectedCategory) { - // Display templates of the selected category - (0,_ui__WEBPACK_IMPORTED_MODULE_7__.showSelectedCategory)(selectedCategory); - }); - (0,_createFormButtonListener__WEBPACK_IMPORTED_MODULE_1__["default"])(); - (0,_favoriteButtonListener__WEBPACK_IMPORTED_MODULE_2__["default"])(); - (0,_useTemplateButtonListener__WEBPACK_IMPORTED_MODULE_3__["default"])(); - (0,_searchListener__WEBPACK_IMPORTED_MODULE_4__["default"])(); - (0,_createTemplateListeners__WEBPACK_IMPORTED_MODULE_5__["default"])(); - (0,_getFreeTemplatesListener__WEBPACK_IMPORTED_MODULE_6__["default"])(); -} - - -/***/ }), - -/***/ "./js/src/form-templates/events/searchListener.js": -/*!********************************************************!*\ - !*** ./js/src/form-templates/events/searchListener.js ***! - \********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../ui */ "./js/src/form-templates/ui/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - -var initSearch = window.frmDom.search.init; - -/** - * Adds search-related event listeners by calling the 'initSearch' function. - * - * @see frmDom.search method - * @return {void} - */ -function addSearchEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - searchInput = _getElements.searchInput, - emptyStateButton = _getElements.emptyStateButton; - initSearch(searchInput, 'frm-card-item', { - handleSearchResult: handleSearchResult - }); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(emptyStateButton, onEmptyStateButtonClick); -} - -/** - * Manages UI state based on search results and input value. - * - * @private - * @param {Object} args Contains flags for search status. - * @param {boolean} args.foundSomething True if search yielded results. - * @param {boolean} args.notEmptySearchText True if search input is not empty. - * @param {Event} event The event object (input, search, or change event). - * @return {void} - */ -function handleSearchResult(_ref, event) { - var foundSomething = _ref.foundSomething, - notEmptySearchText = _ref.notEmptySearchText; - // Prevent double calls as window.frmDom.search.init attaches both 'input' and 'search' events, - // triggering this method twice on 'x' button click. - if (event && event.type === 'search' && event.target.value === '') { - return; - } - var state = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(); - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - allItemsCategory = _getElements2.allItemsCategory; - (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('notEmptySearchText', notEmptySearchText); - - // Revert to 'All Templates' if search and selected category are both empty - if (!state.notEmptySearchText && !state.selectedCategory) { - allItemsCategory.dispatchEvent(new Event('click', { - bubbles: true - })); - return; - } - - // Display search state if a category is selected - if (state.selectedCategory) { - (0,_ui__WEBPACK_IMPORTED_MODULE_4__.showSearchState)(notEmptySearchText); - - // Setting "selectedCategory" to an empty string as a flag for search state - if (notEmptySearchText) { - (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('selectedCategory', ''); - } - } - (0,_ui__WEBPACK_IMPORTED_MODULE_4__.displaySearchElements)(foundSomething, notEmptySearchText); -} - -/** - * Handles the click event on the empty state button. - * - * @private - * @return {void} - */ -var onEmptyStateButtonClick = function onEmptyStateButtonClick() { - var _emptyState$dataset; - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - emptyState = _getElements3.emptyState; - if (_shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.SEARCH !== ((_emptyState$dataset = emptyState.dataset) === null || _emptyState$dataset === void 0 ? void 0 : _emptyState$dataset.view)) { - return; - } - - // Set selectedCategory to '' as search state flag that triggers ALL_ITEMS category if search input is empty - // @see handleSearchResult() - (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('selectedCategory', ''); - (0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.resetSearchInput)(); - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - searchInput = _getElements4.searchInput; - searchInput.focus(); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addSearchEvents); - -/***/ }), - -/***/ "./js/src/form-templates/events/useTemplateButtonListener.js": -/*!*******************************************************************!*\ - !*** ./js/src/form-templates/events/useTemplateButtonListener.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _ui___WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../ui/ */ "./js/src/form-templates/ui/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); -/** - * Internal dependencies - */ - - - - - -/** - * Manages event handling for use template buttons. - * - * @return {void} - */ -function addUseTemplateButtonEvents() { - var useTemplateButtons = document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-use-template-button")); - - // Attach click event listeners to each use template button - useTemplateButtons.forEach(function (useTemplateButton) { - return useTemplateButton.addEventListener('click', onUseTemplateButtonClick); - }); -} - -/** - * Handles the click event on the use template button. - * - * @private - * @param {Event} event The click event object. - * @return {void} - */ -var onUseTemplateButtonClick = function onUseTemplateButtonClick(event) { - var useTemplateButton = event.currentTarget; - var template = useTemplateButton.closest('.frm-card-item'); - var isLocked = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.isLockedTemplate)(template); - var isTemplateCustom = (0,_utils__WEBPACK_IMPORTED_MODULE_3__.isCustomTemplate)(template); - - // Allow the default link behavior, if the template is custom and not locked - if (!isLocked && isTemplateCustom) { - return; - } - - // Prevent the default link behavior for non-custom or locked templates - event.preventDefault(); - - // Handle locked templates - if (isLocked) { - (0,_ui___WEBPACK_IMPORTED_MODULE_2__.showLockedTemplateModal)(template); - return; - } - - // Prepare for new template installation - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - newTemplateForm = _getElements.newTemplateForm, - newTemplateNameInput = _getElements.newTemplateNameInput, - newTemplateDescriptionInput = _getElements.newTemplateDescriptionInput, - newTemplateLinkInput = _getElements.newTemplateLinkInput, - newTemplateActionInput = _getElements.newTemplateActionInput; - var installNewForm = window.frmAdminBuild.installNewForm; - var templateName = template.querySelector('.frm-form-template-name').textContent.trim(); - var templateDescription = template.querySelector('.frm-form-templates-item-description').textContent.trim(); - var actionName = 'frm_install_template'; - newTemplateNameInput.value = templateName; - newTemplateDescriptionInput.value = templateDescription; - newTemplateActionInput.value = actionName; - newTemplateLinkInput.value = useTemplateButton.href; - - // Install new form template - installNewForm(newTemplateForm, actionName, useTemplateButton); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addUseTemplateButtonEvents); - -/***/ }), - -/***/ "./js/src/form-templates/initializeFormTemplates.js": -/*!**********************************************************!*\ - !*** ./js/src/form-templates/initializeFormTemplates.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/form-templates/ui/index.js"); -/* harmony import */ var _templates__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./templates */ "./js/src/form-templates/templates/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./events */ "./js/src/form-templates/events/index.js"); -/** - * Internal dependencies - */ - - - - -/** - * Initializes form templates. - * - * @return {void} - */ -function initializeFormTemplates() { - (0,_templates__WEBPACK_IMPORTED_MODULE_1__.maybeAddApplicationTemplates)(); - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeModal)(); - (0,_templates__WEBPACK_IMPORTED_MODULE_1__.buildCategorizedTemplates)(); - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.setupInitialView)(); - (0,_events__WEBPACK_IMPORTED_MODULE_2__.addEventListeners)(); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeFormTemplates); - -/***/ }), - -/***/ "./js/src/form-templates/shared/constants.js": -/*!***************************************************!*\ - !*** ./js/src/form-templates/shared/constants.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ FEATURED_TEMPLATES_IDS: () => (/* binding */ FEATURED_TEMPLATES_IDS), -/* harmony export */ FREE_TEMPLATES_IDS: () => (/* binding */ FREE_TEMPLATES_IDS), -/* harmony export */ MODAL_SIZES: () => (/* binding */ MODAL_SIZES), -/* harmony export */ PLANS: () => (/* binding */ PLANS), -/* harmony export */ PREFIX: () => (/* binding */ PREFIX), -/* harmony export */ VIEW_SLUGS: () => (/* binding */ VIEW_SLUGS), -/* harmony export */ applicationsUrl: () => (/* binding */ applicationsUrl), -/* harmony export */ canAccessApplicationDashboard: () => (/* binding */ canAccessApplicationDashboard), -/* harmony export */ upgradeLink: () => (/* binding */ upgradeLink) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - canAccessApplicationDashboard = _window$frmGlobal.canAccessApplicationDashboard, - applicationsUrl = _window$frmGlobal.applicationsUrl; - -var _window$frmFormTempla = window.frmFormTemplatesVars, - FEATURED_TEMPLATES_IDS = _window$frmFormTempla.FEATURED_TEMPLATES_IDS, - FREE_TEMPLATES_IDS = _window$frmFormTempla.FREE_TEMPLATES_IDS, - upgradeLink = _window$frmFormTempla.upgradeLink; - -var PREFIX = 'frm-form-templates'; -var VIEW_SLUGS = { - AVAILABLE_TEMPLATES: 'available-templates', - FAVORITES: 'favorites', - CUSTOM: 'custom', - SEARCH: 'search' -}; -var PLANS = { - BASIC: 'basic', - PLUS: 'plus', - BUSINESS: 'business', - ELITE: 'elite', - RENEW: 'renew', - FREE: 'free' -}; -var MODAL_SIZES = { - GENERAL: '440px', - CREATE_TEMPLATE: '550px' -}; - -/***/ }), - -/***/ "./js/src/form-templates/shared/index.js": -/*!***********************************************!*\ - !*** ./js/src/form-templates/shared/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ FEATURED_TEMPLATES_IDS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.FEATURED_TEMPLATES_IDS), -/* harmony export */ FREE_TEMPLATES_IDS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.FREE_TEMPLATES_IDS), -/* harmony export */ MODAL_SIZES: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.MODAL_SIZES), -/* harmony export */ PLANS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PLANS), -/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), -/* harmony export */ VIEW_SLUGS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.VIEW_SLUGS), -/* harmony export */ applicationsUrl: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.applicationsUrl), -/* harmony export */ canAccessApplicationDashboard: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.canAccessApplicationDashboard), -/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setState), -/* harmony export */ upgradeLink: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.upgradeLink) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/form-templates/shared/constants.js"); -/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageState */ "./js/src/form-templates/shared/pageState.js"); - - - -/***/ }), - -/***/ "./js/src/form-templates/shared/pageState.js": -/*!***************************************************!*\ - !*** ./js/src/form-templates/shared/pageState.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setState) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - -var _window$frmFormTempla = window.frmFormTemplatesVars, - templatesCount = _window$frmFormTempla.templatesCount, - favoritesCount = _window$frmFormTempla.favoritesCount, - customCount = _window$frmFormTempla.customCount; -var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - availableTemplateItems = _getElements.availableTemplateItems; -var availableTemplatesCount = availableTemplateItems.length; -(0,core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.setState)({ - availableTemplatesCount: availableTemplatesCount, - customCount: Number(customCount), - extraTemplatesCount: templatesCount - availableTemplatesCount, - favoritesCount: favoritesCount -}); - - -/***/ }), - -/***/ "./js/src/form-templates/templates/applicationTemplates.js": -/*!*****************************************************************!*\ - !*** ./js/src/form-templates/templates/applicationTemplates.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ maybeAddApplicationTemplates: () => (/* binding */ maybeAddApplicationTemplates) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ "./js/src/form-templates/events/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/** - * Internal dependencies - */ - - - - -/** - * Adds application templates if the user has dashboard access. - * - * @return {void} - */ -function maybeAddApplicationTemplates() { - // Exit if the user doesn't have permission to see application dashboard - if (!_shared__WEBPACK_IMPORTED_MODULE_2__.canAccessApplicationDashboard) { - return; - } - var doJsonFetch = frmDom.ajax.doJsonFetch; - doJsonFetch('get_applications_data&view=templates').then(setupApplicationTemplates); -} - -/** - * Sets up application templates by creating HTML elements, injecting them into the DOM, - * and adding event handlers. - * - * @private - * @param {Object} data The data object containing information for application templates. - * @return {void} - */ -function setupApplicationTemplates(data) { - // Create application templates - (0,_elements__WEBPACK_IMPORTED_MODULE_0__.createApplicationTemplates)(data.templates); - - // Inject templates into the DOM - (0,_elements__WEBPACK_IMPORTED_MODULE_0__.addApplicationTemplatesElement)(); - - // Set up event handling - (0,_events__WEBPACK_IMPORTED_MODULE_1__.addApplicationTemplateEvents)(); -} - -/***/ }), - -/***/ "./js/src/form-templates/templates/categorizeTemplates.js": -/*!****************************************************************!*\ - !*** ./js/src/form-templates/templates/categorizeTemplates.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ buildCategorizedTemplates: () => (/* binding */ buildCategorizedTemplates), -/* harmony export */ categorizedTemplates: () => (/* binding */ categorizedTemplates) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/** - * Internal dependencies - */ - -var categorizedTemplates = {}; - -/** - * Builds a categorized list of templates. - * - * @return {void} - */ -function buildCategorizedTemplates() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - templateItems = _getElements.templateItems; - templateItems.forEach(function (template) { - // Extract and split the categories from data attribute - var categories = template.getAttribute('data-categories').split(','); - categories.forEach(function (category) { - // Initialize the category array if not already done - if (!categorizedTemplates[category]) { - categorizedTemplates[category] = []; - } - - // Add the template to the appropriate category - categorizedTemplates[category].push(template); - }); - }); -} - -/***/ }), - -/***/ "./js/src/form-templates/templates/index.js": -/*!**************************************************!*\ - !*** ./js/src/form-templates/templates/index.js ***! - \**************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ buildCategorizedTemplates: () => (/* reexport safe */ _categorizeTemplates__WEBPACK_IMPORTED_MODULE_0__.buildCategorizedTemplates), -/* harmony export */ categorizedTemplates: () => (/* reexport safe */ _categorizeTemplates__WEBPACK_IMPORTED_MODULE_0__.categorizedTemplates), -/* harmony export */ maybeAddApplicationTemplates: () => (/* reexport safe */ _applicationTemplates__WEBPACK_IMPORTED_MODULE_1__.maybeAddApplicationTemplates) -/* harmony export */ }); -/* harmony import */ var _categorizeTemplates__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./categorizeTemplates */ "./js/src/form-templates/templates/categorizeTemplates.js"); -/* harmony import */ var _applicationTemplates__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./applicationTemplates */ "./js/src/form-templates/templates/applicationTemplates.js"); - - - -/***/ }), - -/***/ "./js/src/form-templates/ui/index.js": -/*!*******************************************!*\ - !*** ./js/src/form-templates/ui/index.js ***! - \*******************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ displaySearchElements: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_5__.displaySearchElements), -/* harmony export */ getModalWidget: () => (/* reexport safe */ _initializeModal__WEBPACK_IMPORTED_MODULE_1__.getModalWidget), -/* harmony export */ initializeModal: () => (/* reexport safe */ _initializeModal__WEBPACK_IMPORTED_MODULE_1__.initializeModal), -/* harmony export */ setupInitialView: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ showAllTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showAllTemplates), -/* harmony export */ showAvailableTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showAvailableTemplates), -/* harmony export */ showAvailableTemplatesEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showAvailableTemplatesEmptyState), -/* harmony export */ showCreateTemplateModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showCreateTemplateModal), -/* harmony export */ showCustomTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showCustomTemplates), -/* harmony export */ showCustomTemplatesEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showCustomTemplatesEmptyState), -/* harmony export */ showEmailAddressError: () => (/* reexport safe */ _showError__WEBPACK_IMPORTED_MODULE_8__.showEmailAddressError), -/* harmony export */ showFavoriteTemplates: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showFavoriteTemplates), -/* harmony export */ showFavoritesEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showFavoritesEmptyState), -/* harmony export */ showHeaderCancelButton: () => (/* reexport safe */ _showHeaderCancelButton__WEBPACK_IMPORTED_MODULE_3__.showHeaderCancelButton), -/* harmony export */ showLeaveEmailModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showLeaveEmailModal), -/* harmony export */ showLockedTemplateModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showLockedTemplateModal), -/* harmony export */ showRenewAccountModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showRenewAccountModal), -/* harmony export */ showSearchEmptyState: () => (/* reexport safe */ _showEmptyState__WEBPACK_IMPORTED_MODULE_6__.showSearchEmptyState), -/* harmony export */ showSearchState: () => (/* reexport safe */ _searchState__WEBPACK_IMPORTED_MODULE_5__.showSearchState), -/* harmony export */ showSelectedCategory: () => (/* reexport safe */ _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__.showSelectedCategory), -/* harmony export */ showUpgradeModal: () => (/* reexport safe */ _showModal__WEBPACK_IMPORTED_MODULE_7__.showUpgradeModal), -/* harmony export */ updatePageTitle: () => (/* reexport safe */ _pageTitle__WEBPACK_IMPORTED_MODULE_2__.updatePageTitle) -/* harmony export */ }); -/* harmony import */ var _setupInitialView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupInitialView */ "./js/src/form-templates/ui/setupInitialView.js"); -/* harmony import */ var _initializeModal__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./initializeModal */ "./js/src/form-templates/ui/initializeModal.js"); -/* harmony import */ var _pageTitle__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./pageTitle */ "./js/src/form-templates/ui/pageTitle.js"); -/* harmony import */ var _showHeaderCancelButton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./showHeaderCancelButton */ "./js/src/form-templates/ui/showHeaderCancelButton.js"); -/* harmony import */ var _showSelectedCategory__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./showSelectedCategory */ "./js/src/form-templates/ui/showSelectedCategory.js"); -/* harmony import */ var _searchState__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./searchState */ "./js/src/form-templates/ui/searchState.js"); -/* harmony import */ var _showEmptyState__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./showEmptyState */ "./js/src/form-templates/ui/showEmptyState.js"); -/* harmony import */ var _showModal__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./showModal */ "./js/src/form-templates/ui/showModal.js"); -/* harmony import */ var _showError__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./showError */ "./js/src/form-templates/ui/showError.js"); - - - - - - - - - - -/***/ }), - -/***/ "./js/src/form-templates/ui/initializeModal.js": -/*!*****************************************************!*\ - !*** ./js/src/form-templates/ui/initializeModal.js ***! - \*****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getModalWidget: () => (/* binding */ getModalWidget), -/* harmony export */ initializeModal: () => (/* binding */ initializeModal) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - -var modalWidget = null; - -/** - * Initialize the modal widget. - * - * @return {void} - */ -function initializeModal() { - return _initializeModal.apply(this, arguments); -} - -/** - * Retrieve the modal widget. - * - * @return {Object|false} The modal widget or false. - */ -function _initializeModal() { - _initializeModal = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { - var _window$frmAdminBuild, initModal, offsetModalY, _getElements, leaveEmailModal; - return _regenerator().w(function (_context) { - while (1) switch (_context.n) { - case 0: - _window$frmAdminBuild = window.frmAdminBuild, initModal = _window$frmAdminBuild.initModal, offsetModalY = _window$frmAdminBuild.offsetModalY; - modalWidget = initModal('#frm-form-templates-modal', _shared__WEBPACK_IMPORTED_MODULE_2__.MODAL_SIZES.GENERAL); - - // Set the vertical offset for the modal - if (modalWidget) { - offsetModalY(modalWidget, '103px'); - } - - // Show the email modal if the 'free-templates' query param is present - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hasQueryParam)('free-templates')) { - _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), leaveEmailModal = _getElements.leaveEmailModal; - if (leaveEmailModal) { - (0,___WEBPACK_IMPORTED_MODULE_3__.showLeaveEmailModal)(); - } - } - - // Customize the confirm modal appearance: adjusting its width and vertical position - wp.hooks.addAction('frmAdmin.beforeOpenConfirmModal', 'frmFormTemplates', function (options) { - var confirmModal = options.$info; - confirmModal.dialog('option', 'width', _shared__WEBPACK_IMPORTED_MODULE_2__.MODAL_SIZES.CREATE_TEMPLATE); - offsetModalY(confirmModal, '103px'); - }); - case 1: - return _context.a(2); - } - }, _callee); - })); - return _initializeModal.apply(this, arguments); -} -function getModalWidget() { - return modalWidget; -} - -/***/ }), - -/***/ "./js/src/form-templates/ui/pageTitle.js": -/*!***********************************************!*\ - !*** ./js/src/form-templates/ui/pageTitle.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ updatePageTitle: () => (/* binding */ updatePageTitle) -/* harmony export */ }); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - -/** - * Sets the page title based on a given string or the currently selected category. - * - * @param {string} [title] Optional title to display. - * @return {void} - */ -function updatePageTitle(title) { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - pageTitleText = _getElements.pageTitleText; - var newTitle = title || (0,_shared__WEBPACK_IMPORTED_MODULE_2__.getSingleState)('selectedCategoryEl').querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_0__.PREFIX, "-cat-text")).textContent; - pageTitleText.textContent = newTitle; -} - -/***/ }), - -/***/ "./js/src/form-templates/ui/searchState.js": -/*!*************************************************!*\ - !*** ./js/src/form-templates/ui/searchState.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ displaySearchElements: () => (/* binding */ displaySearchElements), -/* harmony export */ showSearchState: () => (/* binding */ showSearchState) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! . */ "./js/src/form-templates/ui/index.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - -/** - * Updates the UI to display the search state. - * - * @param {boolean} notEmptySearchText True if search input is not empty. - * @return {void} - */ -function showSearchState(notEmptySearchText) { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - bodyContent = _getElements.bodyContent, - bodyContentChildren = _getElements.bodyContentChildren, - pageTitle = _getElements.pageTitle, - templatesList = _getElements.templatesList, - applicationTemplates = _getElements.applicationTemplates; - var bodyContentAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_2__.frmAnimate(bodyContent); - - // Remove highlighting from the currently selected category if the search text is not empty - if (notEmptySearchText) { - (0,_shared__WEBPACK_IMPORTED_MODULE_4__.getSingleState)('selectedCategoryEl').classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_1__.CURRENT_CLASS); - } - - // Hide non-relevant elements in the body content - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hideElements)(bodyContentChildren); - - // Update the page title and display relevant elements - (0,___WEBPACK_IMPORTED_MODULE_5__.updatePageTitle)((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Search Result', 'formidable')); - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.showElements)([pageTitle, templatesList, applicationTemplates]); - - // Smoothly display the updated UI elements - bodyContentAnimate.fadeIn(); -} - -/** - * Displays search results based on search outcome. - * - * @param {boolean} foundSomething True if search yielded results. - * @return {void} - */ -function displaySearchElements(foundSomething) { - // Show empty state if no templates found - if (!foundSomething) { - (0,___WEBPACK_IMPORTED_MODULE_5__.showSearchEmptyState)(); - return; - } - - // Hide empty state if currently displayed - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - emptyState = _getElements2.emptyState; - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_2__.isVisible)(emptyState)) { - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - pageTitle = _getElements3.pageTitle; - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hide)(emptyState); - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.show)(pageTitle); - } - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - templatesList = _getElements4.templatesList, - applicationTemplates = _getElements4.applicationTemplates, - applicationTemplatesTitle = _getElements4.applicationTemplatesTitle, - applicationTemplatesList = _getElements4.applicationTemplatesList; - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.showElements)([templatesList, applicationTemplates, applicationTemplatesTitle]); - if (templatesList.offsetHeight === 0) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hideElements)([templatesList, applicationTemplatesTitle]); - } - if ((applicationTemplatesList === null || applicationTemplatesList === void 0 ? void 0 : applicationTemplatesList.offsetHeight) === 0) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_2__.hide)(applicationTemplates); - } -} - -/***/ }), - -/***/ "./js/src/form-templates/ui/setupInitialView.js": -/*!******************************************************!*\ - !*** ./js/src/form-templates/ui/setupInitialView.js ***! - \******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_ui__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! core/ui */ "./js/src/core/ui/index.js"); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); -/** - * External dependencies - */ - - - - - -/** - * Internal dependencies - */ - - - - -/** - * Sets up the initial view, performing any required - * DOM manipulations for proper element presentation. - * - * @return {void} - */ -function setupInitialView() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_4__.getElements)(), - sidebar = _getElements.sidebar, - searchInput = _getElements.searchInput, - bodyContent = _getElements.bodyContent, - twinFeaturedTemplateItems = _getElements.twinFeaturedTemplateItems, - availableTemplatesCategory = _getElements.availableTemplatesCategory, - extraTemplateCountElements = _getElements.extraTemplateCountElements; - var bodyContentAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(bodyContent); - searchInput.value = ''; - - // Hide the twin featured template items - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)(twinFeaturedTemplateItems); - setupAvailableTemplatesCategory(availableTemplatesCategory); - - // Update extra templates count - extraTemplateCountElements.forEach(function (element) { - return element.textContent = (0,_shared__WEBPACK_IMPORTED_MODULE_5__.getSingleState)('extraTemplatesCount'); - }); - - // Smoothly display the updated UI elements - bodyContent.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); - sidebar.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDE_JS_CLASS); - bodyContentAnimate.fadeIn(); - - // Show the "Cancel" button in the header if the 'return_page' query param is present - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hasQueryParam)('return_page')) { - (0,___WEBPACK_IMPORTED_MODULE_6__.showHeaderCancelButton)(); - } -} - -/** - * Sets up the 'Available Templates' category with proper count display - * - * @param {Element} availableTemplatesCategory The Available Templates category element - * @return {void} - */ -function setupAvailableTemplatesCategory(availableTemplatesCategory) { - if (!availableTemplatesCategory) { - return; - } - var availableTemplatesCount = (0,_shared__WEBPACK_IMPORTED_MODULE_5__.getSingleState)('availableTemplatesCount'); - if (!(0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hasQueryParam)('registered-for-free-templates')) { - availableTemplatesCategory.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_3__.PREFIX, "-cat-count")).textContent = availableTemplatesCount; - return; - } - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.removeParamFromHistory)('registered-for-free-templates'); - runAvailableTemplatesEffects(availableTemplatesCategory, availableTemplatesCount); -} - -/** - * Runs effects for the Available Templates category when the - * 'registered-for-free-templates' query parameter is present. - * - * @param {Element} element The Available Templates category element - * @param {number} count The count of available templates - * @return {void} - */ -function runAvailableTemplatesEffects(element, count) { - setTimeout(function () { - element.dispatchEvent(new Event('click', { - bubbles: true - })); - }, 0); - setTimeout(function () { - (0,core_ui__WEBPACK_IMPORTED_MODULE_2__.counter)(element.querySelector(".".concat(core_page_skeleton__WEBPACK_IMPORTED_MODULE_3__.PREFIX, "-cat-count")), count); - }, 150); - setTimeout(function () { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_4__.getElements)(), - availableTemplateItems = _getElements2.availableTemplateItems; - availableTemplateItems.forEach(function (item) { - if (_shared__WEBPACK_IMPORTED_MODULE_5__.FREE_TEMPLATES_IDS.includes(Number(item.dataset.id))) { - return; - } - item.classList.add('frm-background-highlight'); - - // Remove class after animation completes to prevent restart - item.addEventListener('animationend', function handleAnimationEnd(event) { - if (event.animationName === 'backgroundHighlight') { - this.classList.remove('frm-background-highlight'); - this.removeEventListener('animationend', handleAnimationEnd); - } - }); - }); - }, 750); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (setupInitialView); - -/***/ }), - -/***/ "./js/src/form-templates/ui/showEmptyState.js": -/*!****************************************************!*\ - !*** ./js/src/form-templates/ui/showEmptyState.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showAvailableTemplatesEmptyState: () => (/* binding */ showAvailableTemplatesEmptyState), -/* harmony export */ showCustomTemplatesEmptyState: () => (/* binding */ showCustomTemplatesEmptyState), -/* harmony export */ showFavoritesEmptyState: () => (/* binding */ showFavoritesEmptyState), -/* harmony export */ showSearchEmptyState: () => (/* binding */ showSearchEmptyState) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - -/** - * Display the search-empty state. - * - * @return {void} - */ -function showSearchEmptyState() { - var _emptyState$dataset; - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - notEmptySearchText = _getState.notEmptySearchText; - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - pageTitle = _getElements.pageTitle, - emptyState = _getElements.emptyState, - emptyStateButton = _getElements.emptyStateButton, - applicationTemplates = _getElements.applicationTemplates; - - // Toggle visibility and remove attributes based on search status - if (_shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.SEARCH === ((_emptyState$dataset = emptyState.dataset) === null || _emptyState$dataset === void 0 ? void 0 : _emptyState$dataset.view)) { - if (notEmptySearchText) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(emptyState); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, applicationTemplates]); - } else { - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(emptyState); - emptyState.removeAttribute('data-view'); - } - return; - } - - // Assign state attributes - emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.SEARCH); - - // Update text content - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - emptyStateTitle = _getElements2.emptyStateTitle, - emptyStateText = _getElements2.emptyStateText; - emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No templates found', 'formidable'); - emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Sorry, we didn\'t find any templates that match your criteria.', 'formidable'); - emptyStateButton.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Start from Scratch', 'formidable'); - - // Display the empty state - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, applicationTemplates]); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.showElements)([emptyState, emptyStateButton]); -} - -/** - * Display the favorites-empty state. - * - * @return {void} - */ -function showFavoritesEmptyState() { - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - pageTitle = _getElements3.pageTitle, - emptyState = _getElements3.emptyState, - emptyStateButton = _getElements3.emptyStateButton; - - // Assign state attributes - emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.FAVORITES); - - // Update text content - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - emptyStateTitle = _getElements4.emptyStateTitle, - emptyStateText = _getElements4.emptyStateText; - emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No favorites', 'formidable'); - emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You haven\'t added any templates to your favorites yet.', 'formidable'); - - // Display the empty state - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, emptyStateButton]); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(emptyState); -} - -/** - * Display the custom-empty state. - * - * @return {void} - */ -function showCustomTemplatesEmptyState() { - var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - pageTitle = _getElements5.pageTitle, - emptyState = _getElements5.emptyState, - emptyStateButton = _getElements5.emptyStateButton; - - // Assign state attributes - emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.CUSTOM); - - // Update text content - var _getElements6 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - emptyStateTitle = _getElements6.emptyStateTitle, - emptyStateText = _getElements6.emptyStateText; - emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You currently have no templates.', 'formidable'); - emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You haven\'t created any form templates. Begin now to simplify your workflow and save time.', 'formidable'); - emptyStateButton.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Create Template', 'formidable'); - - // Display the empty state - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(pageTitle); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.showElements)([emptyState, emptyStateButton]); -} - -/** - * Display the available-templates-empty state. - * - * @return {void} - */ -function showAvailableTemplatesEmptyState() { - var _getElements7 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - pageTitle = _getElements7.pageTitle, - emptyState = _getElements7.emptyState, - emptyStateButton = _getElements7.emptyStateButton; - - // Assign state attributes - emptyState.setAttribute('data-view', _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.AVAILABLE_TEMPLATES); - - // Update text content - var _getElements8 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - emptyStateTitle = _getElements8.emptyStateTitle, - emptyStateText = _getElements8.emptyStateText; - var _getState2 = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - extraTemplatesCount = _getState2.extraTemplatesCount; - emptyStateTitle.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('No Templates Available', 'formidable'); - emptyStateText.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.sprintf)( - // translators: %s is the number of extra templates available - (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Upgrade to PRO for %s+ options or explore Free Templates.', 'formidable'), extraTemplatesCount); - - // Display the empty state - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)([pageTitle, emptyStateButton]); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(emptyState); -} - -/***/ }), - -/***/ "./js/src/form-templates/ui/showError.js": -/*!***********************************************!*\ - !*** ./js/src/form-templates/ui/showError.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showEmailAddressError: () => (/* binding */ showEmailAddressError) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/** - * External dependencies - */ - - -/** - * Displays errors related to the email address field. - * - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @return {void} - */ -var showEmailAddressError = function showEmailAddressError(type) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showFormError)('#frm_leave_email', '#frm_leave_email_error', type); -}; - -/***/ }), - -/***/ "./js/src/form-templates/ui/showHeaderCancelButton.js": -/*!************************************************************!*\ - !*** ./js/src/form-templates/ui/showHeaderCancelButton.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showHeaderCancelButton: () => (/* binding */ showHeaderCancelButton) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -/** - * Display the "Cancel" button in the header. - * - * @return {void} - */ -function showHeaderCancelButton() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - headerCancelButton = _getElements.headerCancelButton; - new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(headerCancelButton).fadeIn(); -} - -/***/ }), - -/***/ "./js/src/form-templates/ui/showModal.js": -/*!***********************************************!*\ - !*** ./js/src/form-templates/ui/showModal.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showCreateTemplateModal: () => (/* binding */ showCreateTemplateModal), -/* harmony export */ showLeaveEmailModal: () => (/* binding */ showLeaveEmailModal), -/* harmony export */ showLockedTemplateModal: () => (/* binding */ showLockedTemplateModal), -/* harmony export */ showRenewAccountModal: () => (/* binding */ showRenewAccountModal), -/* harmony export */ showUpgradeModal: () => (/* binding */ showUpgradeModal) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * WordPress dependencies - */ - - -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - -/** - * Display the locked template modal. - * - * @param {HTMLElement} template The template element. - * @return {void} - */ -function showLockedTemplateModal(template) { - var plan = template.dataset.requiredPlan; - switch (plan) { - case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.BASIC: - case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.PLUS: - case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.BUSINESS: - case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.ELITE: - showUpgradeModal(plan, template); - break; - case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.RENEW: - showRenewAccountModal(); - break; - case _shared__WEBPACK_IMPORTED_MODULE_3__.PLANS.FREE: - showLeaveEmailModal(); - break; - } -} - -/** - * Base function to show a modal dialog with a customizable pre-open execution step. - * - * @param {Function} executePreOpen The function to be executed before opening the modal dialog. - * @return {Function} A higher-order function that can be invoked to display the modal dialog. - */ -var showModal = function showModal(executePreOpen) { - return /*#__PURE__*/_asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { - var dialogWidget, - _getElements, - modalItems, - _len, - params, - _key, - _args = arguments; - return _regenerator().w(function (_context) { - while (1) switch (_context.n) { - case 0: - dialogWidget = (0,___WEBPACK_IMPORTED_MODULE_4__.getModalWidget)(); - if (dialogWidget) { - _context.n = 1; - break; - } - return _context.a(2); - case 1: - _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), modalItems = _getElements.modalItems; - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hideElements)(modalItems); - dialogWidget.dialog('option', 'width', _shared__WEBPACK_IMPORTED_MODULE_3__.MODAL_SIZES.GENERAL); - for (_len = _args.length, params = new Array(_len), _key = 0; _key < _len; _key++) { - params[_key] = _args[_key]; - } - _context.n = 2; - return executePreOpen === null || executePreOpen === void 0 ? void 0 : executePreOpen.apply(void 0, params); - case 2: - dialogWidget.dialog('open'); - case 3: - return _context.a(2); - } - }, _callee); - })); -}; - -// Mapping each plan to the subsequent plans it can upgrade to -var upgradablePlans = { - basic: ['basic', 'plus', 'business', 'elite'], - plus: ['plus', 'business', 'elite'], - business: ['business', 'elite'], - elite: ['elite'] -}; - -/** - * Display the modal dialog to prompt the user to upgrade their account. - * - * @param {string} plan Current plan name - * @param {HTMLElement} template The template element - * @return {void} - */ -var showUpgradeModal = showModal(function (plan, template) { - var templateName = template.querySelector('.frm-form-template-name').textContent.trim(); - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - upgradeModal = _getElements2.upgradeModal, - upgradeModalTemplateNames = _getElements2.upgradeModalTemplateNames, - upgradeModalPlansIcons = _getElements2.upgradeModalPlansIcons, - upgradeModalLink = _getElements2.upgradeModalLink; - - // Update template names - upgradeModalTemplateNames.forEach(function (element) { - return element.textContent = templateName; - }); - - // Update plan icons and their availability - upgradeModalPlansIcons.forEach(function (icon) { - var planType = icon.dataset.plan; - var shouldDisplayCheck = upgradablePlans[plan].includes(planType); - - // Toggle icon class based on plan availability - icon.classList.toggle('frm_green', shouldDisplayCheck); - - // Update SVG icon - var svg = icon.querySelector('svg > use'); - svg.setAttribute('href', shouldDisplayCheck ? '#frm_checkmark_icon' : '#frm_close_icon'); - }); - - // Append template slug to the upgrade modal link URL - var templateSlug = template.dataset.slug ? "-".concat(template.dataset.slug) : ''; - upgradeModalLink.href = _shared__WEBPACK_IMPORTED_MODULE_3__.upgradeLink + templateSlug; - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(upgradeModal); -}); - -/** - * Display the modal dialog to prompt the user to renew their account. - * - * @return {void} - */ -var showRenewAccountModal = showModal(function () { - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - renewAccountModal = _getElements3.renewAccountModal; - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(renewAccountModal); -}); - -/** - * Display the modal dialog to prompt the user to leave an email. - * - * @return {void} - */ -var showLeaveEmailModal = showModal(function () { - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - leaveEmailModal = _getElements4.leaveEmailModal; - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(leaveEmailModal); -}); - -/** - * Displays a modal dialog prompting the user to create a new template. - * - * @return {void} - */ -var showCreateTemplateModal = showModal(function () { - var dialogWidget = (0,___WEBPACK_IMPORTED_MODULE_4__.getModalWidget)(); - dialogWidget.dialog('option', 'width', _shared__WEBPACK_IMPORTED_MODULE_3__.MODAL_SIZES.CREATE_TEMPLATE); - var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - createTemplateModal = _getElements5.createTemplateModal; - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(createTemplateModal); -}); - -/***/ }), - -/***/ "./js/src/form-templates/ui/showSelectedCategory.js": -/*!**********************************************************!*\ - !*** ./js/src/form-templates/ui/showSelectedCategory.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ showAllTemplates: () => (/* binding */ showAllTemplates), -/* harmony export */ showAvailableTemplates: () => (/* binding */ showAvailableTemplates), -/* harmony export */ showCustomTemplates: () => (/* binding */ showCustomTemplates), -/* harmony export */ showFavoriteTemplates: () => (/* binding */ showFavoriteTemplates), -/* harmony export */ showSelectedCategory: () => (/* binding */ showSelectedCategory) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/form-templates/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils */ "./js/src/form-templates/utils/index.js"); -/* harmony import */ var _templates__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../templates */ "./js/src/form-templates/templates/index.js"); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ */ "./js/src/form-templates/ui/index.js"); -function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } -function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - - - -/** - * Show templates based on selected category. - * - * @param {string} selectedCategory The selected category to display templates for. - * @return {void} - */ -function showSelectedCategory(selectedCategory) { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - bodyContentChildren = _getElements.bodyContentChildren, - pageTitle = _getElements.pageTitle, - showCreateTemplateModalButton = _getElements.showCreateTemplateModalButton, - templatesList = _getElements.templatesList, - templateItems = _getElements.templateItems, - upsellBanner = _getElements.upsellBanner; - if (core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS !== selectedCategory) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(bodyContentChildren); - } - (0,___WEBPACK_IMPORTED_MODULE_6__.updatePageTitle)(); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(showCreateTemplateModalButton); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.show)(pageTitle); - switch (selectedCategory) { - case core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS: - showAllTemplates(); - break; - case _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.AVAILABLE_TEMPLATES: - showAvailableTemplates(); - break; - case _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.FAVORITES: - showFavoriteTemplates(); - break; - case _shared__WEBPACK_IMPORTED_MODULE_3__.VIEW_SLUGS.CUSTOM: - showCustomTemplates(); - break; - default: - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(templateItems); // Clear the view for new content - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([upsellBanner, templatesList].concat(_toConsumableArray(_templates__WEBPACK_IMPORTED_MODULE_5__.categorizedTemplates[selectedCategory]))); - break; - } -} - -/** - * Shows all templates when 'All Templates' is the selected category. - * - * @return {void} - */ -function showAllTemplates() { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - bodyContentChildren = _getElements2.bodyContentChildren, - pageTitleDivider = _getElements2.pageTitleDivider, - templateItems = _getElements2.templateItems, - twinFeaturedTemplateItems = _getElements2.twinFeaturedTemplateItems, - customTemplatesSection = _getElements2.customTemplatesSection, - emptyState = _getElements2.emptyState, - applicationTemplates = _getElements2.applicationTemplates; - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([].concat(_toConsumableArray(bodyContentChildren), _toConsumableArray(templateItems))); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)([pageTitleDivider].concat(_toConsumableArray(twinFeaturedTemplateItems), [customTemplatesSection, emptyState, applicationTemplates])); -} - -/** - * Shows favorite templates. - * - * @return {void} - */ -function showFavoriteTemplates() { - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - favoritesCount = _getState.favoritesCount; - if (0 === favoritesCount.total) { - (0,___WEBPACK_IMPORTED_MODULE_6__.showFavoritesEmptyState)(); - return; - } - var _getElements3 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - bodyContent = _getElements3.bodyContent, - templatesList = _getElements3.templatesList, - templateItems = _getElements3.templateItems, - customTemplatesSection = _getElements3.customTemplatesSection, - customTemplatesTitle = _getElements3.customTemplatesTitle, - customTemplatesList = _getElements3.customTemplatesList, - customTemplateItems = _getElements3.customTemplateItems; - - // Clear the view for new content - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(templateItems); - var elementsToShow = []; - - // Get all favorite items from the DOM and add the elements to show - var favoriteItems = bodyContent.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_3__.PREFIX, "-favorite-item")); - elementsToShow.push.apply(elementsToShow, _toConsumableArray(favoriteItems)); - - // Add default favorites if available - if (favoritesCount.default > 0) { - elementsToShow.push(templatesList); - } - - // Add custom favorites if available - if (favoritesCount.custom > 0) { - var nonFavCustomTemplates = Array.from(customTemplateItems).filter(function (template) { - return !(0,_utils__WEBPACK_IMPORTED_MODULE_4__.isFavoriteTemplate)(template); - }); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(nonFavCustomTemplates); - elementsToShow.push(customTemplatesSection); - elementsToShow.push(customTemplatesList); - if (0 === favoritesCount.default) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(customTemplatesTitle); - } else { - elementsToShow.push(customTemplatesTitle); - } - } - - // Show elements that were selected to be shown - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)(elementsToShow); -} - -/** - * Shows custom templates. - * - * @return {void} - */ -function showCustomTemplates() { - var _getState2 = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - customCount = _getState2.customCount; - if (0 === customCount) { - (0,___WEBPACK_IMPORTED_MODULE_6__.showCustomTemplatesEmptyState)(); - return; - } - var _getElements4 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - showCreateTemplateModalButton = _getElements4.showCreateTemplateModalButton, - pageTitleDivider = _getElements4.pageTitleDivider, - customTemplatesSection = _getElements4.customTemplatesSection, - customTemplatesList = _getElements4.customTemplatesList, - customTemplatesTitle = _getElements4.customTemplatesTitle, - customTemplateItems = _getElements4.customTemplateItems; - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hide)(customTemplatesTitle); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([showCreateTemplateModalButton, pageTitleDivider, customTemplatesSection, customTemplatesList].concat(_toConsumableArray(customTemplateItems))); -} - -/** - * Shows available templates. - * - * @return {void} - */ -function showAvailableTemplates() { - var _getState3 = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), - availableTemplatesCount = _getState3.availableTemplatesCount; - if (0 === availableTemplatesCount) { - (0,___WEBPACK_IMPORTED_MODULE_6__.showAvailableTemplatesEmptyState)(); - return; - } - var _getElements5 = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - templatesList = _getElements5.templatesList, - templateItems = _getElements5.templateItems, - availableTemplateItems = _getElements5.availableTemplateItems, - upsellBanner = _getElements5.upsellBanner; - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.hideElements)(templateItems); // Clear the view for new content - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.showElements)([upsellBanner, templatesList].concat(_toConsumableArray(availableTemplateItems))); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (showSelectedCategory); - -/***/ }), - -/***/ "./js/src/form-templates/utils/index.js": -/*!**********************************************!*\ - !*** ./js/src/form-templates/utils/index.js ***! - \**********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isAllTemplatesCategory: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isAllTemplatesCategory), -/* harmony export */ isCustomCategory: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isCustomCategory), -/* harmony export */ isCustomTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isCustomTemplate), -/* harmony export */ isFavoriteTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isFavoriteTemplate), -/* harmony export */ isFavoritesCategory: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isFavoritesCategory), -/* harmony export */ isFeaturedTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isFeaturedTemplate), -/* harmony export */ isLockedTemplate: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_0__.isLockedTemplate) -/* harmony export */ }); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validation */ "./js/src/form-templates/utils/validation.js"); - - -/***/ }), - -/***/ "./js/src/form-templates/utils/validation.js": -/*!***************************************************!*\ - !*** ./js/src/form-templates/utils/validation.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isAllTemplatesCategory: () => (/* binding */ isAllTemplatesCategory), -/* harmony export */ isCustomCategory: () => (/* binding */ isCustomCategory), -/* harmony export */ isCustomTemplate: () => (/* binding */ isCustomTemplate), -/* harmony export */ isFavoriteTemplate: () => (/* binding */ isFavoriteTemplate), -/* harmony export */ isFavoritesCategory: () => (/* binding */ isFavoritesCategory), -/* harmony export */ isFeaturedTemplate: () => (/* binding */ isFeaturedTemplate), -/* harmony export */ isLockedTemplate: () => (/* binding */ isLockedTemplate) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/page-skeleton */ "./js/src/core/page-skeleton/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/form-templates/shared/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - -/** - * Checks if the category is "All Templates". - * - * @param {string} category The category slug. - * @return {boolean} True if the category is "All Templates", otherwise false. - */ -var isAllTemplatesCategory = function isAllTemplatesCategory(category) { - return core_page_skeleton__WEBPACK_IMPORTED_MODULE_1__.VIEWS.ALL_ITEMS === category; -}; - -/** - * Checks if the category is "Favorites". - * - * @param {string} category The category slug. - * @return {boolean} True if the category is "Favorites", otherwise false. - */ -var isFavoritesCategory = function isFavoritesCategory(category) { - return _shared__WEBPACK_IMPORTED_MODULE_2__.VIEW_SLUGS.FAVORITES === category; -}; - -/** - * Checks if the category is "Custom". - * - * @param {string} category The category slug. - * @return {boolean} True if the category is "Custom", otherwise false. - */ -var isCustomCategory = function isCustomCategory(category) { - return _shared__WEBPACK_IMPORTED_MODULE_2__.VIEW_SLUGS.CUSTOM === category; -}; - -/** - * Checks if a template is a favorite. - * - * @param {HTMLElement} template The template element. - * @return {boolean} True if the template is a favorite, otherwise false. - */ -var isFavoriteTemplate = function isFavoriteTemplate(template) { - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? template.classList.contains("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-favorite-item")) : false; -}; - -/** - * Checks if a template is custom. - * - * @param {HTMLElement} template The template element. - * @return {boolean} True if the template is custom, otherwise false. - */ -var isCustomTemplate = function isCustomTemplate(template) { - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? template.classList.contains("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-custom-item")) : false; -}; - -/** - * Checks if a template is featured. - * - * @param {HTMLElement} template The template element. - * @return {boolean} True if the template is featured, otherwise false. - */ -var isFeaturedTemplate = function isFeaturedTemplate(template) { - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? _shared__WEBPACK_IMPORTED_MODULE_2__.FEATURED_TEMPLATES_IDS.includes(Number(template.dataset.id)) : false; -}; - -/** - * Checks if a template is locked. - * - * @param {HTMLElement} template The template element. - * @return {boolean} True if the template is locked, otherwise false. - */ -var isLockedTemplate = function isLockedTemplate(template) { - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.isHTMLElement)(template) ? template.classList.contains("".concat(_shared__WEBPACK_IMPORTED_MODULE_2__.PREFIX, "-locked-item")) : false; -}; - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. -(() => { -"use strict"; -/*!****************************************!*\ - !*** ./js/src/form-templates/index.js ***! - \****************************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./shared */ "./js/src/form-templates/shared/index.js"); -/* harmony import */ var _initializeFormTemplates__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./initializeFormTemplates */ "./js/src/form-templates/initializeFormTemplates.js"); -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - - -(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__["default"])(function () { - /** - * Entry point for pre-initialization adjustments to the page state. - * - * @param {Object} state Current state of the page. - */ - wp.hooks.doAction('frmFormTemplates.beforeInitialize', { - getState: _shared__WEBPACK_IMPORTED_MODULE_0__.getState, - setState: _shared__WEBPACK_IMPORTED_MODULE_0__.setState - }); - - // Initialize the form templates - (0,_initializeFormTemplates__WEBPACK_IMPORTED_MODULE_1__["default"])(); - - /** - * Entry point for post-initialization custom logic or adjustments to the page state. - * - * @param {Object} state Current state of the page. - */ - wp.hooks.doAction('frmFormTemplates.afterInitialize', { - getState: _shared__WEBPACK_IMPORTED_MODULE_0__.getState, - setState: _shared__WEBPACK_IMPORTED_MODULE_0__.setState - }); - - /** - * Trigger a specific action to interact with the hidden form '#frm-new-template', - * which is used for creating or using a form template. - * - * @param {HTMLElement} $form The jQuery object containing the hidden form element. - */ - wp.hooks.doAction('frm_new_form_modal_form', jQuery('#frm-new-template')); -}); -})(); - -/******/ })() -; -//# sourceMappingURL=form-templates.js.map \ No newline at end of file +/*! For license information please see form-templates.js.LICENSE.txt */ +(()=>{var t={8616:t=>{t.exports=function(t,e){var n,r,o=0;function a(){var a,i,c=n,l=arguments.length;t:for(;c;){if(c.args.length===arguments.length){for(i=0;i{var r;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function a(t){return function(t,e){var n,r,i,c,l,u,s,m,f,p=1,d=t.length,y="";for(r=0;r=0),c.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,c.width?parseInt(c.width):0);break;case"e":n=c.precision?parseFloat(n).toExponential(c.precision):parseFloat(n).toExponential();break;case"f":n=c.precision?parseFloat(n).toFixed(c.precision):parseFloat(n);break;case"g":n=c.precision?String(Number(n.toPrecision(c.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=c.precision?n.substring(0,c.precision):n;break;case"t":n=String(!!n),n=c.precision?n.substring(0,c.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=c.precision?n.substring(0,c.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=c.precision?n.substring(0,c.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}o.json.test(c.type)?y+=n:(!o.number.test(c.type)||m&&!c.sign?f="":(f=m?"+":"-",n=n.toString().replace(o.sign,"")),u=c.pad_char?"0"===c.pad_char?"0":c.pad_char.charAt(1):" ",s=c.width-(f+n).length,l=c.width&&s>0?u.repeat(s):"",y+=c.align?f+n+l:"0"===u?f+l+n:l+f+n)}return y}(function(t){if(c[t])return c[t];for(var e,n=t,r=[],a=0;n;){if(null!==(e=o.text.exec(n)))r.push(e[0]);else if(null!==(e=o.modulo.exec(n)))r.push("%");else{if(null===(e=o.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){a|=1;var i=[],l=e[2],u=[];if(null===(u=o.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(i.push(u[1]);""!==(l=l.substring(u[0].length));)if(null!==(u=o.key_access.exec(l)))i.push(u[1]);else{if(null===(u=o.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");i.push(u[1])}e[2]=i}else a|=2;if(3===a)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}n=n.substring(e[0].length)}return c[t]=r}(t),arguments)}function i(t,e){return a.apply(null,[t].concat(e||[]))}var c=Object.create(null);e.sprintf=a,e.vsprintf=i,"undefined"!=typeof window&&(window.sprintf=a,window.vsprintf=i,void 0===(r=function(){return{sprintf:a,vsprintf:i}}.call(e,n,e,t))||(t.exports=r))}()}},e={};function n(r){var o=e[r];if(void 0!==o)return o.exports;var a=e[r]={exports:{}};return t[r](a,a.exports,n),a.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t=window.frmGlobal,e=t.canAccessApplicationDashboard,r=t.applicationsUrl,o=window.frmFormTemplatesVars,a=o.FEATURED_TEMPLATES_IDS,i=o.FREE_TEMPLATES_IDS,c=o.upgradeLink,l="frm-form-templates",u="available-templates",s="favorites",m="custom",f="search",p="440px",d="550px",y="frm-page-skeleton",v="all-items";function h(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function b(t){for(var e=1;e":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},T=["(","?"],_={")":["("],":":["?","?:"]},E=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var P={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,n){if(t)throw e;return n}};var F={contextDelimiter:"",onMissingKey:null};function L(t,e){var n;for(n in this.data=t,this.pluralForms={},this.options={},F)this.options[n]=void 0!==e&&n in e?e[n]:F[n]}function B(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function D(t){for(var e=1;e=0||S[o]3&&void 0!==arguments[3]?arguments[3]:10,i=t[e];if(G(n)&&N(r))if("function"==typeof o)if("number"==typeof a){var c={callback:o,priority:a,namespace:r};if(i[n]){var l,u=i[n].handlers;for(l=u.length;l>0&&!(a>=u[l-1].priority);l--);l===u.length?u[l]=c:u.splice(l,0,c),i.__current.forEach(function(t){t.name===n&&t.currentIndex>=l&&t.currentIndex++})}else i[n]={handlers:[c],runs:0};"hookAdded"!==n&&t.doAction("hookAdded",n,r,o,a)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},z=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,o){var a=t[e];if(G(r)&&(n||N(o))){if(!a[r])return 0;var i=0;if(n)i=a[r].handlers.length,a[r]={runs:a[r].runs,handlers:[]};else for(var c=a[r].handlers,l=function(t){c[t].namespace===o&&(c.splice(t,1),i++,a.__current.forEach(function(e){e.name===r&&e.currentIndex>=t&&e.currentIndex--}))},u=c.length-1;u>=0;u--)l(u);return"hookRemoved"!==r&&t.doAction("hookRemoved",r,o),i}}},V=function(t,e){return function(n,r){var o=t[e];return void 0!==r?n in o&&o[n].handlers.some(function(t){return t.namespace===r}):n in o}},$=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var o=t[e];o[r]||(o[r]={handlers:[],runs:0}),o[r].runs++;for(var a=o[r].handlers,i=arguments.length,c=new Array(i>1?i-1:0),l=1;l1&&void 0!==arguments[1]?arguments[1]:"default";r.data[e]=D(D(D({},M),r.data[e]),t),r.data[e][""]=D(D({},M[""]),r.data[e][""])},c=function(t,e){i(t,e),a()},l=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,a=arguments.length>4?arguments[4]:void 0;return r.data[t]||i(void 0,t),r.dcnpgettext(t,e,n,o,a)},u=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},s=function(t,e,r){var o=l(r,e,t);return n?(o=n.applyFilters("i18n.gettext_with_context",o,t,e,r),n.applyFilters("i18n.gettext_with_context_"+u(r),o,t,e,r)):o};if(n){var m=function(t){q.test(t)&&a()};n.addAction("hookAdded","core/i18n",m),n.addAction("hookRemoved","core/i18n",m)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[t]},setLocaleData:c,resetLocaleData:function(t,e){r.data={},r.pluralForms={},c(t,e)},subscribe:function(t){return o.add(t),function(){return o.delete(t)}},__:function(t,e){var r=l(e,void 0,t);return n?(r=n.applyFilters("i18n.gettext",r,t,e),n.applyFilters("i18n.gettext_"+u(e),r,t,e)):r},_x:s,_n:function(t,e,r,o){var a=l(o,void 0,t,e,r);return n?(a=n.applyFilters("i18n.ngettext",a,t,e,r,o),n.applyFilters("i18n.ngettext_"+u(o),a,t,e,r,o)):a},_nx:function(t,e,r,o,a){var i=l(a,o,t,e,r);return n?(i=n.applyFilters("i18n.ngettext_with_context",i,t,e,r,o,a),n.applyFilters("i18n.ngettext_with_context_"+u(a),i,t,e,r,o,a)):i},isRTL:function(){return"rtl"===s("ltr","text direction")},hasTranslation:function(t,e,o){var a,i,c=e?e+""+t:t,l=!(null===(a=r.data)||void 0===a||null===(i=a[null!=o?o:"default"])||void 0===i||!i[c]);return n&&(l=n.applyFilters("i18n.has_translation",l,t,e,o),l=n.applyFilters("i18n.has_translation_"+u(o),l,t,e,o)),l}}}(0,0,Y));K.getLocaleData.bind(K),K.setLocaleData.bind(K),K.resetLocaleData.bind(K),K.subscribe.bind(K);var X=K.__.bind(K),W=(K._x.bind(K),K._n.bind(K),K._nx.bind(K),K.isRTL.bind(K),K.hasTranslation.bind(K),window.frmGlobal),Q=W.url,tt=(W.nonce,"frm_hidden"),et="frm-hide-js",nt="frm-current",rt=window.frmDom,ot=rt.tag,at=rt.div,it=rt.a,ct=rt.img;function lt(t){return lt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},lt(t)}function ut(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function st(t,e,n){return(e=function(t){var e=function(t){if("object"!=lt(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=lt(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==lt(e)?e:e+""}(e))in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}var mt,ft=document.getElementById("post-body-content"),pt=document.getElementById("".concat(y,"-sidebar")),dt=((mt=it({className:"button button-primary frm-button-primary"})).setAttribute("role","button"),at({id:"".concat(y,"-empty-state"),className:"frm-flex-col frm-flex-center frm-gap-md ".concat(tt),children:[ct({src:"".concat(Q,"/images/page-skeleton/empty-state.svg"),alt:X("Empty State","formidable")}),at({className:"frmcenter",children:[ot("h2",{className:"".concat(y,"-title frm-mb-0")}),ot("p",{className:"".concat(y,"-text frm-mb-0")})]}),mt]}));null==ft||ft.append(dt);var yt=function(){var t=document.querySelector("#".concat(y,"-empty-state"));return{emptyState:t,emptyStateTitle:null==t?void 0:t.querySelector(".".concat(y,"-title")),emptyStateText:null==t?void 0:t.querySelector(".".concat(y,"-text")),emptyStateButton:null==t?void 0:t.querySelector(".button")}}(),vt=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==w(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var e=t;return{getElements:function(){return e},addElements:function(t){if("object"!==w(t)||null===t)throw new Error("addElements: newElements must be a non-null object");e=b(b({},e),t)}}}(function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==Tt(t)||null===t)throw new Error("createPageState: initialState must be a non-null object");var e=t;return{getState:function(){return e},getSingleState:function(t){var n=Reflect.get(e,t);return void 0===n?null:n},setState:function(t){if("object"!==Tt(t)||null===t)throw new Error("setState: newState must be a non-null object");e=wt(wt({},e),t)},setSingleState:function(t,n){Reflect.has(e,t)&&Reflect.set(e,t,n)}}}({notEmptySearchText:!1,selectedCategory:v,selectedCategoryEl:_t}),xt=Et.getState,Ot=Et.getSingleState,jt=Et.setState,It=Et.setSingleState;function Ct(t){return Ct="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},Ct(t)}function At(t,e){for(var n=0;n1&&void 0!==arguments[1]?arguments[1]:"default";!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.elements=e,this.type=n,this.prepareElements()},e=[{key:"fadeIn",value:function(){var t=this;this.applyStyleToElements(function(e){e.classList.add("frm-fadein-up"),e.addEventListener("animationend",function(){t.resetOpacity(),e.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){t.applyStyleToElements(function(t,n){t.classList.remove("frm-animate"),t.style.transitionDelay="".concat((n+1)*e,"s")})},200)}},{key:"prepareElements",value:function(){var t=this;this.applyStyleToElements(function(e){"default"===t.type&&(e.style.opacity="0.0"),"cascade"===t.type&&e.classList.add("frm-init-cascade-animation"),"cascade-3d"===t.type&&e.classList.add("frm-init-fadein-3d"),e.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(t){return t.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(t){this.elements instanceof Element?t(this.elements,0):02&&void 0!==arguments[2]?arguments[2]:"pushState";if(zt.set(t,e),Rt.search=zt.toString(),["pushState","replaceState"].includes(a)){var i=(n={},o=e,(r=function(t){var e=function(t){if("object"!=qt(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=qt(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==qt(e)?e:e+""}(r=t))in n?Object.defineProperty(n,r,{value:o,enumerable:!0,configurable:!0,writable:!0}):n[r]=o,n);window.history[a](i,"",Rt)}return Rt.toString()},Ut=function(t){return zt.has(t)},Ht=function(t){return"string"==typeof t&&/^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(t)},Zt=function(t){return t instanceof HTMLElement||console.warn("Invalid argument: Element must be an instance of HTMLElement")||!1},Jt=function(t){var e;return null===(e=Array.from(t))||void 0===e?void 0:e.forEach(function(t){return Kt(t)})},Yt=function(t){var e;return null===(e=Array.from(t))||void 0===e?void 0:e.forEach(function(t){return Xt(t)})},Kt=function(t){return null==t?void 0:t.classList.remove(tt)},Xt=function(t){return null==t?void 0:t.classList.add(tt)},Wt=function(t){var e=t.currentTarget,n=e.getAttribute("data-category"),r=xt(),o=r.selectedCategory,a=r.selectedCategoryEl,i=r.notEmptySearchText;if(o!==n){o=wp.hooks.applyFilters("frmPage.selectedCategory",n),a.classList.remove(nt),(a=e).classList.add(nt),jt({selectedCategory:o,selectedCategoryEl:a}),i&&te(),wp.hooks.doAction("frmPage.onCategoryClick",o);var c=ht().bodyContent;new Pt(c).fadeIn()}};function Qt(t){"Enter"!==t.key&&" "!==t.key||(t.preventDefault(),Wt(t))}function te(){var t=ht().searchInput;t.value="",t.dispatchEvent(new Event("input",{bubbles:!0}))}var ee=ht().bodyContent,ne=document.getElementById("".concat(l,"-list")),re=document.getElementById("".concat(l,"-custom-list-section")),oe=document.querySelector(".".concat(y,'-cat[data-category="').concat(s,'"]')),ae=document.getElementById("".concat(l,"-modal"));bt({headerCancelButton:null===(Nt=document.getElementById("frm-publishing"))||void 0===Nt?void 0:Nt.querySelector("a"),createFormButton:document.getElementById("".concat(l,"-create-form")),pageTitle:document.getElementById("".concat(l,"-page-title")),pageTitleText:document.getElementById("".concat(l,"-page-title-text")),pageTitleDivider:document.getElementById("".concat(l,"-page-title-divider")),upsellBanner:null!==(Gt=document.getElementById("frm-renew-subscription-banner"))&&void 0!==Gt?Gt:document.getElementById("frm-upgrade-banner"),extraTemplateCountElements:document.querySelectorAll(".".concat(l,"-extra-templates-count")),templatesList:ne,templateItems:ne.querySelectorAll(".frm-card-item"),availableTemplateItems:ne.querySelectorAll(".frm-card-item:not(.".concat(l,"-locked-item)")),twinFeaturedTemplateItems:ne.querySelectorAll(".".concat(l,"-featured-item")),featuredTemplatesList:document.getElementById("".concat(l,"-featured-list")),customTemplatesSection:re,customTemplateItems:re.querySelectorAll(".frm-card-item"),customTemplatesTitle:document.getElementById("".concat(l,"-custom-list-title")),customTemplatesList:document.getElementById("".concat(l,"-custom-list")),favoritesCategory:oe,favoritesCategoryCountEl:null==oe?void 0:oe.querySelector(".".concat(y,"-cat-count")),availableTemplatesCategory:document.querySelector(".".concat(y,'-cat[data-category="').concat(u,'"]')),getFreeTemplatesBannerButton:document.querySelector(".frm-get-free-templates-banner .button"),modal:ae,modalItems:null==ae?void 0:ae.querySelectorAll(".".concat(l,"-modal-item")),showCreateTemplateModalButton:document.getElementById("frm-show-create-template-modal"),createTemplateModal:document.getElementById("frm-create-template-modal"),createTemplateFormsDropdown:document.getElementById("frm-create-template-modal-forms-select"),createTemplateName:document.getElementById("frm_create_template_name"),createTemplateDescription:document.getElementById("frm_create_template_description"),createTemplateButton:document.getElementById("frm-create-template-button"),renewAccountModal:document.getElementById("frm-renew-modal"),leaveEmailModal:document.getElementById("frm-leave-email-modal"),leaveEmailModalInput:document.getElementById("frm_leave_email"),leaveEmailModalButton:document.getElementById("frm-get-code-button"),upgradeModal:document.getElementById("frm-form-upgrade-modal"),upgradeModalTemplateNames:null==ae?void 0:ae.querySelectorAll(".frm-upgrade-modal-template-name"),upgradeModalPlansIcons:null==ae?void 0:ae.querySelectorAll(".frm-upgrade-modal-plan-icon"),upgradeModalLink:document.getElementById("frm-upgrade-modal-link"),newTemplateForm:document.getElementById("frm-new-template"),newTemplateNameInput:document.getElementById("frm_template_name"),newTemplateDescriptionInput:document.getElementById("frm_template_desc"),newTemplateLinkInput:document.getElementById("frm_link"),newTemplateActionInput:document.getElementById("frm_action_type"),bodyContentChildren:null==ee?void 0:ee.children});var ie,ce=window.frmDom,le=ce.tag,ue=ce.div,se=ce.span,me=ce.a,fe=ce.img,pe="".concat(Q,"/images/applications/thumbnails");var de=window.frmFormTemplatesVars,ye=de.templatesCount,ve=de.favoritesCount,he=de.customCount,be=ht().availableTemplateItems.length;jt({availableTemplatesCount:be,customCount:Number(he),extraTemplatesCount:ye-be,favoritesCount:ve}),window.frmDom.span;var ge=function(t,e){return t.textContent=String(e),t},we=function(t,e,n,r,o,a,i){e._counterStartTime||(e._counterStartTime=t,e._counterLastTimestamp=t,e._counterFrameDropCount=0,e._counterLastValue=n);var c=t-e._counterLastTimestamp,l=t-e._counterStartTime;if(c>50&&null!==e._counterLastTimestamp&&(e._counterFrameDropCount++,e._counterFrameDropCount>3))return e.style.transition="opacity ".concat(Math.max(o-l,100),"ms ease-out"),e.textContent=String(r),void delete e._counterAnimation;var u=Math.min(l/o,1),s=i(u),m=Math.round(n+a*s);m!==e._counterLastValue&&(e.textContent=String(m),e._counterLastValue=m),e._counterLastTimestamp=t,u<1?e._counterAnimation=requestAnimationFrame(function(t){return we(t,e,n,r,o,a,i)}):(e.textContent=String(r),["_counterAnimation","_counterStartTime","_counterLastTimestamp","_counterFrameDropCount","_counterLastValue"].forEach(function(t){return delete e[t]}),e.style.removeProperty("transition"))},Se=function(t){return 1-Math.pow(1-t,4)};const Te=function(){var t,e=ht(),n=e.sidebar,r=e.searchInput,o=e.bodyContent,a=e.twinFeaturedTemplateItems,c=e.availableTemplatesCategory,l=e.extraTemplateCountElements,u=new Pt(o);r.value="",Yt(a),function(t){if(t){var e,n,r=Ot("availableTemplatesCount");if(Ut("registered-for-free-templates"))history.replaceState({},"",Vt("registered-for-free-templates")),e=t,n=r,setTimeout(function(){e.dispatchEvent(new Event("click",{bubbles:!0}))},0),setTimeout(function(){!function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r="string"==typeof t?document.querySelector(t):t;if(!(r&&r instanceof HTMLElement))return null;var o="number"==typeof e?e:parseInt(e,10);if(isNaN(o))return console.warn("Counter: Invalid value provided, defaulting to 0"),ge(r,"0");if(0===o)return ge(r,"0");var a=n.duration,i=void 0===a?3e3:a,c=n.easing,l=void 0===c?Se:c,u=parseInt(r.textContent,10)||0,s=o-u;0===s||(r._counterAnimation&&cancelAnimationFrame(r._counterAnimation),r.classList.add("frm-fadein"),r._counterAnimation=requestAnimationFrame(function(t){return we(t,r,u,o,i,s,l)}))}(e.querySelector(".".concat(y,"-cat-count")),n)},150),setTimeout(function(){ht().availableTemplateItems.forEach(function(t){i.includes(Number(t.dataset.id))||(t.classList.add("frm-background-highlight"),t.addEventListener("animationend",function t(e){"backgroundHighlight"===e.animationName&&(this.classList.remove("frm-background-highlight"),this.removeEventListener("animationend",t))}))})},750);else t.querySelector(".".concat(y,"-cat-count")).textContent=r}}(c),l.forEach(function(t){return t.textContent=Ot("extraTemplatesCount")}),o.classList.remove(et),n.classList.remove(et),u.fadeIn(),Ut("return_page")&&(t=ht().headerCancelButton,new Pt(t).fadeIn())};function _e(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function a(n,r,o,a){var l=r&&r.prototype instanceof c?r:c,u=Object.create(l.prototype);return Ee(u,"_invoke",function(n,r,o){var a,c,l,u=0,s=o||[],m=!1,f={p:0,n:0,v:t,a:p,f:p.bind(t,4),d:function(e,n){return a=e,c=0,l=t,f.n=n,i}};function p(n,r){for(c=n,l=r,e=0;!m&&u&&!o&&e3?(o=d===r)&&(l=a[(c=a[4])?5:(c=3,3)],a[4]=a[5]=t):a[0]<=p&&((o=n<2&&pr||r>d)&&(a[4]=n,a[5]=r,f.n=d,c=0))}if(o||n>1)return i;throw m=!0,r}return function(o,s,d){if(u>1)throw TypeError("Generator is already running");for(m&&1===s&&p(s,d),c=s,l=d;(e=c<2?t:l)||!m;){a||(c?c<3?(c>1&&(f.n=-1),p(c,l)):f.n=l:f.v=l);try{if(u=2,a){if(c||(o="next"),e=a[o]){if(!(e=e.call(a,l)))throw TypeError("iterator result is not an object");if(!e.done)return e;l=e.value,c<2&&(c=0)}else 1===c&&(e=a.return)&&e.call(a),c<2&&(l=TypeError("The iterator does not provide a '"+o+"' method"),c=1);a=t}else if((e=(m=f.n<0)?l:n.call(r,f))!==i)break}catch(e){a=t,c=1,l=e}finally{u=1}}return{value:e,done:m}}}(n,o,a),!0),u}var i={};function c(){}function l(){}function u(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(Ee(e={},r,function(){return this}),e),m=u.prototype=c.prototype=Object.create(s);function f(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,Ee(t,o,"GeneratorFunction")),t.prototype=Object.create(m),t}return l.prototype=u,Ee(m,"constructor",u),Ee(u,"constructor",l),l.displayName="GeneratorFunction",Ee(u,o,"GeneratorFunction"),Ee(m),Ee(m,o,"Generator"),Ee(m,r,function(){return this}),Ee(m,"toString",function(){return"[object Generator]"}),(_e=function(){return{w:a,m:f}})()}function Ee(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}Ee=function(t,e,n,r){function a(e,n){Ee(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(a("next",0),a("throw",1),a("return",2))},Ee(t,e,n,r)}function xe(t,e,n,r,o,a,i){try{var c=t[a](i),l=c.value}catch(t){return void n(t)}c.done?e(l):Promise.resolve(l).then(r,o)}var Oe=null;function je(){var t;return t=_e().m(function t(){var e,n,r;return _e().w(function(t){for(;;)switch(t.n){case 0:e=window.frmAdminBuild,n=e.initModal,r=e.offsetModalY,(Oe=n("#frm-form-templates-modal",p))&&r(Oe,"103px"),Ut("free-templates")&&ht().leaveEmailModal&&dn(),wp.hooks.addAction("frmAdmin.beforeOpenConfirmModal","frmFormTemplates",function(t){var e=t.$info;e.dialog("option","width",d),r(e,"103px")});case 1:return t.a(2)}},t)}),je=function(){var e=this,n=arguments;return new Promise(function(r,o){var a=t.apply(e,n);function i(t){xe(a,r,o,i,c,"next",t)}function c(t){xe(a,r,o,i,c,"throw",t)}i(void 0)})},je.apply(this,arguments)}function Ie(){return Oe}function Ce(t){var e=ht().pageTitleText,n=t||Ot("selectedCategoryEl").querySelector(".".concat(y,"-cat-text")).textContent;e.textContent=n}var Ae=function(t){return!!Zt(t)&&t.classList.contains("".concat(l,"-favorite-item"))},ke=function(t){return!!Zt(t)&&t.classList.contains("".concat(l,"-custom-item"))},Pe={},Fe=function(){var t=ht(),e=t.createFormButton,n=t.newTemplateForm,r=t.newTemplateNameInput,o=t.newTemplateActionInput,a=window.frmAdminBuild.installNewForm;r.value="",o.value="frm_install_form",a(n,"frm_install_form",e)};var Le=".".concat(l,"-item-favorite-button"),Be="".concat(Le," use"),De="#frm_heart_solid_icon",Me="#frm_heart_icon",qe=function(t){var e,n=t.currentTarget,r=ht(),o=r.templatesList,i=r.featuredTemplatesList,c=r.favoritesCategoryCountEl,u=r.customTemplatesTitle,m=n.closest(".frm-card-item"),f=m.dataset.id,p=Ae(m),d=ke(m),y=function(t){return!!Zt(t)&&a.includes(Number(t.dataset.id))}(m),v=null;if(m.classList.toggle("".concat(l,"-favorite-item"),!p),y){var h=m.closest("#".concat(l,"-list"))?i:o;h&&(v=h.querySelector('.frm-card-item[data-id="'.concat(f,'"]'))).classList.toggle("".concat(l,"-favorite-item"),!p)}var b,g=xt(),w=g.selectedCategory,S=g.favoritesCount,T=p?"remove":"add",_=m.querySelector(Be),E=null===(e=v)||void 0===e?void 0:e.querySelector(Be);"add"===T?(++S.total,d?++S.custom:++S.default,_.setAttribute("href",De),null==E||E.setAttribute("href",De)):(--S.total,d?--S.custom:--S.default,_.setAttribute("href",Me),null==E||E.setAttribute("href",Me)),c.textContent=S.total,It("favoritesCount",S),s===w&&(0===S.total&&on(),Xt(m),0===S.default&&Xt(o),0!==S.custom&&0!==S.default||Xt(u)),b=function(){return t=f,e=T,n=d,r=new FormData,o=frmDom.ajax.doJsonPost,r.append("template_id",t),r.append("operation",e),r.append("is_custom_template",n),o("add_or_remove_favorite_template",r);var t,e,n,r,o},Ft=Ft.then(b).catch(b)};var Ne=function(t){var e=t.currentTarget,n=e.closest(".frm-card-item"),r=function(t){return!!Zt(t)&&t.classList.contains("".concat(l,"-locked-item"))}(n),o=ke(n);if(r||!o)if(t.preventDefault(),r)!function(t){var e=t.dataset.requiredPlan;switch(e){case"basic":case"plus":case"business":case"elite":fn(e,t);break;case"renew":pn();break;case"free":dn()}}(n);else{var a=ht(),i=a.newTemplateForm,c=a.newTemplateNameInput,u=a.newTemplateDescriptionInput,s=a.newTemplateLinkInput,m=a.newTemplateActionInput,f=window.frmAdminBuild.installNewForm,p=n.querySelector(".frm-form-template-name").textContent.trim(),d=n.querySelector(".frm-form-templates-item-description").textContent.trim(),y="frm_install_template";c.value=p,u.value=d,m.value=y,s.value=e.href,f(i,y,e)}};var Ge=window.frmDom.search.init;function Re(t,e){var n=t.foundSomething,r=t.notEmptySearchText;if(!e||"search"!==e.type||""!==e.target.value){var o=xt(),a=ht().allItemsCategory;It("notEmptySearchText",r),o.notEmptySearchText||o.selectedCategory?(o.selectedCategory&&(function(t){var e=ht(),n=e.bodyContent,r=e.bodyContentChildren,o=e.pageTitle,a=e.templatesList,i=e.applicationTemplates,c=new Pt(n);t&&Ot("selectedCategoryEl").classList.remove(nt),Yt(r),Ce(X("Search Result","formidable")),Jt([o,a,i]),c.fadeIn()}(r),r&&It("selectedCategory","")),function(t){if(t){var e,n=ht().emptyState;if(e=n,"none"!==window.getComputedStyle(e).getPropertyValue("display")){var r=ht().pageTitle;Xt(n),Kt(r)}var o=ht(),a=o.templatesList,i=o.applicationTemplates,c=o.applicationTemplatesTitle,l=o.applicationTemplatesList;Jt([a,i,c]),0===a.offsetHeight&&Yt([a,c]),0===(null==l?void 0:l.offsetHeight)&&Xt(i)}else!function(){var t,e=xt().notEmptySearchText,n=ht(),r=n.pageTitle,o=n.emptyState,a=n.emptyStateButton,i=n.applicationTemplates;if(f!==(null===(t=o.dataset)||void 0===t?void 0:t.view)){o.setAttribute("data-view",f);var c=ht(),l=c.emptyStateTitle,u=c.emptyStateText;l.textContent=X("No templates found","formidable"),u.textContent=X("Sorry, we didn't find any templates that match your criteria.","formidable"),a.textContent=X("Start from Scratch","formidable"),Yt([r,i]),Jt([o,a])}else e?(Kt(o),Yt([r,i])):(Xt(o),o.removeAttribute("data-view"))}()}(n)):a.dispatchEvent(new Event("click",{bubbles:!0}))}}var ze=function(){var t,e=ht().emptyState;f===(null===(t=e.dataset)||void 0===t?void 0:t.view)&&(It("selectedCategory",""),te(),ht().searchInput.focus())};var Ve=function(){var t=xt().selectedCategory;m===t&&yn()},$e=function(){var t=ht().createTemplateFormsDropdown,e=t.value;if(e&&"no-forms"!==e){Ue(!1);var n=t.options[t.selectedIndex],r=n.dataset.description.trim(),o=n.dataset.name.trim(),a=" ".concat(X("Template","formidable"));o.endsWith(a)||(o+=a);var i=ht(),c=i.createTemplateName,l=i.createTemplateDescription;c.value=o,l.value=r}else Ue(!0)},Ue=function(t){var e=ht(),n=e.createTemplateName,r=e.createTemplateDescription,o=e.createTemplateButton;[n,r].forEach(function(e){e.disabled=t,t&&(e.value="")}),o.classList.toggle("disabled",t)},He=function(){var t=window.frmAdminBuild.installNewForm,e="frm_create_template",n=ht(),r=n.newTemplateForm,o=n.newTemplateActionInput,a=n.newTemplateNameInput,i=n.newTemplateDescriptionInput,c=n.newTemplateLinkInput,l=n.createTemplateName,u=n.createTemplateDescription,s=n.createTemplateFormsDropdown,m=n.createTemplateButton;o.value=e,a.value=l.value.trim(),i.value=u.value.trim(),c.value=s.value,t(r,e,m)};function Ze(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function a(n,r,o,a){var l=r&&r.prototype instanceof c?r:c,u=Object.create(l.prototype);return Je(u,"_invoke",function(n,r,o){var a,c,l,u=0,s=o||[],m=!1,f={p:0,n:0,v:t,a:p,f:p.bind(t,4),d:function(e,n){return a=e,c=0,l=t,f.n=n,i}};function p(n,r){for(c=n,l=r,e=0;!m&&u&&!o&&e3?(o=d===r)&&(l=a[(c=a[4])?5:(c=3,3)],a[4]=a[5]=t):a[0]<=p&&((o=n<2&&pr||r>d)&&(a[4]=n,a[5]=r,f.n=d,c=0))}if(o||n>1)return i;throw m=!0,r}return function(o,s,d){if(u>1)throw TypeError("Generator is already running");for(m&&1===s&&p(s,d),c=s,l=d;(e=c<2?t:l)||!m;){a||(c?c<3?(c>1&&(f.n=-1),p(c,l)):f.n=l:f.v=l);try{if(u=2,a){if(c||(o="next"),e=a[o]){if(!(e=e.call(a,l)))throw TypeError("iterator result is not an object");if(!e.done)return e;l=e.value,c<2&&(c=0)}else 1===c&&(e=a.return)&&e.call(a),c<2&&(l=TypeError("The iterator does not provide a '"+o+"' method"),c=1);a=t}else if((e=(m=f.n<0)?l:n.call(r,f))!==i)break}catch(e){a=t,c=1,l=e}finally{u=1}}return{value:e,done:m}}}(n,o,a),!0),u}var i={};function c(){}function l(){}function u(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(Je(e={},r,function(){return this}),e),m=u.prototype=c.prototype=Object.create(s);function f(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,Je(t,o,"GeneratorFunction")),t.prototype=Object.create(m),t}return l.prototype=u,Je(m,"constructor",u),Je(u,"constructor",l),l.displayName="GeneratorFunction",Je(u,o,"GeneratorFunction"),Je(m),Je(m,o,"Generator"),Je(m,r,function(){return this}),Je(m,"toString",function(){return"[object Generator]"}),(Ze=function(){return{w:a,m:f}})()}function Je(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}Je=function(t,e,n,r){function a(e,n){Je(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(a("next",0),a("throw",1),a("return",2))},Je(t,e,n,r)}function Ye(t,e,n,r,o,a,i){try{var c=t[a](i),l=c.value}catch(t){return void n(t)}c.done?e(l):Promise.resolve(l).then(r,o)}var Ke=window.frmDom.tag,Xe=function(){var t,e=(t=Ze().m(function t(){var e,n,r,o,a,i,c,l,u;return Ze().w(function(t){for(;;)switch(t.p=t.n){case 0:if(e=ht(),n=e.leaveEmailModalInput,r=n.value.trim()){t.n=1;break}return vn("empty"),t.a(2);case 1:if(Ht(r)){t.n=2;break}return vn("invalid"),t.a(2);case 2:return o=ht(),(a=o.leaveEmailModalButton).style.setProperty("cursor","not-allowed"),a.classList.add("frm_loading_button"),(i=new FormData).append("email",r),l=frmDom.ajax.doJsonPost,t.p=3,t.n=4,l("get_free_templates",i);case 4:c=t.v,t.n=6;break;case 5:return t.p=5,u=t.v,console.error("An error occurred:",u),We(),t.a(2);case 6:if(c.success){t.n=7;break}return We(),t.a(2);case 7:Ut("free-templates")&&Vt("free-templates"),$t("registered-for-free-templates","1"),window.location.reload();case 8:return t.a(2)}},t,null,[[3,5]])}),function(){var e=this,n=arguments;return new Promise(function(r,o){var a=t.apply(e,n);function i(t){Ye(a,r,o,i,c,"next",t)}function c(t){Ye(a,r,o,i,c,"throw",t)}i(void 0)})});return function(){return e.apply(this,arguments)}}();function We(){var t=ht().leaveEmailModal;t.querySelector(".inside").replaceChildren(Ke("p",X("Failed to get templates, please try again later.","formidable"))),t.querySelector(".frm_modal_footer").classList.add("frm_hidden")}var Qe=function(t){if(!t.target.closest("a")){var e=t.currentTarget;window.location.href=e.dataset.href}};function tn(){var t,e,n,r;ht().categoryItems.forEach(function(t){Mt(t,Wt),t.addEventListener("keydown",Qt)}),wp.hooks.addAction("frmPage.onCategoryClick","frmFormTemplates",function(t){!function(t){var e=ht(),n=e.bodyContentChildren,r=e.pageTitle,o=e.showCreateTemplateModalButton,a=e.templatesList,i=e.templateItems,c=e.upsellBanner;switch(v!==t&&Yt(n),Ce(),Xt(o),Kt(r),t){case v:!function(){var t=ht(),e=t.bodyContentChildren,n=t.pageTitleDivider,r=t.templateItems,o=t.twinFeaturedTemplateItems,a=t.customTemplatesSection,i=t.emptyState,c=t.applicationTemplates;Jt([].concat(nn(e),nn(r))),Yt([n].concat(nn(o),[a,i,c]))}();break;case u:!function(){if(0!==xt().availableTemplatesCount){var t=ht(),e=t.templatesList,n=t.templateItems,r=t.availableTemplateItems,o=t.upsellBanner;Yt(n),Jt([o,e].concat(nn(r)))}else!function(){var t=ht(),e=t.pageTitle,n=t.emptyState,r=t.emptyStateButton;n.setAttribute("data-view",u);var o=ht(),a=o.emptyStateTitle,i=o.emptyStateText,c=xt().extraTemplatesCount;a.textContent=X("No Templates Available","formidable"),i.textContent=function(t){try{for(var e=arguments.length,n=new Array(e>1?e-1:0),r=1;r0&&s.push(r),t.custom>0){var f=Array.from(u).filter(function(t){return!Ae(t)});Yt(f),s.push(a),s.push(c),0===t.default?Xt(i):s.push(i)}Jt(s)}else on()}();break;case m:!function(){if(0!==xt().customCount){var t=ht(),e=t.showCreateTemplateModalButton,n=t.pageTitleDivider,r=t.customTemplatesSection,o=t.customTemplatesList,a=t.customTemplatesTitle,i=t.customTemplateItems;Xt(a),Jt([e,n,r,o].concat(nn(i)))}else!function(){var t=ht(),e=t.pageTitle,n=t.emptyState,r=t.emptyStateButton;n.setAttribute("data-view",m);var o=ht(),a=o.emptyStateTitle,i=o.emptyStateText;a.textContent=X("You currently have no templates.","formidable"),i.textContent=X("You haven't created any form templates. Begin now to simplify your workflow and save time.","formidable"),r.textContent=X("Create Template","formidable"),Xt(e),Jt([n,r])}()}();break;default:Yt(i),Jt([c,a].concat(nn(Pe[t])))}}(t)}),r=ht().createFormButton,Mt(r,Fe),document.querySelectorAll(Le).forEach(function(t){return Mt(t,qe)}),document.querySelectorAll(".".concat(l,"-use-template-button")).forEach(function(t){return t.addEventListener("click",Ne)}),t=ht(),e=t.searchInput,n=t.emptyStateButton,Ge(e,"frm-card-item",{handleSearchResult:Re}),Mt(n,ze),function(){var t=ht(),e=t.createTemplateFormsDropdown,n=t.createTemplateButton,r=t.showCreateTemplateModalButton,o=t.emptyStateButton;Mt(r,Ve),Mt(o,Ve),e.addEventListener("change",$e),Mt(n,He)}(),function(){var t=ht(),e=t.leaveEmailModalButton,n=t.getFreeTemplatesBannerButton;Mt(e,Xe),Mt(n,dn)}()}function en(t){var e,n;(function(t){if(t&&t.length){var e=t.map(function(t){return function(t){var e=t.name,n=t.key,o=t.hasLiteThumbnail,a=t.isWebp,i=o?a?"".concat(pe,"/").concat(n,".webp"):"".concat(pe,"/").concat(n,".png"):"".concat(pe,"/placeholder.svg");return le("li",{className:"frm-card-item",data:{href:"".concat(r,"&triggerViewApplicationModal=1&template=").concat(n),"frm-search-text":e.toLowerCase()},children:[ue({className:"".concat(l,"-item-icon"),child:fe({src:i})}),ue({className:"".concat(l,"-item-body"),children:[se({text:X("Ready Made Solution","formidable"),className:"frm-meta-tag frm-orange-tag frm-text-xs"}),le("h3",{text:e,className:"frm-text-sm frm-font-medium frm-m-0"}),me({text:X("See all applications","formidable"),className:"frm-text-xs frm-font-semibold",href:r})]})]})}(t)});ie=ue({id:"".concat(l,"-applications"),className:tt,children:[le("h2",{text:X("Application Templates"),className:"frm-text-sm frm-mb-sm"}),le("ul",{className:"".concat(l,"-list frm-list-grid-layout"),children:e})]})}})(t.templates),(e=ht()).applicationTemplates||void 0===ie||(e.bodyContent.append(ie),bt({applicationTemplates:ie,applicationTemplatesTitle:ie.querySelector("h2"),applicationTemplatesList:ie.querySelector(".".concat(l,"-list")),applicationTemplateItems:ie.querySelectorAll(".frm-card-item")})),void 0!==(n=ht().applicationTemplateItems)&&n.forEach(function(t){t.addEventListener("click",Qe)})}function nn(t){return function(t){if(Array.isArray(t))return rn(t)}(t)||function(t){if("undefined"!=typeof Symbol&&null!=t[Symbol.iterator]||null!=t["@@iterator"])return Array.from(t)}(t)||function(t,e){if(t){if("string"==typeof t)return rn(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?rn(t,e):void 0}}(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function rn(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n3?(o=d===r)&&(l=a[(c=a[4])?5:(c=3,3)],a[4]=a[5]=t):a[0]<=p&&((o=n<2&&pr||r>d)&&(a[4]=n,a[5]=r,f.n=d,c=0))}if(o||n>1)return i;throw m=!0,r}return function(o,s,d){if(u>1)throw TypeError("Generator is already running");for(m&&1===s&&p(s,d),c=s,l=d;(e=c<2?t:l)||!m;){a||(c?c<3?(c>1&&(f.n=-1),p(c,l)):f.n=l:f.v=l);try{if(u=2,a){if(c||(o="next"),e=a[o]){if(!(e=e.call(a,l)))throw TypeError("iterator result is not an object");if(!e.done)return e;l=e.value,c<2&&(c=0)}else 1===c&&(e=a.return)&&e.call(a),c<2&&(l=TypeError("The iterator does not provide a '"+o+"' method"),c=1);a=t}else if((e=(m=f.n<0)?l:n.call(r,f))!==i)break}catch(e){a=t,c=1,l=e}finally{u=1}}return{value:e,done:m}}}(n,o,a),!0),u}var i={};function c(){}function l(){}function u(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(cn(e={},r,function(){return this}),e),m=u.prototype=c.prototype=Object.create(s);function f(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,cn(t,o,"GeneratorFunction")),t.prototype=Object.create(m),t}return l.prototype=u,cn(m,"constructor",u),cn(u,"constructor",l),l.displayName="GeneratorFunction",cn(u,o,"GeneratorFunction"),cn(m),cn(m,o,"Generator"),cn(m,r,function(){return this}),cn(m,"toString",function(){return"[object Generator]"}),(an=function(){return{w:a,m:f}})()}function cn(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}cn=function(t,e,n,r){function a(e,n){cn(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(a("next",0),a("throw",1),a("return",2))},cn(t,e,n,r)}function ln(t,e,n,r,o,a,i){try{var c=t[a](i),l=c.value}catch(t){return void n(t)}c.done?e(l):Promise.resolve(l).then(r,o)}function un(t){return function(){var e=this,n=arguments;return new Promise(function(r,o){var a=t.apply(e,n);function i(t){ln(a,r,o,i,c,"next",t)}function c(t){ln(a,r,o,i,c,"throw",t)}i(void 0)})}}var sn=function(t){return un(an().m(function e(){var n,r,o,a,i,c,l=arguments;return an().w(function(e){for(;;)switch(e.n){case 0:if(n=Ie()){e.n=1;break}return e.a(2);case 1:for(r=ht(),o=r.modalItems,Yt(o),n.dialog("option","width",p),a=l.length,i=new Array(a),c=0;c use").setAttribute("href",r?"#frm_checkmark_icon":"#frm_close_icon")});var u=e.dataset.slug?"-".concat(e.dataset.slug):"";l.href=c+u,Kt(o)}),pn=sn(function(){var t=ht().renewAccountModal;Kt(t)}),dn=sn(function(){var t=ht().leaveEmailModal;Kt(t)}),yn=sn(function(){Ie().dialog("option","width",d);var t=ht().createTemplateModal;Kt(t)}),vn=function(t){!function(t,e,n){var r=document.querySelector("#frm_leave_email"),o=document.querySelector("#frm_leave_email_error");r&&o?(o.setAttribute("frm-error",n),Kt(o),r.addEventListener("keyup",function(){Xt(o)},{once:!0})):console.warn("showFormError: Unable to find input or error element.")}(0,0,t)};var hn;hn=function(){wp.hooks.doAction("frmFormTemplates.beforeInitialize",{getState:xt,setState:jt}),e&&(0,frmDom.ajax.doJsonFetch)("get_applications_data&view=templates").then(en),function(){je.apply(this,arguments)}(),ht().templateItems.forEach(function(t){t.getAttribute("data-categories").split(",").forEach(function(e){Pe[e]||(Pe[e]=[]),Pe[e].push(t)})}),Te(),tn(),wp.hooks.doAction("frmFormTemplates.afterInitialize",{getState:xt,setState:jt}),wp.hooks.doAction("frm_new_form_modal_form",jQuery("#frm-new-template"))},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",hn):hn())})()})(); \ No newline at end of file diff --git a/js/formidable-settings-components.js b/js/formidable-settings-components.js index d6a786b727..999ee2a980 100644 --- a/js/formidable-settings-components.js +++ b/js/formidable-settings-components.js @@ -1,2931 +1 @@ -/******/ (() => { // webpackBootstrap -/******/ "use strict"; -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": -/*!*****************************************************************!*\ - !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ domReady) -/* harmony export */ }); -/** - * @typedef {() => void} Callback - * - * TODO: Remove this typedef and inline `() => void` type. - * - * This typedef is used so that a descriptive type is provided in our - * automatically generated documentation. - * - * An in-line type `() => void` would be preferable, but the generated - * documentation is `null` in that case. - * - * @see https://github.com/WordPress/gutenberg/issues/18045 - */ - -/** - * Specify a function to execute when the DOM is fully loaded. - * - * @param {Callback} callback A function to execute after the DOM is ready. - * - * @example - * ```js - * import domReady from '@wordpress/dom-ready'; - * - * domReady( function() { - * //do something after DOM loads. - * } ); - * ``` - * - * @return {void} - */ -function domReady(callback) { - if (typeof document === 'undefined') { - return; - } - - if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. - document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. - ) { - return void callback(); - } // DOMContentLoaded has not fired yet, delay callback until then. - - - document.addEventListener('DOMContentLoaded', callback); -} -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./js/src/admin/components/dependent-updater-component.js": -/*!****************************************************************!*\ - !*** ./js/src/admin/components/dependent-updater-component.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmStyleDependentUpdaterComponent) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * This component updates the dependent style element's values and triggers a custom change event for each style element, initiating the style preview. - * The names of the elements that will be updated are specified using the "will-change" attribute. - * It is primarily used in components from Style/Quick Settings. - * For instance, when the "FrmPrimaryColorStyleComponent" is changed, it simultaneously updates various style elements like border color, text color, and button backgrounds. - */ -var frmStyleDependentUpdaterComponent = /*#__PURE__*/function () { - /** - * Creates an instance of frmStyleDependentUpdaterComponent. - * - * @param {HTMLElement} component - The component element. - */ - function frmStyleDependentUpdaterComponent(component) { - _classCallCheck(this, frmStyleDependentUpdaterComponent); - this.component = component; - try { - var willChangeData = JSON.parse(this.component.dataset.willChange); - this.data = { - propagateInputs: this.initPropagationList(willChangeData), - changeEvent: new Event('change', { - bubbles: true - }) - }; - } catch (error) { - console.error('Error parsing JSON data from "will-change" attribute.', error); - } - } - - /** - * Initializes the list of inputs to propagate changes to. - * The selection is made by provided input's names list in "will-change" attribute. - * - * @param {string[]} inputNames - The names of the inputs to propagate changes to. - * @return {HTMLElement[]} - The list of inputs to propagate changes to. - */ - return _createClass(frmStyleDependentUpdaterComponent, [{ - key: "initPropagationList", - value: function initPropagationList(inputNames) { - var list = []; - inputNames.forEach(function (name) { - var input = document.querySelector("input[name=\"".concat(name, "\"]")); - if (input) { - list.push(input); - } - }); - return list; - } - - /** - * Updates all dependent elements with the given value. - * - * @param {string} value - The value to update the dependent elements with. - */ - }, { - key: "updateAllDependentElements", - value: function updateAllDependentElements(value) { - this.data.propagateInputs.forEach(function (input) { - input.value = value; - }); - this.data.propagateInputs[0].dispatchEvent(this.data.changeEvent); - } - }]); -}(); - - -/***/ }), - -/***/ "./js/src/components/class-tabs-navigator.js": -/*!***************************************************!*\ - !*** ./js/src/components/class-tabs-navigator.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmTabsNavigator: () => (/* binding */ frmTabsNavigator) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmTabsNavigator = /*#__PURE__*/function () { - function frmTabsNavigator(wrapper) { - _classCallCheck(this, frmTabsNavigator); - if (wrapper === undefined) { - return; - } - this.wrapper = wrapper instanceof Element ? wrapper : document.querySelector(wrapper); - if (null === this.wrapper) { - return; - } - this.flexboxSlidesGap = '16px'; - this.navs = this.wrapper.querySelectorAll('.frm-tabs-navs ul > li'); - this.slideTrackLine = this.wrapper.querySelector('.frm-tabs-active-underline'); - this.slideTrack = this.wrapper.querySelector('.frm-tabs-slide-track'); - this.slides = this.wrapper.querySelectorAll('.frm-tabs-slide-track > div'); - this.isRTL = document.documentElement.dir === 'rtl' || document.body.dir === 'rtl'; - this.resizeObserver = null; - this.init(); - } - return _createClass(frmTabsNavigator, [{ - key: "init", - value: function init() { - var _this = this; - if (null === this.wrapper || !this.navs.length || null === this.slideTrackLine || null === this.slideTrack || !this.slides.length) { - return; - } - this.navs.forEach(function (nav, index) { - nav.addEventListener('click', function (event) { - return _this.onNavClick(event, index); - }); - if (nav.classList.contains('frm-active')) { - _this.initSlideTrackUnderline(nav); - } - }); - this.slideTrackLine.style.display = 'block'; - this.setupScrollbarObserver(); - // Cleanup observers when page unloads to prevent memory leaks - window.addEventListener('beforeunload', this.cleanupObservers); - } - }, { - key: "onNavClick", - value: function onNavClick(event, index) { - var navItem = event.currentTarget; - event.preventDefault(); - this.removeActiveClassnameFromNavs(); - navItem.classList.add('frm-active'); - this.initSlideTrackUnderline(navItem); - this.changeSlide(index); - - // Handle special case for frm_insert_fields_tab - var navLink = navItem.querySelector('a'); - if (navLink && navLink.id === 'frm_insert_fields_tab' && !navLink.closest('#frm_adv_info')) { - var _window$frmAdminBuild, _window$frmAdminBuild2; - (_window$frmAdminBuild = window.frmAdminBuild) === null || _window$frmAdminBuild === void 0 || (_window$frmAdminBuild2 = _window$frmAdminBuild.clearSettingsBox) === null || _window$frmAdminBuild2 === void 0 || _window$frmAdminBuild2.call(_window$frmAdminBuild); - } - } - }, { - key: "initSlideTrackUnderline", - value: function initSlideTrackUnderline(nav) { - var activeNav = nav !== undefined ? nav : this.navs.filter(function (nav) { - return nav.classList.contains('frm-active'); - }); - this.positionUnderlineIndicator(activeNav); - } - - /** - * Sets up a ResizeObserver to watch for scrollbar changes in the parent container. - * Automatically repositions the underline indicator when layout changes occur. - */ - }, { - key: "setupScrollbarObserver", - value: function setupScrollbarObserver() { - var _this2 = this; - var resizeObserverTarget = document.querySelector('.frm-scrollbar-wrapper, .styling_settings') || document.body; - if (!resizeObserverTarget || !('ResizeObserver' in window)) { - return; - } - this.resizeObserver = new ResizeObserver(function () { - var activeNav = _this2.wrapper.querySelector('.frm-tabs-navs ul > li.frm-active'); - if (activeNav) { - _this2.positionUnderlineIndicator(activeNav); - } - }); - this.resizeObserver.observe(resizeObserverTarget); - } - - /** - * Cleans up observers to prevent memory leaks. - */ - }, { - key: "cleanupObservers", - value: function cleanupObservers() { - if (this.resizeObserver) { - this.resizeObserver.disconnect(); - this.resizeObserver = null; - } - } - - /** - * Positions the underline indicator based on the active navigation element. - * - * @param {HTMLElement} activeNav The active navigation element to position the underline under - */ - }, { - key: "positionUnderlineIndicator", - value: function positionUnderlineIndicator(activeNav) { - var _this3 = this; - requestAnimationFrame(function () { - var position = _this3.isRTL ? -(activeNav.parentElement.offsetWidth - activeNav.offsetLeft - activeNav.offsetWidth) : activeNav.offsetLeft; - _this3.slideTrackLine.style.transform = "translateX(".concat(position, "px)"); - _this3.slideTrackLine.style.width = "".concat(activeNav.clientWidth, "px"); - }); - } - }, { - key: "changeSlide", - value: function changeSlide(index) { - this.removeActiveClassnameFromSlides(); - var translate = index == 0 ? '0px' : "calc( ( ".concat(index * 100, "% + ").concat(parseInt(this.flexboxSlidesGap, 10) * index, "px ) * ").concat(this.isRTL ? 1 : -1, " )"); - if ('0px' !== translate) { - this.slideTrack.style.transform = "translateX(".concat(translate, ")"); - } else { - this.slideTrack.style.removeProperty('transform'); - } - if (index in this.slides) { - this.slides[index].classList.add('frm-active'); - } - } - }, { - key: "removeActiveClassnameFromSlides", - value: function removeActiveClassnameFromSlides() { - this.slides.forEach(function (slide) { - return slide.classList.remove('frm-active'); - }); - } - }, { - key: "removeActiveClassnameFromNavs", - value: function removeActiveClassnameFromNavs() { - this.navs.forEach(function (nav) { - return nav.classList.remove('frm-active'); - }); - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }), - -/***/ "./js/src/settings-components/components/index.js": -/*!********************************************************!*\ - !*** ./js/src/settings-components/components/index.js ***! - \********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmRadioComponent: () => (/* reexport safe */ _radio_component__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ frmSliderComponent: () => (/* reexport safe */ _slider_component__WEBPACK_IMPORTED_MODULE_1__["default"]), -/* harmony export */ frmTabsComponent: () => (/* reexport safe */ _tabs_component__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ initToggleGroupComponents: () => (/* reexport safe */ _toggle_group__WEBPACK_IMPORTED_MODULE_4__.initToggleGroupComponents), -/* harmony export */ initTokenInputFields: () => (/* reexport safe */ _token_input__WEBPACK_IMPORTED_MODULE_3__.initTokenInputFields), -/* harmony export */ setupUnitInputHandlers: () => (/* reexport safe */ _unit_input__WEBPACK_IMPORTED_MODULE_5__.setupUnitInputHandlers) -/* harmony export */ }); -/* harmony import */ var _radio_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./radio-component */ "./js/src/settings-components/components/radio-component.js"); -/* harmony import */ var _slider_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./slider-component */ "./js/src/settings-components/components/slider-component.js"); -/* harmony import */ var _tabs_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./tabs-component */ "./js/src/settings-components/components/tabs-component.js"); -/* harmony import */ var _token_input__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./token-input */ "./js/src/settings-components/components/token-input/index.js"); -/* harmony import */ var _toggle_group__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./toggle-group */ "./js/src/settings-components/components/toggle-group/index.js"); -/* harmony import */ var _unit_input__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./unit-input */ "./js/src/settings-components/components/unit-input.js"); - - - - - - - -/***/ }), - -/***/ "./js/src/settings-components/components/radio-component.js": -/*!******************************************************************!*\ - !*** ./js/src/settings-components/components/radio-component.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmRadioComponent) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Internal dependencies - */ - - - -/** - * Represents a radio component. - * - * @class - */ -var frmRadioComponent = /*#__PURE__*/function () { - function frmRadioComponent() { - var _this = this; - _classCallCheck(this, frmRadioComponent); - this.radioElements = document.querySelectorAll('.frm-style-component.frm-radio-component'); - this.observers = new Map(); - if (0 < this.radioElements.length) { - this.init(); - } - - /** - * Handles the addition of new fields. - * - * @param {Event} event The frm_added_field event. - * @param {HTMLElement} event.frmField The added field object being destructured from the event. - */ - document.addEventListener('frm_added_field', function (_ref) { - var frmField = _ref.frmField; - return _this.discoverAndInitFieldRadios(frmField.dataset.fid); - }); - - /** - * Handles the addition of new fields via AJAX. - * - * @param {Event} event The frm_ajax_loaded_field event. - * @param {HTMLElement} event.frmFields The added field objects being destructured from the event. - */ - document.addEventListener('frm_ajax_loaded_field', function (_ref2) { - var frmFields = _ref2.frmFields; - return frmFields.forEach(function (field) { - return _this.discoverAndInitFieldRadios(field.id); - }); - }); - - // Cleanup observers when page unloads to prevent memory leaks - window.addEventListener('beforeunload', function () { - return _this.cleanupObservers(); - }); - - // Handle window resize with throttling - this.resizeTimeout = null; - window.addEventListener('resize', function () { - return _this.throttledUpdateAllTrackers(); - }); - } - - /** - * Initializes the radio component. - */ - return _createClass(frmRadioComponent, [{ - key: "init", - value: function init() { - this.initRadio(); - this.initTrackerOnAccordionClick(); - } - - /** - * Discovers and initializes radio components for a specific field. - * - * @param {string|number} fieldId The unique identifier of the field whose radio components should be discovered and initialized - * @throws {Error} Throws an error if the field container is not found in the DOM - */ - }, { - key: "discoverAndInitFieldRadios", - value: function discoverAndInitFieldRadios(fieldId) { - var fieldContainer = document.getElementById("frm-single-settings-".concat(fieldId)); - if (!fieldContainer) { - throw new Error("Field container not found for field ID: ".concat(fieldId)); - } - this.radioElements = fieldContainer.querySelectorAll('.frm-style-component.frm-radio-component'); - this.initRadio(); - } - - /** - * Initializes the radio component. - */ - }, { - key: "initRadio", - value: function initRadio() { - var _this2 = this; - this.radioElements.forEach(function (element) { - _this2.initOnRadioChange(element); - _this2.initVisibilityObserver(element); - }); - } - }, { - key: "initTrackerOnAccordionClick", - value: function initTrackerOnAccordionClick() { - var _this3 = this; - var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); - accordionitems.forEach(function (accordionitem) { - accordionitem.addEventListener('click', function (event) { - var wrapper = event.target.closest('.accordion-section'); - var radioButtons = wrapper.querySelectorAll('.frm-style-component.frm-radio-component input[type="radio"]:checked'); - radioButtons.forEach(function (radio) { - setTimeout(function () { - return _this3.onRadioChange(radio); - }, 200); - }); - }); - }); - } - - /** - * Initializes the onRadioChange event for the given wrapper. - * - * @param {HTMLElement} radioElement - The radio element. - */ - }, { - key: "initOnRadioChange", - value: function initOnRadioChange(radioElement) { - var _this4 = this; - radioElement.querySelectorAll('input[type="radio"]').forEach(function (radio) { - if (radio.checked) { - _this4.onRadioChange(radio); - } - radio.addEventListener('change', function (event) { - _this4.onRadioChange(event.target); - }); - }); - } - - /** - * Handles the onRadioChange event for the given wrapper. - * - * @param {HTMLElement} target - The active radio button. - */ - }, { - key: "onRadioChange", - value: function onRadioChange(target) { - var wrapper = target.closest('.frm-style-component.frm-radio-component'); - var activeItem = wrapper.querySelector('input[type="radio"]:checked + label'); - if (null === activeItem) { - return; - } - this.moveTracker(activeItem, wrapper); - this.hideExtraElements(target); - this.maybeShowExtraElements(target); - } - - /** - * Display additional elements related to the selected radio option. - * - * @param {HTMLElement} radio - The radio button element. - */ - }, { - key: "maybeShowExtraElements", - value: function maybeShowExtraElements(radio) { - var elementAttr = radio.getAttribute('data-frm-show-element'); - if (null === elementAttr) { - return; - } - var elements = document.querySelectorAll("div[data-frm-element=\"".concat(elementAttr, "\"]")); - if (0 === elements.length) { - return; - } - elements.forEach(function (element) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(element); - element.classList.add('frm-element-is-visible'); - }); - } - - /** - * Throttled update of all radio trackers on window resize. - * - * @return {void} - */ - }, { - key: "throttledUpdateAllTrackers", - value: function throttledUpdateAllTrackers() { - var _this5 = this; - if (this.resizeTimeout) { - return; - } - this.resizeTimeout = requestAnimationFrame(function () { - _this5.resizeTimeout = null; - document.querySelectorAll('.frm-radio-component input[type="radio"]:checked').forEach(function (radio) { - var wrapper = radio.closest('.frm-radio-component'); - if (wrapper && wrapper.offsetWidth > 0) { - _this5.onRadioChange(radio); - } - }); - }); - } - - /** - * Initializes visibility observer for the radio component. This handles cases when components are conditionally shown. - * - * @param {HTMLElement} element The radio component element - * @return {void} - */ - }, { - key: "initVisibilityObserver", - value: function initVisibilityObserver(element) { - var _this6 = this; - if (this.observers.has(element)) { - this.observers.get(element).disconnect(); - } - var observer = new MutationObserver(function () { - // Check if element is now visible - if ((0,core_utils__WEBPACK_IMPORTED_MODULE_1__.isVisible)(element)) { - var radio = element.querySelector('input[type="radio"]:checked'); - if (radio) { - _this6.onRadioChange(radio); - } - } - }); - this.observers.set(element, observer); - - // Observe for attribute changes on the component and its ancestors - observer.observe(element, { - attributes: true, - attributeFilter: ['class', 'style'] - }); - - // Also observe parent elements up to a reasonable depth - var parent = element.parentElement; - for (var i = 0; i < 7 && parent; i++) { - observer.observe(parent, { - attributes: true, - attributeFilter: ['class', 'style'] - }); - parent = parent.parentElement; - } - } - - /** - * Cleanup all observers to prevent memory leaks. - */ - }, { - key: "cleanupObservers", - value: function cleanupObservers() { - this.observers.forEach(function (observer) { - observer.disconnect(); - }); - this.observers.clear(); - } - - /** - * Hide the possible opepend extra elements. - */ - }, { - key: "hideExtraElements", - value: function hideExtraElements() { - var elements = document.querySelectorAll('.frm-element-is-visible'); - if (0 === elements.length) { - return; - } - elements.forEach(function (element) { - element.classList.remove('frm-element-is-visible'); - element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(element); - }); - } - - /** - * Moves the tracker to the active item. - * - * @param {HTMLElement} activeItem - The active item element. - * @param {HTMLElement} wrapper - The wrapper element. - */ - }, { - key: "moveTracker", - value: function moveTracker(activeItem, wrapper) { - var offset = activeItem.offsetLeft; - var width = activeItem.offsetWidth; - var tracker = wrapper.querySelector('.frm-radio-active-tracker'); - tracker.style.left = 0; - tracker.style.width = "".concat(width, "px"); - tracker.style.transform = "translateX(".concat(offset, "px)"); - } - }]); -}(); - - -/***/ }), - -/***/ "./js/src/settings-components/components/slider-component.js": -/*!*******************************************************************!*\ - !*** ./js/src/settings-components/components/slider-component.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmSliderComponent) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../admin/components/dependent-updater-component */ "./js/src/admin/components/dependent-updater-component.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Internal dependencies - */ - - - -/** - * Represents a slider component. - * - * @class frmSliderComponent - */ -var frmSliderComponent = /*#__PURE__*/function () { - function frmSliderComponent() { - var _this = this; - var sliderElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; - var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - _classCallCheck(this, frmSliderComponent); - this.loadedByWebComponent = sliderElements.length > 0; - this.sliderElements = sliderElements.length > 0 ? sliderElements : document.querySelectorAll('.frm-slider-component'); - this.settings = settings; - if (0 === this.sliderElements.length) { - return; - } - - // The slider bullet point width in pixels. Used in value calculation on drag event. - this.sliderBulletWidth = 16; - this.sliderMarginRight = 5; - this.eventsChange = []; - var debounce = frmDom.util.debounce; - this.valueChangeDebouncer = debounce(function (index) { - return _this.triggerValueChange(index); - }, 25); - this.initOptions(); - this.init(); - } - - /** - * Initializes the options for the slider component. - */ - return _createClass(frmSliderComponent, [{ - key: "initOptions", - value: function initOptions() { - var _this2 = this; - this.options = []; - this.sliderElements.forEach(function (element, index) { - var parentWrapper = element.classList.contains('frm-has-multiple-values') ? element.closest('.frm-style-component') : element; - var steps = _this2.settings.steps || (element.dataset.steps ? JSON.parse(element.dataset.steps) : null); - _this2.options.push({ - dragging: false, - startX: 0, - translateX: 0, - maxValue: parseInt(element.dataset.maxValue, 10), - element: element, - index: index, - value: 0, - steps: steps, - dependentUpdater: parentWrapper.classList.contains('frm-style-dependent-updater-component') ? new _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__["default"](parentWrapper) : null - }); - }); - } - - /** - * Initializes the slider component. - */ - }, { - key: "init", - value: function init() { - this.initDraggable(); - if (this.loadedByWebComponent) { - this.initSlidersPositionInsideWebComponent(); - return; - } - this.initSlidersPosition(); - } - - /** - * Initializes the draggable functionality for the slider component. - */ - }, { - key: "initDraggable", - value: function initDraggable() { - var _this3 = this; - this.sliderElements.forEach(function (element, index) { - _this3.eventsChange[index] = new Event('change', { - bubbles: true, - cancelable: true - }); - var draggableBullet = element.querySelector('.frm-slider-bullet'); - var valueInput = element.querySelector('.frm-slider-value input[type="text"]'); - valueInput.addEventListener('change', function (event) { - var unit = element.querySelector('select').value; - if (_this3.getMaxValue(unit, index) < parseInt(event.target.value, 10)) { - return; - } - _this3.initSliderWidth(element); - _this3.options[index].fullValue = _this3.updateValue(element, valueInput.value + unit); - _this3.triggerValueChange(index); - }); - _this3.expandSliderGroup(element); - _this3.updateOnUnitChange(element, valueInput, index); - _this3.changeSliderPositionOnClick(element, valueInput, index); - frmSliderComponent.maybeDisableUnitDropdown(element); - draggableBullet.addEventListener('mousedown', function (event) { - event.preventDefault(); - event.stopPropagation(); - if (element.classList.contains('frm-disabled')) { - return; - } - _this3.enableDragging(event, index); - var onMouseMove = function onMouseMove(moveEvent) { - return _this3.moveTracker(moveEvent, index); - }; - var _onMouseUp = function onMouseUp() { - _this3.disableDragging(index); - document.removeEventListener('mousemove', onMouseMove); - document.removeEventListener('mouseup', _onMouseUp); - }; - document.addEventListener('mousemove', onMouseMove); - document.addEventListener('mouseup', _onMouseUp); - }); - }); - } - }, { - key: "expandSliderGroup", - value: function expandSliderGroup(element) { - var svgIcon = element.querySelector('.frmsvg'); - if (element.dataset.displaySliders === undefined || null === svgIcon) { - return; - } - var sliderGroupItems = this.getSliderGroupItems(element); - svgIcon.addEventListener('click', function () { - sliderGroupItems.forEach(function (item) { - item.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); - }); - }); - } - }, { - key: "updateOnUnitChange", - value: function updateOnUnitChange(element, valueInput, index) { - var _this4 = this; - element.querySelector('select').addEventListener('change', function (event) { - var unit = event.target.value.toLowerCase(); - if ('' === unit) { - element.classList.add('frm-disabled', 'frm-empty'); - return; - } - if ('auto' === unit) { - element.classList.add('frm-disabled'); - _this4.updateValue(element, 'auto'); - _this4.triggerValueChange(index); - return; - } - element.classList.remove('frm-disabled', 'frm-empty'); - _this4.options[index].fullValue = valueInput.value + unit; - _this4.updateValue(element, _this4.options[index].fullValue); - _this4.triggerValueChange(index); - }); - } - }, { - key: "changeSliderPositionOnClick", - value: function changeSliderPositionOnClick(element, valueInput, index) { - var _this5 = this; - var frmSlider = element.querySelector('.frm-slider'); - var customEvent = new Event('change', { - bubbles: true, - cancelable: true - }); - frmSlider.addEventListener('click', function (event) { - if (element.classList.contains('frm-disabled')) { - return; - } - event.preventDefault(); - event.stopPropagation(); - if (!event.target.classList.contains('frm-slider') && !event.target.classList.contains('frm-slider-active-track')) { - return; - } - var sliderWidth = frmSlider.offsetWidth - _this5.sliderBulletWidth; - var sliderRect = frmSlider.getBoundingClientRect(); - var deltaX = event.clientX - sliderRect.left - _this5.sliderBulletWidth; - var unit = element.querySelector('select').value; - var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, _this5.getMaxValue(unit, index), _this5.options[index].steps); - if (value < 0) { - return; - } - _this5.options[index].fullValue = _this5.updateValue(element, value + unit); - _this5.initChildSlidersWidth(element, deltaX, index, value + unit); - valueInput.value = value; - valueInput.dispatchEvent(customEvent); - }); - } - - /** - * Disables the unit dropdown if there is only a single unit option. - * - * @param {HTMLElement} element - The slider element. - */ - }, { - key: "getSliderGroupItems", - value: - /** - * Retrieves an array of slider group items based on the provided element. - * - * @param {HTMLElement} element - The element to retrieve slider group items from. - * @return {NodeList} - An array-like object containing the slider group items. - */ - function getSliderGroupItems(element) { - if (element.dataset.displaySliders === undefined) { - return []; - } - var slidersGroup = element.dataset.displaySliders.split(','); - var query = slidersGroup.map(function (item) { - return ".frm-slider-component[data-type=\"".concat(item, "\"]"); - }).join(', '); - return element.closest('.frm-style-component').querySelectorAll(query); - } - }, { - key: "initSlidersPositionInsideWebComponent", - value: function initSlidersPositionInsideWebComponent() { - var _this6 = this; - this.sliderElements.forEach(function (element, index) { - _this6.initSliderWidth(element, index); - }); - } - - /** - * Initializes the position of sliders when a accordion section is opened. - */ - }, { - key: "initSlidersPosition", - value: function initSlidersPosition() { - var _this7 = this; - var emailSettings = document.querySelector('.email_settings'); - if (emailSettings) { - this.initSlidersWidth(emailSettings); - return; - } - var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); - var quickSettings = document.querySelector('.frm-quick-settings'); - var openedAccordion = document.querySelector('.accordion-section.open'); - - // Detect if upload background image upload has triggered and initialize the "Image Opacity" slider width. - wp.hooks.addAction('frm_pro_on_bg_image_upload', 'formidable', function (event) { - var imageBackgroundOpacitySlider = event.closest('.accordion-section-content').querySelector('#frm-bg-image-opacity-slider'); - _this7.initSlidersWidth(imageBackgroundOpacitySlider); - }); - - // init the sliders width from "Quick Settings" page. - if (quickSettings) { - this.initSlidersWidth(quickSettings); - } - - // Init the sliders width in opened accordion section from "Advanced Settings" page. - if (openedAccordion) { - this.initSlidersWidth(openedAccordion); - } - - // init the sliders width everytime when an accordion section is opened from "Advanced Settings" page. - accordionitems.forEach(function (item) { - item.addEventListener('click', function (event) { - _this7.initSlidersWidth(event.target.closest('.accordion-section')); - }); - }); - this.initSliderPositionOnFieldShapeChange(); - } - - /** - * Initializes the width of "Corner Radius" slider that is dynamically is displayed on "Field Shape" option change from "Quick Settings". - * - * @return {void} - */ - }, { - key: "initSliderPositionOnFieldShapeChange", - value: function initSliderPositionOnFieldShapeChange() { - var _this8 = this; - var fieldShapeType = document.querySelector('.frm-style-component.frm-field-shape'); - if (!fieldShapeType) { - return; - } - var radioButtons = fieldShapeType.querySelectorAll('input[type="radio"]'); - radioButtons.forEach(function (radio) { - radio.addEventListener('change', function (event) { - if (event.target.checked && 'rounded-corner' === event.target.value) { - var slider = document.querySelector('div[data-frm-element="field-shape-corner-radius"] .frm-slider-component'); - _this8.initSliderWidth(slider); - } - }); - }); - } - - /** - * Initializes the width of sliders within a given section. - * - * @param {HTMLElement} section - The section containing the sliders. - * @return {void} - */ - }, { - key: "initSlidersWidth", - value: function initSlidersWidth(section) { - var _this9 = this; - var sliders = section.querySelectorAll('.frm-slider-component'); - sliders.forEach(function (slider) { - setTimeout(function () { - _this9.initSliderWidth(slider); - }, 100); - }); - } - - /** - * Initializes the width of a slider. - * - * @param {HTMLElement} slider - The slider element. - * @param {number} sliderIndex - The index of the slider. - * @return {void} - */ - }, { - key: "initSliderWidth", - value: function initSliderWidth(slider) { - var sliderIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - if (slider.classList.contains('frm-disabled')) { - return; - } - var index = sliderIndex !== null ? sliderIndex : this.getSliderIndex(slider); - var sliderWidth = slider.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; - var value = parseInt(slider.querySelector('.frm-slider-value input[type="text"]').value, 10); - var unit = slider.querySelector('select').value; - var steps = this.options[index].steps; - var deltaX = Math.ceil(value / this.options[index].maxValue * sliderWidth); - if ('%' === unit) { - deltaX = Math.round(sliderWidth * value / 100); - } else if (steps && steps.length > 0) { - deltaX = frmSliderComponent.calculateDeltaXFromSteps(value, steps, sliderWidth); - } - slider.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); - this.options[index].translateX = deltaX; - this.options[index].value = value + unit; - } - - /** - * Calculates the deltaX position based on a value and steps array. - * - * @param {number} value - The current value. - * @param {Array} steps - Array of step values. - * @param {number} sliderWidth - The width of the slider. - * @return {number} - The calculated deltaX position. - */ - }, { - key: "initChildSlidersWidth", - value: - /** - * Initializes the width of child sliders. - * - * @param {HTMLElement} slider - The parent slider element. - * @param {number} width - The width to set for the child sliders. - * @param {number} index - The starting index for the child sliders. - * @param {number} value - The value to set for the child sliders. - */ - function initChildSlidersWidth(slider, width, index, value) { - var _this0 = this; - if (!slider.classList.contains('frm-has-independent-fields') && !slider.classList.contains('frm-has-multiple-values')) { - return; - } - var childSliders = slider.classList.contains('frm-has-independent-fields') ? slider.querySelectorAll('.frm-independent-slider-field') : this.getSliderGroupItems(slider); - childSliders.forEach(function (item, childIndex) { - item.querySelector('.frm-slider-active-track').style.width = "".concat(width, "px"); - _this0.options[index + childIndex + 1].translateX = width; - _this0.options[index + childIndex + 1].value = value; - }); - } - - /** - * Returns the index of the specified slider element. - * - * @param {HTMLElement} slider - The slider element. - * @return {number} The index of the slider element. - */ - }, { - key: "getSliderIndex", - value: function getSliderIndex(slider) { - return this.options.filter(function (option) { - return option.element === slider; - })[0].index; - } - - /** - * Handles the movement of the slider tracker. - * - * @param {Event} event - The event object representing the mouse movement. - * @param {number} index - The index of the slider element. - * @return {void} - */ - }, { - key: "moveTracker", - value: function moveTracker(event, index) { - if (!this.options[index].dragging) { - return; - } - var deltaX = event.clientX - this.options[index].startX; - var element = this.sliderElements[index]; - var sliderWidth = element.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; - - // Clamp deltaX within valid range - deltaX = Math.max(deltaX, 0); - deltaX = Math.min(deltaX, sliderWidth); - var unit = element.querySelector('select').value; - var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, this.getMaxValue(unit, index), this.options[index].steps); - element.querySelector('.frm-slider-value input[type="text"]').value = value; - element.querySelector('.frm-slider-bullet .frm-slider-value-label').innerText = value; - element.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); - this.initChildSlidersWidth(element, deltaX, index, value + unit); - this.options[index].translateX = deltaX; - this.options[index].value = value + unit; - this.options[index].fullValue = this.updateValue(element, this.options[index].value); - this.valueChangeDebouncer(index); - } - - /** - * Get the maximum value based on the unit and index. - * - * @param {string} unit - The unit of measurement. - * @param {number} index - The index of the option. - * @return {number} The maximum value. - */ - }, { - key: "getMaxValue", - value: function getMaxValue(unit, index) { - return '%' === unit ? 100 : this.options[index].maxValue; - } - - /** - * Enables dragging for the slider component. - * - * @param {Event} event - The event object. - * @param {number} index - The index of the option being dragged. - */ - }, { - key: "enableDragging", - value: function enableDragging(event, index) { - event.target.classList.add('frm-dragging'); - this.options[index].dragging = true; - this.options[index].startX = event.clientX - this.options[index].translateX; - } - - /** - * Disables dragging for a specific index. - * - * @param {number} index - The index of the option to disable dragging for. - */ - }, { - key: "disableDragging", - value: function disableDragging(index) { - if (false === this.options[index].dragging) { - return; - } - var draggableBullet = this.sliderElements[index].querySelector('.frm-slider-bullet'); - draggableBullet.classList.remove('frm-dragging'); - this.options[index].dragging = false; - this.triggerValueChange(index); - } - - /** - * Triggers a value change for the specified index. - * - * @param {number} index - The index of the value to be changed. - */ - }, { - key: "triggerValueChange", - value: function triggerValueChange(index) { - var _this1 = this; - if (null !== this.options[index].dependentUpdater) { - this.options[index].dependentUpdater.updateAllDependentElements(this.options[index].fullValue); - return; - } - var input = this.sliderElements[index].classList.contains('frm-has-multiple-values') ? this.sliderElements[index].closest('.frm-style-component').querySelector('input[type="hidden"]') : this.sliderElements[index].querySelectorAll('.frm-slider-value input[type="hidden"]'); - if (input instanceof NodeList) { - input.forEach(function (item) { - item.dispatchEvent(_this1.eventsChange[index]); - }); - return; - } - input.dispatchEvent(this.eventsChange[index]); - } - - /** - * Calculates the value based on the width, deltaX, and maxValue. - * - * @param {number} width - The width of the slider. - * @param {number} deltaX - The change in x-coordinate. - * @param {number} maxValue - The maximum value. - * @param {Array|null} steps - Optional array of step values to snap to. - * @return {number} - The calculated value. - */ - }, { - key: "updateValue", - value: - /** - * Updates the value of a slider component. - * - * @param {HTMLElement} element - The slider component element. - * @param {string} value - The new value to be set. - * @return {string} - The updated value. - */ - function updateValue(element, value) { - var _this10 = this; - // When the slider component is used for "Base Font Size", we need to update a hidden input field when change happens to indicate that the "Base Font Size" has been adjusted. - // Used to avoid conflicts with other possible font sizes adjustemnts in "Advanced Settings" when moving from "Quick Settings" when "Base Font Size" is not changed. - if (element.classList.contains('frm-base-font-size')) { - var userBaseFontSizeInput = document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]'); - if (userBaseFontSizeInput) { - userBaseFontSizeInput.value = 'true'; - } - } - if (element.classList.contains('frm-has-multiple-values')) { - var input = element.closest('.frm-style-component').querySelector('input[type="hidden"]'); - var inputValue = input.value.split(' '); - var type = element.dataset.type; - if (!inputValue[2]) { - inputValue[2] = '0px'; - } - if (!inputValue[3]) { - inputValue[3] = '0px'; - } - switch (type) { - case 'vertical': - inputValue[0] = value; - inputValue[2] = value; - break; - case 'horizontal': - inputValue[1] = value; - inputValue[3] = value; - break; - case 'top': - inputValue[0] = value; - break; - case 'bottom': - inputValue[2] = value; - break; - case 'left': - inputValue[3] = value; - break; - case 'right': - inputValue[1] = value; - break; - } - var newValue = inputValue.join(' '); - input.value = newValue; - var childSlidersGroup = this.getSliderGroupItems(element); - childSlidersGroup.forEach(function (slider) { - var unitMeasure = _this10.getUnitMeasureFromValue(value); - slider.querySelector('.frm-slider-value input[type="text"]').value = parseInt(value, 10); - slider.querySelector('select').value = unitMeasure; - }); - return newValue; - } - if (element.classList.contains('frm-has-independent-fields')) { - var inputValues = element.querySelectorAll('.frm-slider-value input[type="hidden"]'); - var visibleValues = element.querySelectorAll('.frm-slider-value input[type="text"]'); - inputValues.forEach(function (input, index) { - input.value = value; - visibleValues[index + 1].value = parseInt(value, 10); - }); - return value; - } - element.querySelector('.frm-slider-value input[type="hidden"]').value = value; - return value; - } - - /** - * Returns the unit of measurement used in the given value. - * - * @param {string} value - The value to check for the unit of measurement. - * @return {string} The unit of measurement ('%', 'px', 'em') found in the value, or an empty string if none is found. - */ - }, { - key: "getUnitMeasureFromValue", - value: function getUnitMeasureFromValue(value) { - return ['%', 'px', 'em'].find(function (unit) { - return value.includes(unit); - }) || ''; - } - }], [{ - key: "maybeDisableUnitDropdown", - value: function maybeDisableUnitDropdown(element) { - var select = element.querySelector('select'); - if (!select) { - return; - } - var options = Array.from(select.options).filter(function (option) { - return '' !== option.value; - }); - if (1 >= options.length) { - select.classList.add('frm-single-unit'); - select.addEventListener('mousedown', function (event) { - return event.preventDefault(); - }); - } - } - }, { - key: "calculateDeltaXFromSteps", - value: function calculateDeltaXFromSteps(value, steps, sliderWidth) { - var stepIndex = steps.indexOf(value); - if (-1 === stepIndex) { - // If value not in steps, find closest and use its position - var closestValue = frmSliderComponent.snapToStep(value, steps); - var closestIndex = steps.indexOf(closestValue); - return Math.round(closestIndex / (steps.length - 1) * sliderWidth); - } - return Math.round(stepIndex / (steps.length - 1) * sliderWidth); - } - }, { - key: "calculateValue", - value: function calculateValue(width, deltaX, maxValue) { - var steps = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - if (steps && steps.length > 0) { - // For stepped sliders, map position directly to step index - var position = deltaX / width; - var stepIndex = Math.round(position * (steps.length - 1)); - var clampedIndex = Math.max(0, Math.min(stepIndex, steps.length - 1)); - return steps[clampedIndex]; - } - - // Calculate value as a simple proportion of the slider position - var value = Math.round(deltaX / width * maxValue); - return Math.min(value, maxValue); - } - - /** - * Snaps a value to the nearest step in the steps array. - * - * @param {number} value - The value to snap. - * @param {Array} steps - Array of step values to snap to. - * @return {number} - The nearest step value. - */ - }, { - key: "snapToStep", - value: function snapToStep(value, steps) { - var nearest = steps[0]; - var minDiff = Math.abs(value - nearest); - for (var i = 1; i < steps.length; i++) { - var diff = Math.abs(value - steps[i]); - if (diff < minDiff) { - minDiff = diff; - nearest = steps[i]; - } - } - return nearest; - } - }]); -}(); - - -/***/ }), - -/***/ "./js/src/settings-components/components/tabs-component.js": -/*!*****************************************************************!*\ - !*** ./js/src/settings-components/components/tabs-component.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmTabsComponent) -/* harmony export */ }); -/* harmony import */ var _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../components/class-tabs-navigator */ "./js/src/components/class-tabs-navigator.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } - -/** - * Represents a Tabs Component. - * - * @class - */ -var frmTabsComponent = /*#__PURE__*/function () { - function frmTabsComponent() { - _classCallCheck(this, frmTabsComponent); - this.elements = document.querySelectorAll('.frm-style-tabs-wrapper'); - if (0 < this.elements.length) { - this.init(); - } - } - - /** - * Initializes the Tabs Component. - */ - return _createClass(frmTabsComponent, [{ - key: "init", - value: function init() { - this.elements.forEach(function (element) { - new _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__.frmTabsNavigator(element); - }); - } - - /** - * Initializes the component on tab click. - * - * @param {Element} wrapper - The wrapper element. - */ - }, { - key: "initOnTabClick", - value: function initOnTabClick(wrapper) { - var _this = this; - this.initActiveBackgroundWidth(wrapper); - wrapper.querySelectorAll('.frm-tab-item').forEach(function (tab) { - tab.addEventListener('click', function (event) { - _this.onTabClick(event.target.closest('.frm-tabs-wrapper')); - }); - }); - } - }]); -}(); - - -/***/ }), - -/***/ "./js/src/settings-components/components/toggle-group/index.js": -/*!*********************************************************************!*\ - !*** ./js/src/settings-components/components/toggle-group/index.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ initToggleGroupComponents: () => (/* reexport safe */ _toggle_group_js__WEBPACK_IMPORTED_MODULE_0__.initToggleGroupComponents) -/* harmony export */ }); -/* harmony import */ var _toggle_group_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toggle-group.js */ "./js/src/settings-components/components/toggle-group/toggle-group.js"); - - -/***/ }), - -/***/ "./js/src/settings-components/components/toggle-group/toggle-group.js": -/*!****************************************************************************!*\ - !*** ./js/src/settings-components/components/toggle-group/toggle-group.js ***! - \****************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ initToggleGroupComponents: () => (/* binding */ initToggleGroupComponents) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Group Toggle Component - * - * Handles toggling visibility and enabled state of related form elements - */ - -/** - * Internal dependencies - */ - - - -/** - * Class names for group toggle component - * - * @private - */ -var CLASS_NAMES = { - GROUP_TOGGLE: 'frm-toggle-group', - TOGGLE_BLOCK: 'frm_toggle_block' -}; - -/** - * Data attributes for group toggle component - * - * @private - */ -var DATA_ATTRIBUTES = { - GROUP_NAME: 'data-group-name', - SHOW: 'data-show', - DISABLE: 'data-disable', - ENABLE: 'data-enable' -}; - -/** - * Initialize all group toggle components on the page - * - * @return {void} - */ -function initToggleGroupComponents() { - applyInitialState(); - addEventListeners(); -} - -/** - * Apply the initial state for all toggle buttons on the page - * - * @private - * @return {void} - */ -function applyInitialState() { - var toggleGroups = document.querySelectorAll(".".concat(CLASS_NAMES.GROUP_TOGGLE)); - if (!toggleGroups.length) { - return; - } - toggleGroups.forEach(function (toggleGroup) { - var toggleButton = toggleGroup.querySelector("[".concat(DATA_ATTRIBUTES.GROUP_NAME, "]:checked")); - if (!toggleButton) { - return; - } - applyToggleState(toggleButton, toggleGroup); - }); -} - -/** - * Add event listeners to toggle buttons in a group toggle component - * - * @private - * @return {void} - */ -function addEventListeners() { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.documentOn)('change', ".".concat(CLASS_NAMES.GROUP_TOGGLE, " [").concat(DATA_ATTRIBUTES.GROUP_NAME, "]"), handleToggleClick); -} - -/** - * Handle click events on toggle buttons - * - * @private - * @param {Event} event The click event - * @return {void} - */ -function handleToggleClick(event) { - var toggleButton = event.target; - var toggleGroup = toggleButton.closest(".".concat(CLASS_NAMES.GROUP_TOGGLE)); - if (!toggleGroup) { - return; - } - applyToggleState(toggleButton, toggleGroup); -} - -/** - * Apply toggle state based on toggle button settings - * Shared functionality used by both click handler and initial state - * - * @private - * @param {HTMLElement} toggleButton The toggle button element - * @param {HTMLElement} toggleGroup The toggle group container element - * @return {void} - */ -function applyToggleState(toggleButton, toggleGroup) { - var _toggleGroup$closest; - var fieldId = ((_toggleGroup$closest = toggleGroup.closest(".".concat(core_constants__WEBPACK_IMPORTED_MODULE_1__.SINGLE_SETTINGS_CLASS))) === null || _toggleGroup$closest === void 0 ? void 0 : _toggleGroup$closest.dataset.fid) || toggleGroup.dataset.fid; - var isChecked = toggleButton.checked; - - // Handle show/hide elements - var showSelectors = toggleButton.getAttribute(DATA_ATTRIBUTES.SHOW); - if (showSelectors) { - document.querySelectorAll(normalizeSelector(showSelectors, fieldId)).forEach(function (element) { - return element.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.HIDDEN_CLASS, !isChecked); - }); - } - - // Handle disable elements - var disableSelectors = toggleButton.getAttribute(DATA_ATTRIBUTES.DISABLE); - if (disableSelectors) { - document.querySelectorAll(normalizeSelector(disableSelectors, fieldId)).forEach(function (element) { - element.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.DISABLED_CLASS, isChecked); - element.querySelectorAll('input, select, textarea').forEach(function (formElement) { - return formElement.disabled = isChecked; - }); - element.querySelectorAll('.frm-show-inline-modal[tabindex]').forEach(function (inlineModal) { - return inlineModal.tabIndex = isChecked ? -1 : 0; - }); - }); - } - - // Handle enable elements - var enableSelectors = toggleButton.getAttribute(DATA_ATTRIBUTES.ENABLE); - if (enableSelectors) { - document.querySelectorAll(normalizeSelector(enableSelectors, fieldId)).forEach(function (element) { - return element.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.DISABLED_CLASS, !isChecked); - }); - } - - // Toggle disabled state for all other toggle blocks within the group - var currentToggleBlock = toggleButton.closest(".".concat(CLASS_NAMES.TOGGLE_BLOCK)); - Array.from(toggleGroup.querySelectorAll(".".concat(CLASS_NAMES.TOGGLE_BLOCK))).filter(function (toggleBlock) { - return toggleBlock !== currentToggleBlock; - }).forEach(function (toggleBlock) { - toggleBlock.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_1__.DISABLED_CLASS, isChecked); - - // Disable toggle switch - var toggle = toggleBlock.querySelector('.frm_toggle'); - toggle.tabIndex = isChecked ? -1 : 0; - toggle.setAttribute('aria-disabled', isChecked); - }); -} - -/** - * Normalize a selector by replacing {id} placeholders with the actual field ID - * - * @private - * @param {string} selector The selector string with potential {id} placeholders - * @param {string} fieldId The field ID to replace placeholders with - * @return {string} The normalized selector - */ -function normalizeSelector(selector, fieldId) { - return selector.replace(/{id}/g, fieldId); -} - - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/constants.js": -/*!************************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/constants.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CLASS_NAMES: () => (/* binding */ CLASS_NAMES), -/* harmony export */ KEYS: () => (/* binding */ KEYS), -/* harmony export */ PROXY_INPUT_HEIGHT: () => (/* binding */ PROXY_INPUT_HEIGHT), -/* harmony export */ TOKEN_GAP: () => (/* binding */ TOKEN_GAP) -/* harmony export */ }); -/** - * Constants for token input component - * - * Reusable constants for class names and other static values - */ - -var CLASS_NAMES = { - CONTAINER: 'frm-token-container', - TOKENS_WRAPPER: 'frm-tokens', - TOKEN: 'frm-token', - TOKEN_VALUE: 'frm-token-value', - TOKEN_REMOVE: 'frm-token-remove', - TOKEN_INPUT_FIELD: 'frm-token-input-field', - TOKEN_PROXY_INPUT: 'frm-token-proxy-input', - WITH_RIGHT_ICON: 'frm-with-right-icon' -}; -var KEYS = { - SPACE: ' ', - ENTER: 'Enter', - COMMA: ',', - TAB: 'Tab', - BACKSPACE: 'Backspace' -}; -var PROXY_INPUT_HEIGHT = 36; -var TOKEN_GAP = 4; - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/event-handlers.js": -/*!*****************************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/event-handlers.js ***! - \*****************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); -/* harmony import */ var _token_actions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./token-actions */ "./js/src/settings-components/components/token-input/token-actions.js"); -/* harmony import */ var _proxy_input_style__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./proxy-input-style */ "./js/src/settings-components/components/token-input/proxy-input-style.js"); -/** - * Event handlers - * - * Functions for handling token input events - */ - -/** - * Internal dependencies - */ - - - - -/** - * Add event listeners to token input components - * - * @param {HTMLElement} field The original hidden input field - * @param {HTMLElement} proxyInput The proxy input field for interaction - * @param {HTMLElement} tokensWrapper The wrapper for token display - * @return {void} - */ -function addEventListeners(field, proxyInput, tokensWrapper) { - // The jQuery change event is required to catch programmatic updates, as "Add Layout Classes" modifies the field value via jQuery - jQuery(field).on('change', function () { - return (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.synchronizeTokensDisplay)(field.value, proxyInput, tokensWrapper); - }); - proxyInput.addEventListener('keydown', function (event) { - return onProxyInputKeydown(event, field, proxyInput, tokensWrapper); - }); - proxyInput.addEventListener('blur', function () { - return (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.addToken)(proxyInput.value.trim(), field, proxyInput); - }); - tokensWrapper.addEventListener('click', function (event) { - return handleTokenRemoval(event, field, proxyInput); - }); -} - -/** - * Handle keydown events on the proxy input field - * - * @private - * - * @param {Event} event Keydown event - * @param {HTMLElement} field The original hidden input field - * @param {HTMLElement} proxyInput The proxy input field for interaction - * @param {HTMLElement} tokensWrapper The wrapper for token display - * @return {void} - */ -function onProxyInputKeydown(event, field, proxyInput, tokensWrapper) { - var key = event.key; - var value = proxyInput.value.trim(); - switch (key) { - // Remove the last token when backspace is pressed and input field is empty (no text being typed) - case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.BACKSPACE: - if (!value) { - event.preventDefault(); - var lastToken = tokensWrapper.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN, ":last-child")); - (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.removeToken)(lastToken, field, proxyInput); - } - break; - - // Create a token from current input when delimiter keys are pressed - case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.SPACE: - case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.COMMA: - case _constants__WEBPACK_IMPORTED_MODULE_0__.KEYS.ENTER: - event.preventDefault(); - (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.addToken)(value, field, proxyInput); - break; - } - (0,_proxy_input_style__WEBPACK_IMPORTED_MODULE_2__.adjustProxyInputStyle)(proxyInput, tokensWrapper); -} - -/** - * Handle token removal when clicking the remove button - * - * @private - * - * @param {Event} event Click event - * @param {HTMLElement} field The original hidden input field - * @param {HTMLElement} proxyInput The proxy input field for interaction - * @return {void} - */ -function handleTokenRemoval(event, field, proxyInput) { - var removeButton = event.target.closest(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN_REMOVE)); - if (!removeButton) { - return; - } - var token = removeButton.closest(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN)); - if (!token) { - return; - } - var tokensWrapper = token.parentElement; - (0,_token_actions__WEBPACK_IMPORTED_MODULE_1__.removeToken)(token, field, proxyInput); - (0,_proxy_input_style__WEBPACK_IMPORTED_MODULE_2__.adjustProxyInputStyle)(proxyInput, tokensWrapper); -} - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/index.js": -/*!********************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/index.js ***! - \********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ initTokenInputFields: () => (/* reexport safe */ _token_input__WEBPACK_IMPORTED_MODULE_0__.initTokenInputFields) -/* harmony export */ }); -/* harmony import */ var _token_input__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./token-input */ "./js/src/settings-components/components/token-input/token-input.js"); - - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/proxy-input-style.js": -/*!********************************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/proxy-input-style.js ***! - \********************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ adjustAllProxyInputStyles: () => (/* binding */ adjustAllProxyInputStyles), -/* harmony export */ adjustProxyInputStyle: () => (/* binding */ adjustProxyInputStyle) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); -/** - * Proxy input style - * - * Functions for adjusting proxy input styling - */ - - - -/** - * Adjust styling for all proxy inputs on the current settings - * - * @return {void} - */ -function adjustAllProxyInputStyles() { - document.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.CONTAINER)).forEach(function (container) { - return adjustProxyInputStyle(container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN_PROXY_INPUT)), container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKENS_WRAPPER))); - }); -} - -/** - * Adjust the styling of the proxy input based on tokens wrapper dimensions - * - * @param {HTMLElement} proxyInput The proxy input field - * @param {HTMLElement} tokensWrapper The wrapper for token display - * @return {void} - */ -function adjustProxyInputStyle(proxyInput, tokensWrapper) { - if (!proxyInput || !tokensWrapper) { - return; - } - var tokens = tokensWrapper.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN)); - var hasTokens = tokens.length > 0; - - // Reset all styles if no tokens - if (!hasTokens) { - proxyInput.style.paddingLeft = ''; - proxyInput.style.paddingTop = ''; - proxyInput.style.height = ''; - return; - } - var tokensWrapperHeight = tokensWrapper.offsetHeight; - - // Calculate number of rows based on wrapper height - var numRows = Math.max(1, Math.ceil(tokensWrapperHeight / _constants__WEBPACK_IMPORTED_MODULE_0__.PROXY_INPUT_HEIGHT)); - if (numRows > 1) { - // For multiple rows, calculate the width of tokens in the last row - var lastRowWidth = calculateLastRowWidth(getLastRowTokens(tokens)); - proxyInput.style.height = "".concat(tokensWrapperHeight, "px"); - proxyInput.style.paddingTop = "".concat(tokensWrapperHeight - _constants__WEBPACK_IMPORTED_MODULE_0__.PROXY_INPUT_HEIGHT + _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP, "px"); - proxyInput.style.paddingLeft = lastRowWidth ? "".concat(lastRowWidth + _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP * 2, "px") : ''; - } else { - // For single row, use the full width of tokens - proxyInput.style.height = ''; - proxyInput.style.paddingTop = ''; - proxyInput.style.paddingLeft = "".concat(tokensWrapper.offsetWidth - _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP, "px"); - } -} - -/** - * Identify tokens in the last row of a multi-row token layout - * - * @param {NodeList} tokens All token elements - * @return {Array} Array of tokens in the last row - */ -function getLastRowTokens(tokens) { - if (!tokens.length) { - return []; - } - var tokensArray = Array.from(tokens); - var lastRowY = -1; - tokensArray.forEach(function (token) { - var tokenRect = token.getBoundingClientRect(); - var tokenBottom = tokenRect.bottom; - if (tokenBottom > lastRowY) { - lastRowY = tokenBottom; - } - }); - var threshold = _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP / 2; - return tokensArray.filter(function (token) { - var tokenRect = token.getBoundingClientRect(); - return Math.abs(tokenRect.bottom - lastRowY) <= threshold; - }); -} - -/** - * Calculate the total width of tokens in the last row - * - * @param {Array} lastRowTokens Array of token elements in the last row - * @return {number} Total width of tokens in the last row - */ -function calculateLastRowWidth(lastRowTokens) { - if (!lastRowTokens.length) { - return 0; - } - var totalWidth = 0; - lastRowTokens.forEach(function (token) { - totalWidth += token.offsetWidth; - }); - totalWidth += (lastRowTokens.length - 1) * _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP; - return totalWidth + _constants__WEBPACK_IMPORTED_MODULE_0__.TOKEN_GAP; -} - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/token-actions.js": -/*!****************************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/token-actions.js ***! - \****************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToken: () => (/* binding */ addToken), -/* harmony export */ clearProxyInput: () => (/* binding */ clearProxyInput), -/* harmony export */ parseTokens: () => (/* binding */ parseTokens), -/* harmony export */ removeToken: () => (/* binding */ removeToken), -/* harmony export */ synchronizeTokensDisplay: () => (/* binding */ synchronizeTokensDisplay), -/* harmony export */ updateFieldValue: () => (/* binding */ updateFieldValue) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); -/* harmony import */ var _proxy_input_style__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./proxy-input-style */ "./js/src/settings-components/components/token-input/proxy-input-style.js"); -/* harmony import */ var _token_elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./token-elements */ "./js/src/settings-components/components/token-input/token-elements.js"); -/** - * Token actions - * - * Core functions for token operations and management - */ - -/** - * Internal dependencies - */ - - - - -/** - * Synchronize token display with the field value - * - * @param {string} value The field value - * @param {HTMLElement} proxyInput The proxy input field - * @param {HTMLElement} tokensWrapper Wrapper element for tokens - * @return {void} - */ -function synchronizeTokensDisplay(value, proxyInput, tokensWrapper) { - if (!value || !tokensWrapper || !proxyInput) { - return; - } - - // Clear existing tokens display and render new tokens - tokensWrapper.innerHTML = ''; - parseTokens(value).forEach(function (token) { - return (0,_token_elements__WEBPACK_IMPORTED_MODULE_2__.createTokenElement)(token, tokensWrapper); - }); - (0,_proxy_input_style__WEBPACK_IMPORTED_MODULE_1__.adjustProxyInputStyle)(proxyInput, tokensWrapper); - proxyInput.focus(); -} - -/** - * Add a new token to the field - * - * @param {string} tokenValue The token value to add - * @param {HTMLElement} field The original field - * @param {HTMLElement} proxyInput The proxy input - * @return {boolean} Whether a token was added - */ -function addToken(tokenValue, field, proxyInput) { - if (!tokenValue || !field || !proxyInput) { - return false; - } - - // Get current tokens from field value - var tokens = parseTokens(field.value); - - // Skip duplicate tokens - if (tokens.includes(tokenValue)) { - clearProxyInput(proxyInput); - return false; - } - - // Add new token - tokens.push(tokenValue); - updateFieldValue(field, tokens); - clearProxyInput(proxyInput); - return true; -} - -/** - * Remove a specific token from the field - * - * @param {HTMLElement} token The token element to remove - * @param {HTMLElement} field The original field - * @param {HTMLElement} proxyInput The proxy input - * @return {void} - */ -function removeToken(token, field, proxyInput) { - if (!token || !field || !proxyInput) { - return; - } - var value = token.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_0__.CLASS_NAMES.TOKEN_VALUE)).textContent; - - // Filter out the token to remove - var tokens = parseTokens(field.value).filter(function (tokenValue) { - return tokenValue !== value; - }); - updateFieldValue(field, tokens); - - // Remove the token element from DOM - token.remove(); - proxyInput.focus(); -} - -/** - * Parse string input into an array of tokens - * - * @param {string} value Space-separated string - * @return {string[]} Array of tokens - */ -function parseTokens() { - var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; - value = value.trim(); - if (!value) { - return []; - } - return value.split(/\s+/).filter(Boolean); -} - -/** - * Update field value with tokens and trigger change event - * - * @param {HTMLElement} field The field to update - * @param {string[]} tokens Array of token values - * @return {void} - */ -function updateFieldValue(field) { - var tokens = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; - if (!field) { - return; - } - field.value = tokens.join(' '); - jQuery(field).trigger('change'); -} - -/** - * Clear proxy input and maintain focus - * - * @param {HTMLElement} proxyInput The proxy input field - * @return {void} - */ -function clearProxyInput(proxyInput) { - if (!proxyInput) { - return; - } - proxyInput.value = ''; - proxyInput.focus(); -} - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/token-elements.js": -/*!*****************************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/token-elements.js ***! - \*****************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createTokenContainerElement: () => (/* binding */ createTokenContainerElement), -/* harmony export */ createTokenElement: () => (/* binding */ createTokenElement) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); -/** - * Token elements - * - * Functions for creating token DOM elements - */ - -/** - * Internal dependencies - */ - - -var _window$frmDom = window.frmDom, - span = _window$frmDom.span, - svg = _window$frmDom.svg, - tag = _window$frmDom.tag; - -/** - * Create token container and input elements - * - * @param {HTMLElement} field Input field for tokenization - * @return {HTMLElement|null} The container element or null if already initialized - */ -function createTokenContainerElement(field) { - // Get the main container (.frm-with-right-icon) to work with Formidable's modal system - var container = field.closest(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.WITH_RIGHT_ICON)); - if (container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKENS_WRAPPER))) { - return null; - } - container.classList.add(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.CONTAINER); - var tokensWrapper = span({ - className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKENS_WRAPPER - }); - container.insertBefore(tokensWrapper, container.firstChild); - var proxyInput = tag('input', { - className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_PROXY_INPUT, - id: "".concat(field.id, "-proxy-input") - }); - proxyInput.type = 'text'; - - // Inserting proxyInput after the field is important to maintain compatibility with Formidable's modal system - field.parentNode.insertBefore(proxyInput, field.nextSibling); - field.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); - return container; -} - -/** - * Create a single token element - * - * @param {string} value Token value - * @param {HTMLElement} tokensWrapper Wrapper element for tokens - * @return {void} - */ -function createTokenElement(value, tokensWrapper) { - var tokenElement = span({ - className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN, - children: [span({ - text: value, - className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_VALUE - }), span({ - className: _constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_REMOVE, - child: svg({ - href: '#frm_close_icon' - }) - })] - }); - tokensWrapper.append(tokenElement); -} - -/***/ }), - -/***/ "./js/src/settings-components/components/token-input/token-input.js": -/*!**************************************************************************!*\ - !*** ./js/src/settings-components/components/token-input/token-input.js ***! - \**************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ initTokenInputFields: () => (/* binding */ initTokenInputFields) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./js/src/settings-components/components/token-input/constants.js"); -/* harmony import */ var _token_elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./token-elements */ "./js/src/settings-components/components/token-input/token-elements.js"); -/* harmony import */ var _token_actions__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./token-actions */ "./js/src/settings-components/components/token-input/token-actions.js"); -/* harmony import */ var _proxy_input_style__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./proxy-input-style */ "./js/src/settings-components/components/token-input/proxy-input-style.js"); -/* harmony import */ var _event_handlers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./event-handlers */ "./js/src/settings-components/components/token-input/event-handlers.js"); -/** - * Token Input Component - * - * Transforms space-separated values in a text input into selectable tokens - */ - -/** - * Internal dependencies - */ - - - - - - - -/** - * Initialize all token input fields on the page - * - * @return {void} - */ -function initTokenInputFields() { - findAndInitializeTokenFields(); - - /** - * Initialize for newly added fields - * - * @param {Event} event The frm_added_field event. - * @param {HTMLElement} event.frmField The added field object being destructured from the event. - */ - document.addEventListener('frm_added_field', function (_ref) { - var frmField = _ref.frmField; - return findAndInitializeTokenFields(frmField.dataset.fid); - }); - - /** - * Initialize for newly added fields via AJAX - * - * @param {Event} event The frm_ajax_loaded_field event. - * @param {HTMLElement} event.frmFields The added field objects being destructured from the event. - */ - document.addEventListener('frm_ajax_loaded_field', function (_ref2) { - var frmFields = _ref2.frmFields; - return frmFields.forEach(function (field) { - return findAndInitializeTokenFields(field.id); - }); - }); - - // Adjust styling for all token inputs when field settings are shown - wp.hooks.addAction(core_constants__WEBPACK_IMPORTED_MODULE_0__.HOOKS.SHOW_FIELD_SETTINGS, 'formidable-token-input', _proxy_input_style__WEBPACK_IMPORTED_MODULE_4__.adjustAllProxyInputStyles); -} - -/** - * Find all token input fields and initialize them - * - * @private - * @param {string|number} fieldId The ID of the field to initialize - * @return {void} - */ -function findAndInitializeTokenFields(fieldId) { - var container = fieldId ? document.getElementById("frm-single-settings-".concat(fieldId)) : document.body; - var tokenInputFields = container.querySelectorAll(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_INPUT_FIELD)); - if (!tokenInputFields.length) { - return; - } - - // Track processed fields to prevent duplicate initialization - var processedFields = new Set(); - tokenInputFields.forEach(function (field) { - if (!processedFields.has(field.id)) { - setupTokenInput(field); - processedFields.add(field.id); - } - }); -} - -/** - * Set up a token input field with token container - * - * @private - * - * @param {HTMLElement} field Input field for tokenization - */ -function setupTokenInput(field) { - var container = (0,_token_elements__WEBPACK_IMPORTED_MODULE_2__.createTokenContainerElement)(field); - if (!container) { - return; - } - var proxyInput = container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKEN_PROXY_INPUT)); - var tokensWrapper = container.querySelector(".".concat(_constants__WEBPACK_IMPORTED_MODULE_1__.CLASS_NAMES.TOKENS_WRAPPER)); - (0,_token_actions__WEBPACK_IMPORTED_MODULE_3__.synchronizeTokensDisplay)(field.value, proxyInput, tokensWrapper); - (0,_event_handlers__WEBPACK_IMPORTED_MODULE_5__.addEventListeners)(field, proxyInput, tokensWrapper); -} - - -/***/ }), - -/***/ "./js/src/settings-components/components/unit-input.js": -/*!*************************************************************!*\ - !*** ./js/src/settings-components/components/unit-input.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ setupUnitInputHandlers: () => (/* binding */ setupUnitInputHandlers) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Setup unit input handlers - * - * @return {void} - */ -function setupUnitInputHandlers() { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.documentOn)('change', '.frm-unit-input .frm-unit-input-control', onUnitInputChange); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.documentOn)('change', '.frm-unit-input select', onUnitInputChange); -} - -/** - * Handle the change event for the unit input - * - * @private - * @param {Event} event The event object. - * @return {void} - */ -function onUnitInputChange(event) { - var unitInput = event.target.closest('.frm-unit-input'); - var control = unitInput.querySelector('.frm-unit-input-control'); - var unit = unitInput.querySelector('select').value; - - // Update input type when unit changes - if (event.target.matches('select')) { - control.type = '' === unit ? 'text' : 'number'; - } - - // Update the actual field value - var inputValue = control.value.trim(); - unitInput.querySelector('input[type="hidden"]').value = '' !== inputValue ? inputValue + unit : ''; -} - -/***/ }), - -/***/ "./js/src/settings-components/events/add-fields-button-handler.js": -/*!************************************************************************!*\ - !*** ./js/src/settings-components/events/add-fields-button-handler.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Redirects to "Add Fields" tab when the "Add Fields" button is clicked. - * - * When users view the Field Options tab with no fields, they see an "Add Fields" button. - * Clicking this button should take them to the "Add Fields" tab for field selection. - */ - -/** - * Initializes the Add Fields button click handler. - */ -var initAddFieldsButtonHandler = function initAddFieldsButtonHandler() { - var _document$getElementB; - (_document$getElementB = document.getElementById('frm-form-add-field')) === null || _document$getElementB === void 0 || _document$getElementB.addEventListener('click', function (event) { - var _document$querySelect; - event.preventDefault(); - (_document$querySelect = document.querySelector('.frm-settings-panel .frm-tabs-navs ul > li:first-child')) === null || _document$querySelect === void 0 || _document$querySelect.click(); - }); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initAddFieldsButtonHandler); - -/***/ }), - -/***/ "./js/src/settings-components/events/index.js": -/*!****************************************************!*\ - !*** ./js/src/settings-components/events/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ initAddFieldsButtonHandler: () => (/* reexport safe */ _add_fields_button_handler__WEBPACK_IMPORTED_MODULE_0__["default"]) -/* harmony export */ }); -/* harmony import */ var _add_fields_button_handler__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./add-fields-button-handler */ "./js/src/settings-components/events/add-fields-button-handler.js"); - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. -(() => { -/*!*********************************************!*\ - !*** ./js/src/settings-components/index.js ***! - \*********************************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./events */ "./js/src/settings-components/events/index.js"); -/* harmony import */ var _components__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components */ "./js/src/settings-components/components/index.js"); -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - - -(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__["default"])(function () { - new _components__WEBPACK_IMPORTED_MODULE_1__.frmRadioComponent(); - new _components__WEBPACK_IMPORTED_MODULE_1__.frmSliderComponent(); - new _components__WEBPACK_IMPORTED_MODULE_1__.frmTabsComponent(); - (0,_events__WEBPACK_IMPORTED_MODULE_0__.initAddFieldsButtonHandler)(); - (0,_components__WEBPACK_IMPORTED_MODULE_1__.initTokenInputFields)(); - (0,_components__WEBPACK_IMPORTED_MODULE_1__.initToggleGroupComponents)(); - (0,_components__WEBPACK_IMPORTED_MODULE_1__.setupUnitInputHandlers)(); -}); -})(); - -/******/ })() -; -//# sourceMappingURL=formidable-settings-components.js.map \ No newline at end of file +(()=>{"use strict";var e=window.frmGlobal,t=(e.url,e.nonce,"frm_hidden"),n="frm_disabled",r=(Promise.resolve(),frmDom),i=(r.div,r.span,r.tag,r.a,r.img,r.svg,frmDom.modal),o=(i.maybeCreateModal,i.footerButton,frmDom.util),a=(o.onClickPreventDefault,o.documentOn);frmDom.ajax.doJsonPost;var l=(new URL(window.location.href).searchParams,function(e){return null==e?void 0:e.classList.remove(t)});function s(e){return s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},s(e)}function c(e,t){for(var n=0;n0&&e.onRadioChange(t)})}))}},{key:"initVisibilityObserver",value:function(e){var t=this;this.observers.has(e)&&this.observers.get(e).disconnect();var n=new MutationObserver(function(){if(function(e){return"none"!==window.getComputedStyle(e).getPropertyValue("display")}(e)){var n=e.querySelector('input[type="radio"]:checked');n&&t.onRadioChange(n)}});this.observers.set(e,n),n.observe(e,{attributes:!0,attributeFilter:["class","style"]});for(var r=e.parentElement,i=0;i<7&&r;i++)n.observe(r,{attributes:!0,attributeFilter:["class","style"]}),r=r.parentElement}},{key:"cleanupObservers",value:function(){this.observers.forEach(function(e){e.disconnect()}),this.observers.clear()}},{key:"hideExtraElements",value:function(){var e=document.querySelectorAll(".frm-element-is-visible");0!==e.length&&e.forEach(function(e){e.classList.remove("frm-element-is-visible"),e.classList.add(t),function(e){null==e||e.classList.add(t)}(e)})}},{key:"moveTracker",value:function(e,t){var n=e.offsetLeft,r=e.offsetWidth,i=t.querySelector(".frm-radio-active-tracker");i.style.left=0,i.style.width="".concat(r,"px"),i.style.transform="translateX(".concat(n,"px)")}}])&&c(e.prototype,n),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,n}();function f(e){return f="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},f(e)}function m(e,t){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:[],r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.loadedByWebComponent=n.length>0,this.sliderElements=n.length>0?n:document.querySelectorAll(".frm-slider-component"),this.settings=r,0!==this.sliderElements.length){this.sliderBulletWidth=16,this.sliderMarginRight=5,this.eventsChange=[];var i=frmDom.util.debounce;this.valueChangeDebouncer=i(function(e){return t.triggerValueChange(e)},25),this.initOptions(),this.init()}}return n=e,r=[{key:"initOptions",value:function(){var e=this;this.options=[],this.sliderElements.forEach(function(t,n){var r=t.classList.contains("frm-has-multiple-values")?t.closest(".frm-style-component"):t,i=e.settings.steps||(t.dataset.steps?JSON.parse(t.dataset.steps):null);e.options.push({dragging:!1,startX:0,translateX:0,maxValue:parseInt(t.dataset.maxValue,10),element:t,index:n,value:0,steps:i,dependentUpdater:r.classList.contains("frm-style-dependent-updater-component")?new h(r):null})})}},{key:"init",value:function(){this.initDraggable(),this.loadedByWebComponent?this.initSlidersPositionInsideWebComponent():this.initSlidersPosition()}},{key:"initDraggable",value:function(){var t=this;this.sliderElements.forEach(function(n,r){t.eventsChange[r]=new Event("change",{bubbles:!0,cancelable:!0});var i=n.querySelector(".frm-slider-bullet"),o=n.querySelector('.frm-slider-value input[type="text"]');o.addEventListener("change",function(e){var i=n.querySelector("select").value;t.getMaxValue(i,r)1&&void 0!==arguments[1]?arguments[1]:null;if(!t.classList.contains("frm-disabled")){var r=null!==n?n:this.getSliderIndex(t),i=t.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth,o=parseInt(t.querySelector('.frm-slider-value input[type="text"]').value,10),a=t.querySelector("select").value,l=this.options[r].steps,s=Math.ceil(o/this.options[r].maxValue*i);"%"===a?s=Math.round(i*o/100):l&&l.length>0&&(s=e.calculateDeltaXFromSteps(o,l,i)),t.querySelector(".frm-slider-active-track").style.width="".concat(s,"px"),this.options[r].translateX=s,this.options[r].value=o+a}}},{key:"initChildSlidersWidth",value:function(e,t,n,r){var i=this;(e.classList.contains("frm-has-independent-fields")||e.classList.contains("frm-has-multiple-values"))&&(e.classList.contains("frm-has-independent-fields")?e.querySelectorAll(".frm-independent-slider-field"):this.getSliderGroupItems(e)).forEach(function(e,o){e.querySelector(".frm-slider-active-track").style.width="".concat(t,"px"),i.options[n+o+1].translateX=t,i.options[n+o+1].value=r})}},{key:"getSliderIndex",value:function(e){return this.options.filter(function(t){return t.element===e})[0].index}},{key:"moveTracker",value:function(t,n){if(this.options[n].dragging){var r=t.clientX-this.options[n].startX,i=this.sliderElements[n],o=i.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth;r=Math.max(r,0),r=Math.min(r,o);var a=i.querySelector("select").value,l=e.calculateValue(o,r,this.getMaxValue(a,n),this.options[n].steps);i.querySelector('.frm-slider-value input[type="text"]').value=l,i.querySelector(".frm-slider-bullet .frm-slider-value-label").innerText=l,i.querySelector(".frm-slider-active-track").style.width="".concat(r,"px"),this.initChildSlidersWidth(i,r,n,l+a),this.options[n].translateX=r,this.options[n].value=l+a,this.options[n].fullValue=this.updateValue(i,this.options[n].value),this.valueChangeDebouncer(n)}}},{key:"getMaxValue",value:function(e,t){return"%"===e?100:this.options[t].maxValue}},{key:"enableDragging",value:function(e,t){e.target.classList.add("frm-dragging"),this.options[t].dragging=!0,this.options[t].startX=e.clientX-this.options[t].translateX}},{key:"disableDragging",value:function(e){!1!==this.options[e].dragging&&(this.sliderElements[e].querySelector(".frm-slider-bullet").classList.remove("frm-dragging"),this.options[e].dragging=!1,this.triggerValueChange(e))}},{key:"triggerValueChange",value:function(e){var t=this;if(null===this.options[e].dependentUpdater){var n=this.sliderElements[e].classList.contains("frm-has-multiple-values")?this.sliderElements[e].closest(".frm-style-component").querySelector('input[type="hidden"]'):this.sliderElements[e].querySelectorAll('.frm-slider-value input[type="hidden"]');n instanceof NodeList?n.forEach(function(n){n.dispatchEvent(t.eventsChange[e])}):n.dispatchEvent(this.eventsChange[e])}else this.options[e].dependentUpdater.updateAllDependentElements(this.options[e].fullValue)}},{key:"updateValue",value:function(e,t){var n=this;if(e.classList.contains("frm-base-font-size")){var r=document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]');r&&(r.value="true")}if(e.classList.contains("frm-has-multiple-values")){var i=e.closest(".frm-style-component").querySelector('input[type="hidden"]'),o=i.value.split(" "),a=e.dataset.type;switch(o[2]||(o[2]="0px"),o[3]||(o[3]="0px"),a){case"vertical":o[0]=t,o[2]=t;break;case"horizontal":o[1]=t,o[3]=t;break;case"top":o[0]=t;break;case"bottom":o[2]=t;break;case"left":o[3]=t;break;case"right":o[1]=t}var l=o.join(" ");return i.value=l,this.getSliderGroupItems(e).forEach(function(e){var r=n.getUnitMeasureFromValue(t);e.querySelector('.frm-slider-value input[type="text"]').value=parseInt(t,10),e.querySelector("select").value=r}),l}if(e.classList.contains("frm-has-independent-fields")){var s=e.querySelectorAll('.frm-slider-value input[type="hidden"]'),c=e.querySelectorAll('.frm-slider-value input[type="text"]');return s.forEach(function(e,n){e.value=t,c[n+1].value=parseInt(t,10)}),t}return e.querySelector('.frm-slider-value input[type="hidden"]').value=t,t}},{key:"getUnitMeasureFromValue",value:function(e){return["%","px","em"].find(function(t){return e.includes(t)})||""}}],i=[{key:"maybeDisableUnitDropdown",value:function(e){var t=e.querySelector("select");t&&1>=Array.from(t.options).filter(function(e){return""!==e.value}).length&&(t.classList.add("frm-single-unit"),t.addEventListener("mousedown",function(e){return e.preventDefault()}))}},{key:"calculateDeltaXFromSteps",value:function(t,n,r){var i=n.indexOf(t);if(-1===i){var o=e.snapToStep(t,n),a=n.indexOf(o);return Math.round(a/(n.length-1)*r)}return Math.round(i/(n.length-1)*r)}},{key:"calculateValue",value:function(e,t,n){var r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null;if(r&&r.length>0){var i=t/e,o=Math.round(i*(r.length-1));return r[Math.max(0,Math.min(o,r.length-1))]}var a=Math.round(t/e*n);return Math.min(a,n)}},{key:"snapToStep",value:function(e,t){for(var n=t[0],r=Math.abs(e-n),i=1;i li"),this.slideTrackLine=this.wrapper.querySelector(".frm-tabs-active-underline"),this.slideTrack=this.wrapper.querySelector(".frm-tabs-slide-track"),this.slides=this.wrapper.querySelectorAll(".frm-tabs-slide-track > div"),this.isRTL="rtl"===document.documentElement.dir||"rtl"===document.body.dir,this.resizeObserver=null,this.init()))},(t=[{key:"init",value:function(){var e=this;null!==this.wrapper&&this.navs.length&&null!==this.slideTrackLine&&null!==this.slideTrack&&this.slides.length&&(this.navs.forEach(function(t,n){t.addEventListener("click",function(t){return e.onNavClick(t,n)}),t.classList.contains("frm-active")&&e.initSlideTrackUnderline(t)}),this.slideTrackLine.style.display="block",this.setupScrollbarObserver(),window.addEventListener("beforeunload",this.cleanupObservers))}},{key:"onNavClick",value:function(e,t){var n=e.currentTarget;e.preventDefault(),this.removeActiveClassnameFromNavs(),n.classList.add("frm-active"),this.initSlideTrackUnderline(n),this.changeSlide(t);var r,i,o=n.querySelector("a");o&&"frm_insert_fields_tab"===o.id&&!o.closest("#frm_adv_info")&&(null===(r=window.frmAdminBuild)||void 0===r||null===(i=r.clearSettingsBox)||void 0===i||i.call(r))}},{key:"initSlideTrackUnderline",value:function(e){var t=void 0!==e?e:this.navs.filter(function(e){return e.classList.contains("frm-active")});this.positionUnderlineIndicator(t)}},{key:"setupScrollbarObserver",value:function(){var e=this,t=document.querySelector(".frm-scrollbar-wrapper, .styling_settings")||document.body;t&&"ResizeObserver"in window&&(this.resizeObserver=new ResizeObserver(function(){var t=e.wrapper.querySelector(".frm-tabs-navs ul > li.frm-active");t&&e.positionUnderlineIndicator(t)}),this.resizeObserver.observe(t))}},{key:"cleanupObservers",value:function(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null)}},{key:"positionUnderlineIndicator",value:function(e){var t=this;requestAnimationFrame(function(){var n=t.isRTL?-(e.parentElement.offsetWidth-e.offsetLeft-e.offsetWidth):e.offsetLeft;t.slideTrackLine.style.transform="translateX(".concat(n,"px)"),t.slideTrackLine.style.width="".concat(e.clientWidth,"px")})}},{key:"changeSlide",value:function(e){this.removeActiveClassnameFromSlides();var t=0==e?"0px":"calc( ( ".concat(100*e,"% + ").concat(parseInt(this.flexboxSlidesGap,10)*e,"px ) * ").concat(this.isRTL?1:-1," )");"0px"!==t?this.slideTrack.style.transform="translateX(".concat(t,")"):this.slideTrack.style.removeProperty("transform"),e in this.slides&&this.slides[e].classList.add("frm-active")}},{key:"removeActiveClassnameFromSlides",value:function(){this.slides.forEach(function(e){return e.classList.remove("frm-active")})}},{key:"removeActiveClassnameFromNavs",value:function(){this.navs.forEach(function(e){return e.classList.remove("frm-active")})}}])&&k(e.prototype,t),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,t}();function q(e){return q="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},q(e)}function L(e,t){for(var n=0;n0))return e.style.paddingLeft="",e.style.paddingTop="",void(e.style.height="");var r=t.offsetHeight;if(Math.max(1,Math.ceil(r/36))>1){var i=function(e){if(!e.length)return 0;var t=0;return e.forEach(function(e){t+=e.offsetWidth}),(t+=4*(e.length-1))+4}(function(e){if(!e.length)return[];var t=Array.from(e),n=-1;t.forEach(function(e){var t=e.getBoundingClientRect().bottom;t>n&&(n=t)});return t.filter(function(e){var t=e.getBoundingClientRect();return Math.abs(t.bottom-n)<=2})}(n));e.style.height="".concat(r,"px"),e.style.paddingTop="".concat(r-36+4,"px"),e.style.paddingLeft=i?"".concat(i+8,"px"):""}else e.style.height="",e.style.paddingTop="",e.style.paddingLeft="".concat(t.offsetWidth-4,"px")}}function F(e,t,n){e&&n&&t&&(n.innerHTML="",z(e).forEach(function(e){return function(e,t){var n=D({className:O,children:[D({text:e,className:_}),D({className:P,child:I({href:"#frm_close_icon"})})]});t.append(n)}(e,n)}),R(t,n),t.focus())}function B(e,t,n){if(!e||!t||!n)return!1;var r=z(t.value);return r.includes(e)?(N(n),!1):(r.push(e),X(t,r),N(n),!0)}function U(e,t,n){if(e&&t&&n){var r=e.querySelector(".".concat(_)).textContent;X(t,z(t.value).filter(function(e){return e!==r})),e.remove(),n.focus()}}function z(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"";return(e=e.trim())?e.split(/\s+/).filter(Boolean):[]}function X(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];e&&(e.value=t.join(" "),jQuery(e).trigger("change"))}function N(e){e&&(e.value="",e.focus())}function G(e){var n=(e?document.getElementById("frm-single-settings-".concat(e)):document.body).querySelectorAll(".".concat("frm-token-input-field"));if(n.length){var r=new Set;n.forEach(function(e){r.has(e.id)||(function(e){var n=function(e){var n=e.closest(".".concat("frm-with-right-icon"));if(n.querySelector(".".concat(T)))return null;n.classList.add(A);var r=D({className:T});n.insertBefore(r,n.firstChild);var i=j("input",{className:V,id:"".concat(e.id,"-proxy-input")});return i.type="text",e.parentNode.insertBefore(i,e.nextSibling),e.classList.add(t),n}(e);if(n){var r=n.querySelector(".".concat(V)),i=n.querySelector(".".concat(T));F(e.value,r,i),function(e,t,n){jQuery(e).on("change",function(){return F(e.value,t,n)}),t.addEventListener("keydown",function(r){return function(e,t,n,r){var i=e.key,o=n.value.trim();switch(i){case"Backspace":o||(e.preventDefault(),U(r.querySelector(".".concat(O,":last-child")),t,n));break;case" ":case",":case"Enter":e.preventDefault(),B(o,t,n)}R(n,r)}(r,e,t,n)}),t.addEventListener("blur",function(){return B(t.value.trim(),e,t)}),n.addEventListener("click",function(n){return function(e,t,n){var r=e.target.closest(".".concat(P));if(r){var i=r.closest(".".concat(O));if(i){var o=i.parentElement;U(i,t,n),R(n,o)}}}(n,e,t)})}(e,r,i)}}(e),r.add(e.id))})}}var J,H="frm-toggle-group",Q="frm_toggle_block",K="data-group-name";function Y(e){var t=e.target,n=t.closest(".".concat(H));n&&Z(t,n)}function Z(e,r){var i,o=(null===(i=r.closest(".".concat("frm-single-settings")))||void 0===i?void 0:i.dataset.fid)||r.dataset.fid,a=e.checked,l=e.getAttribute("data-show");l&&document.querySelectorAll($(l,o)).forEach(function(e){return e.classList.toggle(t,!a)});var s=e.getAttribute("data-disable");s&&document.querySelectorAll($(s,o)).forEach(function(e){e.classList.toggle(n,a),e.querySelectorAll("input, select, textarea").forEach(function(e){return e.disabled=a}),e.querySelectorAll(".frm-show-inline-modal[tabindex]").forEach(function(e){return e.tabIndex=a?-1:0})});var c=e.getAttribute("data-enable");c&&document.querySelectorAll($(c,o)).forEach(function(e){return e.classList.toggle(n,!a)});var u=e.closest(".".concat(Q));Array.from(r.querySelectorAll(".".concat(Q))).filter(function(e){return e!==u}).forEach(function(e){e.classList.toggle(n,a);var t=e.querySelector(".frm_toggle");t.tabIndex=a?-1:0,t.setAttribute("aria-disabled",a)})}function $(e,t){return e.replace(/{id}/g,t)}function ee(e){var t=e.target.closest(".frm-unit-input"),n=t.querySelector(".frm-unit-input-control"),r=t.querySelector("select").value;e.target.matches("select")&&(n.type=""===r?"text":"number");var i=n.value.trim();t.querySelector('input[type="hidden"]').value=""!==i?i+r:""}J=function(){var e,t;new d,new b,new C,null===(t=document.getElementById("frm-form-add-field"))||void 0===t||t.addEventListener("click",function(e){var t;e.preventDefault(),null===(t=document.querySelector(".frm-settings-panel .frm-tabs-navs ul > li:first-child"))||void 0===t||t.click()}),G(),document.addEventListener("frm_added_field",function(e){return G(e.frmField.dataset.fid)}),document.addEventListener("frm_ajax_loaded_field",function(e){return e.frmFields.forEach(function(e){return G(e.id)})}),wp.hooks.addAction("frmShowedFieldSettings","formidable-token-input",M),(e=document.querySelectorAll(".".concat(H))).length&&e.forEach(function(e){var t=e.querySelector("[".concat(K,"]:checked"));t&&Z(t,e)}),a("change",".".concat(H," [").concat(K,"]"),Y),a("change",".frm-unit-input .frm-unit-input-control",ee),a("change",".frm-unit-input select",ee)},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",J):J())})(); \ No newline at end of file diff --git a/js/formidable-web-components.js b/js/formidable-web-components.js index d0e7d5f6d7..34a3ccc9b7 100644 --- a/js/formidable-web-components.js +++ b/js/formidable-web-components.js @@ -1,5835 +1 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/admin/components/dependent-updater-component.js": -/*!****************************************************************!*\ - !*** ./js/src/admin/components/dependent-updater-component.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmStyleDependentUpdaterComponent) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * This component updates the dependent style element's values and triggers a custom change event for each style element, initiating the style preview. - * The names of the elements that will be updated are specified using the "will-change" attribute. - * It is primarily used in components from Style/Quick Settings. - * For instance, when the "FrmPrimaryColorStyleComponent" is changed, it simultaneously updates various style elements like border color, text color, and button backgrounds. - */ -var frmStyleDependentUpdaterComponent = /*#__PURE__*/function () { - /** - * Creates an instance of frmStyleDependentUpdaterComponent. - * - * @param {HTMLElement} component - The component element. - */ - function frmStyleDependentUpdaterComponent(component) { - _classCallCheck(this, frmStyleDependentUpdaterComponent); - this.component = component; - try { - var willChangeData = JSON.parse(this.component.dataset.willChange); - this.data = { - propagateInputs: this.initPropagationList(willChangeData), - changeEvent: new Event('change', { - bubbles: true - }) - }; - } catch (error) { - console.error('Error parsing JSON data from "will-change" attribute.', error); - } - } - - /** - * Initializes the list of inputs to propagate changes to. - * The selection is made by provided input's names list in "will-change" attribute. - * - * @param {string[]} inputNames - The names of the inputs to propagate changes to. - * @return {HTMLElement[]} - The list of inputs to propagate changes to. - */ - return _createClass(frmStyleDependentUpdaterComponent, [{ - key: "initPropagationList", - value: function initPropagationList(inputNames) { - var list = []; - inputNames.forEach(function (name) { - var input = document.querySelector("input[name=\"".concat(name, "\"]")); - if (input) { - list.push(input); - } - }); - return list; - } - - /** - * Updates all dependent elements with the given value. - * - * @param {string} value - The value to update the dependent elements with. - */ - }, { - key: "updateAllDependentElements", - value: function updateAllDependentElements(value) { - this.data.propagateInputs.forEach(function (input) { - input.value = value; - }); - this.data.propagateInputs[0].dispatchEvent(this.data.changeEvent); - } - }]); -}(); - - -/***/ }), - -/***/ "./js/src/components/class-tabs-navigator.js": -/*!***************************************************!*\ - !*** ./js/src/components/class-tabs-navigator.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmTabsNavigator: () => (/* binding */ frmTabsNavigator) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmTabsNavigator = /*#__PURE__*/function () { - function frmTabsNavigator(wrapper) { - _classCallCheck(this, frmTabsNavigator); - if (wrapper === undefined) { - return; - } - this.wrapper = wrapper instanceof Element ? wrapper : document.querySelector(wrapper); - if (null === this.wrapper) { - return; - } - this.flexboxSlidesGap = '16px'; - this.navs = this.wrapper.querySelectorAll('.frm-tabs-navs ul > li'); - this.slideTrackLine = this.wrapper.querySelector('.frm-tabs-active-underline'); - this.slideTrack = this.wrapper.querySelector('.frm-tabs-slide-track'); - this.slides = this.wrapper.querySelectorAll('.frm-tabs-slide-track > div'); - this.isRTL = document.documentElement.dir === 'rtl' || document.body.dir === 'rtl'; - this.resizeObserver = null; - this.init(); - } - return _createClass(frmTabsNavigator, [{ - key: "init", - value: function init() { - var _this = this; - if (null === this.wrapper || !this.navs.length || null === this.slideTrackLine || null === this.slideTrack || !this.slides.length) { - return; - } - this.navs.forEach(function (nav, index) { - nav.addEventListener('click', function (event) { - return _this.onNavClick(event, index); - }); - if (nav.classList.contains('frm-active')) { - _this.initSlideTrackUnderline(nav); - } - }); - this.slideTrackLine.style.display = 'block'; - this.setupScrollbarObserver(); - // Cleanup observers when page unloads to prevent memory leaks - window.addEventListener('beforeunload', this.cleanupObservers); - } - }, { - key: "onNavClick", - value: function onNavClick(event, index) { - var navItem = event.currentTarget; - event.preventDefault(); - this.removeActiveClassnameFromNavs(); - navItem.classList.add('frm-active'); - this.initSlideTrackUnderline(navItem); - this.changeSlide(index); - - // Handle special case for frm_insert_fields_tab - var navLink = navItem.querySelector('a'); - if (navLink && navLink.id === 'frm_insert_fields_tab' && !navLink.closest('#frm_adv_info')) { - var _window$frmAdminBuild, _window$frmAdminBuild2; - (_window$frmAdminBuild = window.frmAdminBuild) === null || _window$frmAdminBuild === void 0 || (_window$frmAdminBuild2 = _window$frmAdminBuild.clearSettingsBox) === null || _window$frmAdminBuild2 === void 0 || _window$frmAdminBuild2.call(_window$frmAdminBuild); - } - } - }, { - key: "initSlideTrackUnderline", - value: function initSlideTrackUnderline(nav) { - var activeNav = nav !== undefined ? nav : this.navs.filter(function (nav) { - return nav.classList.contains('frm-active'); - }); - this.positionUnderlineIndicator(activeNav); - } - - /** - * Sets up a ResizeObserver to watch for scrollbar changes in the parent container. - * Automatically repositions the underline indicator when layout changes occur. - */ - }, { - key: "setupScrollbarObserver", - value: function setupScrollbarObserver() { - var _this2 = this; - var resizeObserverTarget = document.querySelector('.frm-scrollbar-wrapper, .styling_settings') || document.body; - if (!resizeObserverTarget || !('ResizeObserver' in window)) { - return; - } - this.resizeObserver = new ResizeObserver(function () { - var activeNav = _this2.wrapper.querySelector('.frm-tabs-navs ul > li.frm-active'); - if (activeNav) { - _this2.positionUnderlineIndicator(activeNav); - } - }); - this.resizeObserver.observe(resizeObserverTarget); - } - - /** - * Cleans up observers to prevent memory leaks. - */ - }, { - key: "cleanupObservers", - value: function cleanupObservers() { - if (this.resizeObserver) { - this.resizeObserver.disconnect(); - this.resizeObserver = null; - } - } - - /** - * Positions the underline indicator based on the active navigation element. - * - * @param {HTMLElement} activeNav The active navigation element to position the underline under - */ - }, { - key: "positionUnderlineIndicator", - value: function positionUnderlineIndicator(activeNav) { - var _this3 = this; - requestAnimationFrame(function () { - var position = _this3.isRTL ? -(activeNav.parentElement.offsetWidth - activeNav.offsetLeft - activeNav.offsetWidth) : activeNav.offsetLeft; - _this3.slideTrackLine.style.transform = "translateX(".concat(position, "px)"); - _this3.slideTrackLine.style.width = "".concat(activeNav.clientWidth, "px"); - }); - } - }, { - key: "changeSlide", - value: function changeSlide(index) { - this.removeActiveClassnameFromSlides(); - var translate = index == 0 ? '0px' : "calc( ( ".concat(index * 100, "% + ").concat(parseInt(this.flexboxSlidesGap, 10) * index, "px ) * ").concat(this.isRTL ? 1 : -1, " )"); - if ('0px' !== translate) { - this.slideTrack.style.transform = "translateX(".concat(translate, ")"); - } else { - this.slideTrack.style.removeProperty('transform'); - } - if (index in this.slides) { - this.slides[index].classList.add('frm-active'); - } - } - }, { - key: "removeActiveClassnameFromSlides", - value: function removeActiveClassnameFromSlides() { - this.slides.forEach(function (slide) { - return slide.classList.remove('frm-active'); - }); - } - }, { - key: "removeActiveClassnameFromNavs", - value: function removeActiveClassnameFromNavs() { - this.navs.forEach(function (nav) { - return nav.classList.remove('frm-active'); - }); - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/settings-components/components/slider-component.js": -/*!*******************************************************************!*\ - !*** ./js/src/settings-components/components/slider-component.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmSliderComponent) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../admin/components/dependent-updater-component */ "./js/src/admin/components/dependent-updater-component.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Internal dependencies - */ - - - -/** - * Represents a slider component. - * - * @class frmSliderComponent - */ -var frmSliderComponent = /*#__PURE__*/function () { - function frmSliderComponent() { - var _this = this; - var sliderElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; - var settings = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - _classCallCheck(this, frmSliderComponent); - this.loadedByWebComponent = sliderElements.length > 0; - this.sliderElements = sliderElements.length > 0 ? sliderElements : document.querySelectorAll('.frm-slider-component'); - this.settings = settings; - if (0 === this.sliderElements.length) { - return; - } - - // The slider bullet point width in pixels. Used in value calculation on drag event. - this.sliderBulletWidth = 16; - this.sliderMarginRight = 5; - this.eventsChange = []; - var debounce = frmDom.util.debounce; - this.valueChangeDebouncer = debounce(function (index) { - return _this.triggerValueChange(index); - }, 25); - this.initOptions(); - this.init(); - } - - /** - * Initializes the options for the slider component. - */ - return _createClass(frmSliderComponent, [{ - key: "initOptions", - value: function initOptions() { - var _this2 = this; - this.options = []; - this.sliderElements.forEach(function (element, index) { - var parentWrapper = element.classList.contains('frm-has-multiple-values') ? element.closest('.frm-style-component') : element; - var steps = _this2.settings.steps || (element.dataset.steps ? JSON.parse(element.dataset.steps) : null); - _this2.options.push({ - dragging: false, - startX: 0, - translateX: 0, - maxValue: parseInt(element.dataset.maxValue, 10), - element: element, - index: index, - value: 0, - steps: steps, - dependentUpdater: parentWrapper.classList.contains('frm-style-dependent-updater-component') ? new _admin_components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__["default"](parentWrapper) : null - }); - }); - } - - /** - * Initializes the slider component. - */ - }, { - key: "init", - value: function init() { - this.initDraggable(); - if (this.loadedByWebComponent) { - this.initSlidersPositionInsideWebComponent(); - return; - } - this.initSlidersPosition(); - } - - /** - * Initializes the draggable functionality for the slider component. - */ - }, { - key: "initDraggable", - value: function initDraggable() { - var _this3 = this; - this.sliderElements.forEach(function (element, index) { - _this3.eventsChange[index] = new Event('change', { - bubbles: true, - cancelable: true - }); - var draggableBullet = element.querySelector('.frm-slider-bullet'); - var valueInput = element.querySelector('.frm-slider-value input[type="text"]'); - valueInput.addEventListener('change', function (event) { - var unit = element.querySelector('select').value; - if (_this3.getMaxValue(unit, index) < parseInt(event.target.value, 10)) { - return; - } - _this3.initSliderWidth(element); - _this3.options[index].fullValue = _this3.updateValue(element, valueInput.value + unit); - _this3.triggerValueChange(index); - }); - _this3.expandSliderGroup(element); - _this3.updateOnUnitChange(element, valueInput, index); - _this3.changeSliderPositionOnClick(element, valueInput, index); - frmSliderComponent.maybeDisableUnitDropdown(element); - draggableBullet.addEventListener('mousedown', function (event) { - event.preventDefault(); - event.stopPropagation(); - if (element.classList.contains('frm-disabled')) { - return; - } - _this3.enableDragging(event, index); - var onMouseMove = function onMouseMove(moveEvent) { - return _this3.moveTracker(moveEvent, index); - }; - var _onMouseUp = function onMouseUp() { - _this3.disableDragging(index); - document.removeEventListener('mousemove', onMouseMove); - document.removeEventListener('mouseup', _onMouseUp); - }; - document.addEventListener('mousemove', onMouseMove); - document.addEventListener('mouseup', _onMouseUp); - }); - }); - } - }, { - key: "expandSliderGroup", - value: function expandSliderGroup(element) { - var svgIcon = element.querySelector('.frmsvg'); - if (element.dataset.displaySliders === undefined || null === svgIcon) { - return; - } - var sliderGroupItems = this.getSliderGroupItems(element); - svgIcon.addEventListener('click', function () { - sliderGroupItems.forEach(function (item) { - item.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); - }); - }); - } - }, { - key: "updateOnUnitChange", - value: function updateOnUnitChange(element, valueInput, index) { - var _this4 = this; - element.querySelector('select').addEventListener('change', function (event) { - var unit = event.target.value.toLowerCase(); - if ('' === unit) { - element.classList.add('frm-disabled', 'frm-empty'); - return; - } - if ('auto' === unit) { - element.classList.add('frm-disabled'); - _this4.updateValue(element, 'auto'); - _this4.triggerValueChange(index); - return; - } - element.classList.remove('frm-disabled', 'frm-empty'); - _this4.options[index].fullValue = valueInput.value + unit; - _this4.updateValue(element, _this4.options[index].fullValue); - _this4.triggerValueChange(index); - }); - } - }, { - key: "changeSliderPositionOnClick", - value: function changeSliderPositionOnClick(element, valueInput, index) { - var _this5 = this; - var frmSlider = element.querySelector('.frm-slider'); - var customEvent = new Event('change', { - bubbles: true, - cancelable: true - }); - frmSlider.addEventListener('click', function (event) { - if (element.classList.contains('frm-disabled')) { - return; - } - event.preventDefault(); - event.stopPropagation(); - if (!event.target.classList.contains('frm-slider') && !event.target.classList.contains('frm-slider-active-track')) { - return; - } - var sliderWidth = frmSlider.offsetWidth - _this5.sliderBulletWidth; - var sliderRect = frmSlider.getBoundingClientRect(); - var deltaX = event.clientX - sliderRect.left - _this5.sliderBulletWidth; - var unit = element.querySelector('select').value; - var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, _this5.getMaxValue(unit, index), _this5.options[index].steps); - if (value < 0) { - return; - } - _this5.options[index].fullValue = _this5.updateValue(element, value + unit); - _this5.initChildSlidersWidth(element, deltaX, index, value + unit); - valueInput.value = value; - valueInput.dispatchEvent(customEvent); - }); - } - - /** - * Disables the unit dropdown if there is only a single unit option. - * - * @param {HTMLElement} element - The slider element. - */ - }, { - key: "getSliderGroupItems", - value: - /** - * Retrieves an array of slider group items based on the provided element. - * - * @param {HTMLElement} element - The element to retrieve slider group items from. - * @return {NodeList} - An array-like object containing the slider group items. - */ - function getSliderGroupItems(element) { - if (element.dataset.displaySliders === undefined) { - return []; - } - var slidersGroup = element.dataset.displaySliders.split(','); - var query = slidersGroup.map(function (item) { - return ".frm-slider-component[data-type=\"".concat(item, "\"]"); - }).join(', '); - return element.closest('.frm-style-component').querySelectorAll(query); - } - }, { - key: "initSlidersPositionInsideWebComponent", - value: function initSlidersPositionInsideWebComponent() { - var _this6 = this; - this.sliderElements.forEach(function (element, index) { - _this6.initSliderWidth(element, index); - }); - } - - /** - * Initializes the position of sliders when a accordion section is opened. - */ - }, { - key: "initSlidersPosition", - value: function initSlidersPosition() { - var _this7 = this; - var emailSettings = document.querySelector('.email_settings'); - if (emailSettings) { - this.initSlidersWidth(emailSettings); - return; - } - var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); - var quickSettings = document.querySelector('.frm-quick-settings'); - var openedAccordion = document.querySelector('.accordion-section.open'); - - // Detect if upload background image upload has triggered and initialize the "Image Opacity" slider width. - wp.hooks.addAction('frm_pro_on_bg_image_upload', 'formidable', function (event) { - var imageBackgroundOpacitySlider = event.closest('.accordion-section-content').querySelector('#frm-bg-image-opacity-slider'); - _this7.initSlidersWidth(imageBackgroundOpacitySlider); - }); - - // init the sliders width from "Quick Settings" page. - if (quickSettings) { - this.initSlidersWidth(quickSettings); - } - - // Init the sliders width in opened accordion section from "Advanced Settings" page. - if (openedAccordion) { - this.initSlidersWidth(openedAccordion); - } - - // init the sliders width everytime when an accordion section is opened from "Advanced Settings" page. - accordionitems.forEach(function (item) { - item.addEventListener('click', function (event) { - _this7.initSlidersWidth(event.target.closest('.accordion-section')); - }); - }); - this.initSliderPositionOnFieldShapeChange(); - } - - /** - * Initializes the width of "Corner Radius" slider that is dynamically is displayed on "Field Shape" option change from "Quick Settings". - * - * @return {void} - */ - }, { - key: "initSliderPositionOnFieldShapeChange", - value: function initSliderPositionOnFieldShapeChange() { - var _this8 = this; - var fieldShapeType = document.querySelector('.frm-style-component.frm-field-shape'); - if (!fieldShapeType) { - return; - } - var radioButtons = fieldShapeType.querySelectorAll('input[type="radio"]'); - radioButtons.forEach(function (radio) { - radio.addEventListener('change', function (event) { - if (event.target.checked && 'rounded-corner' === event.target.value) { - var slider = document.querySelector('div[data-frm-element="field-shape-corner-radius"] .frm-slider-component'); - _this8.initSliderWidth(slider); - } - }); - }); - } - - /** - * Initializes the width of sliders within a given section. - * - * @param {HTMLElement} section - The section containing the sliders. - * @return {void} - */ - }, { - key: "initSlidersWidth", - value: function initSlidersWidth(section) { - var _this9 = this; - var sliders = section.querySelectorAll('.frm-slider-component'); - sliders.forEach(function (slider) { - setTimeout(function () { - _this9.initSliderWidth(slider); - }, 100); - }); - } - - /** - * Initializes the width of a slider. - * - * @param {HTMLElement} slider - The slider element. - * @param {number} sliderIndex - The index of the slider. - * @return {void} - */ - }, { - key: "initSliderWidth", - value: function initSliderWidth(slider) { - var sliderIndex = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - if (slider.classList.contains('frm-disabled')) { - return; - } - var index = sliderIndex !== null ? sliderIndex : this.getSliderIndex(slider); - var sliderWidth = slider.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; - var value = parseInt(slider.querySelector('.frm-slider-value input[type="text"]').value, 10); - var unit = slider.querySelector('select').value; - var steps = this.options[index].steps; - var deltaX = Math.ceil(value / this.options[index].maxValue * sliderWidth); - if ('%' === unit) { - deltaX = Math.round(sliderWidth * value / 100); - } else if (steps && steps.length > 0) { - deltaX = frmSliderComponent.calculateDeltaXFromSteps(value, steps, sliderWidth); - } - slider.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); - this.options[index].translateX = deltaX; - this.options[index].value = value + unit; - } - - /** - * Calculates the deltaX position based on a value and steps array. - * - * @param {number} value - The current value. - * @param {Array} steps - Array of step values. - * @param {number} sliderWidth - The width of the slider. - * @return {number} - The calculated deltaX position. - */ - }, { - key: "initChildSlidersWidth", - value: - /** - * Initializes the width of child sliders. - * - * @param {HTMLElement} slider - The parent slider element. - * @param {number} width - The width to set for the child sliders. - * @param {number} index - The starting index for the child sliders. - * @param {number} value - The value to set for the child sliders. - */ - function initChildSlidersWidth(slider, width, index, value) { - var _this0 = this; - if (!slider.classList.contains('frm-has-independent-fields') && !slider.classList.contains('frm-has-multiple-values')) { - return; - } - var childSliders = slider.classList.contains('frm-has-independent-fields') ? slider.querySelectorAll('.frm-independent-slider-field') : this.getSliderGroupItems(slider); - childSliders.forEach(function (item, childIndex) { - item.querySelector('.frm-slider-active-track').style.width = "".concat(width, "px"); - _this0.options[index + childIndex + 1].translateX = width; - _this0.options[index + childIndex + 1].value = value; - }); - } - - /** - * Returns the index of the specified slider element. - * - * @param {HTMLElement} slider - The slider element. - * @return {number} The index of the slider element. - */ - }, { - key: "getSliderIndex", - value: function getSliderIndex(slider) { - return this.options.filter(function (option) { - return option.element === slider; - })[0].index; - } - - /** - * Handles the movement of the slider tracker. - * - * @param {Event} event - The event object representing the mouse movement. - * @param {number} index - The index of the slider element. - * @return {void} - */ - }, { - key: "moveTracker", - value: function moveTracker(event, index) { - if (!this.options[index].dragging) { - return; - } - var deltaX = event.clientX - this.options[index].startX; - var element = this.sliderElements[index]; - var sliderWidth = element.querySelector('.frm-slider').offsetWidth - this.sliderBulletWidth; - - // Clamp deltaX within valid range - deltaX = Math.max(deltaX, 0); - deltaX = Math.min(deltaX, sliderWidth); - var unit = element.querySelector('select').value; - var value = frmSliderComponent.calculateValue(sliderWidth, deltaX, this.getMaxValue(unit, index), this.options[index].steps); - element.querySelector('.frm-slider-value input[type="text"]').value = value; - element.querySelector('.frm-slider-bullet .frm-slider-value-label').innerText = value; - element.querySelector('.frm-slider-active-track').style.width = "".concat(deltaX, "px"); - this.initChildSlidersWidth(element, deltaX, index, value + unit); - this.options[index].translateX = deltaX; - this.options[index].value = value + unit; - this.options[index].fullValue = this.updateValue(element, this.options[index].value); - this.valueChangeDebouncer(index); - } - - /** - * Get the maximum value based on the unit and index. - * - * @param {string} unit - The unit of measurement. - * @param {number} index - The index of the option. - * @return {number} The maximum value. - */ - }, { - key: "getMaxValue", - value: function getMaxValue(unit, index) { - return '%' === unit ? 100 : this.options[index].maxValue; - } - - /** - * Enables dragging for the slider component. - * - * @param {Event} event - The event object. - * @param {number} index - The index of the option being dragged. - */ - }, { - key: "enableDragging", - value: function enableDragging(event, index) { - event.target.classList.add('frm-dragging'); - this.options[index].dragging = true; - this.options[index].startX = event.clientX - this.options[index].translateX; - } - - /** - * Disables dragging for a specific index. - * - * @param {number} index - The index of the option to disable dragging for. - */ - }, { - key: "disableDragging", - value: function disableDragging(index) { - if (false === this.options[index].dragging) { - return; - } - var draggableBullet = this.sliderElements[index].querySelector('.frm-slider-bullet'); - draggableBullet.classList.remove('frm-dragging'); - this.options[index].dragging = false; - this.triggerValueChange(index); - } - - /** - * Triggers a value change for the specified index. - * - * @param {number} index - The index of the value to be changed. - */ - }, { - key: "triggerValueChange", - value: function triggerValueChange(index) { - var _this1 = this; - if (null !== this.options[index].dependentUpdater) { - this.options[index].dependentUpdater.updateAllDependentElements(this.options[index].fullValue); - return; - } - var input = this.sliderElements[index].classList.contains('frm-has-multiple-values') ? this.sliderElements[index].closest('.frm-style-component').querySelector('input[type="hidden"]') : this.sliderElements[index].querySelectorAll('.frm-slider-value input[type="hidden"]'); - if (input instanceof NodeList) { - input.forEach(function (item) { - item.dispatchEvent(_this1.eventsChange[index]); - }); - return; - } - input.dispatchEvent(this.eventsChange[index]); - } - - /** - * Calculates the value based on the width, deltaX, and maxValue. - * - * @param {number} width - The width of the slider. - * @param {number} deltaX - The change in x-coordinate. - * @param {number} maxValue - The maximum value. - * @param {Array|null} steps - Optional array of step values to snap to. - * @return {number} - The calculated value. - */ - }, { - key: "updateValue", - value: - /** - * Updates the value of a slider component. - * - * @param {HTMLElement} element - The slider component element. - * @param {string} value - The new value to be set. - * @return {string} - The updated value. - */ - function updateValue(element, value) { - var _this10 = this; - // When the slider component is used for "Base Font Size", we need to update a hidden input field when change happens to indicate that the "Base Font Size" has been adjusted. - // Used to avoid conflicts with other possible font sizes adjustemnts in "Advanced Settings" when moving from "Quick Settings" when "Base Font Size" is not changed. - if (element.classList.contains('frm-base-font-size')) { - var userBaseFontSizeInput = document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]'); - if (userBaseFontSizeInput) { - userBaseFontSizeInput.value = 'true'; - } - } - if (element.classList.contains('frm-has-multiple-values')) { - var input = element.closest('.frm-style-component').querySelector('input[type="hidden"]'); - var inputValue = input.value.split(' '); - var type = element.dataset.type; - if (!inputValue[2]) { - inputValue[2] = '0px'; - } - if (!inputValue[3]) { - inputValue[3] = '0px'; - } - switch (type) { - case 'vertical': - inputValue[0] = value; - inputValue[2] = value; - break; - case 'horizontal': - inputValue[1] = value; - inputValue[3] = value; - break; - case 'top': - inputValue[0] = value; - break; - case 'bottom': - inputValue[2] = value; - break; - case 'left': - inputValue[3] = value; - break; - case 'right': - inputValue[1] = value; - break; - } - var newValue = inputValue.join(' '); - input.value = newValue; - var childSlidersGroup = this.getSliderGroupItems(element); - childSlidersGroup.forEach(function (slider) { - var unitMeasure = _this10.getUnitMeasureFromValue(value); - slider.querySelector('.frm-slider-value input[type="text"]').value = parseInt(value, 10); - slider.querySelector('select').value = unitMeasure; - }); - return newValue; - } - if (element.classList.contains('frm-has-independent-fields')) { - var inputValues = element.querySelectorAll('.frm-slider-value input[type="hidden"]'); - var visibleValues = element.querySelectorAll('.frm-slider-value input[type="text"]'); - inputValues.forEach(function (input, index) { - input.value = value; - visibleValues[index + 1].value = parseInt(value, 10); - }); - return value; - } - element.querySelector('.frm-slider-value input[type="hidden"]').value = value; - return value; - } - - /** - * Returns the unit of measurement used in the given value. - * - * @param {string} value - The value to check for the unit of measurement. - * @return {string} The unit of measurement ('%', 'px', 'em') found in the value, or an empty string if none is found. - */ - }, { - key: "getUnitMeasureFromValue", - value: function getUnitMeasureFromValue(value) { - return ['%', 'px', 'em'].find(function (unit) { - return value.includes(unit); - }) || ''; - } - }], [{ - key: "maybeDisableUnitDropdown", - value: function maybeDisableUnitDropdown(element) { - var select = element.querySelector('select'); - if (!select) { - return; - } - var options = Array.from(select.options).filter(function (option) { - return '' !== option.value; - }); - if (1 >= options.length) { - select.classList.add('frm-single-unit'); - select.addEventListener('mousedown', function (event) { - return event.preventDefault(); - }); - } - } - }, { - key: "calculateDeltaXFromSteps", - value: function calculateDeltaXFromSteps(value, steps, sliderWidth) { - var stepIndex = steps.indexOf(value); - if (-1 === stepIndex) { - // If value not in steps, find closest and use its position - var closestValue = frmSliderComponent.snapToStep(value, steps); - var closestIndex = steps.indexOf(closestValue); - return Math.round(closestIndex / (steps.length - 1) * sliderWidth); - } - return Math.round(stepIndex / (steps.length - 1) * sliderWidth); - } - }, { - key: "calculateValue", - value: function calculateValue(width, deltaX, maxValue) { - var steps = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; - if (steps && steps.length > 0) { - // For stepped sliders, map position directly to step index - var position = deltaX / width; - var stepIndex = Math.round(position * (steps.length - 1)); - var clampedIndex = Math.max(0, Math.min(stepIndex, steps.length - 1)); - return steps[clampedIndex]; - } - - // Calculate value as a simple proportion of the slider position - var value = Math.round(deltaX / width * maxValue); - return Math.min(value, maxValue); - } - - /** - * Snaps a value to the nearest step in the steps array. - * - * @param {number} value - The value to snap. - * @param {Array} steps - Array of step values to snap to. - * @return {number} - The nearest step value. - */ - }, { - key: "snapToStep", - value: function snapToStep(value, steps) { - var nearest = steps[0]; - var minDiff = Math.abs(value - nearest); - for (var i = 1; i < steps.length; i++) { - var diff = Math.abs(value - steps[i]); - if (diff < minDiff) { - minDiff = diff; - nearest = steps[i]; - } - } - return nearest; - } - }]); -}(); - - -/***/ }), - -/***/ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.js": -/*!******************************************************************************************!*\ - !*** ./js/src/web-components/frm-border-radius-component/frm-border-radius-component.js ***! - \******************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmBorderRadiusComponent: () => (/* binding */ frmBorderRadiusComponent) -/* harmony export */ }); -/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var _frm_border_radius_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-border-radius-component.css */ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.css"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _superPropGet(t, o, e, r) { var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } -function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } -function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } -function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } -function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } -function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } -function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } - - - -var _onChange = /*#__PURE__*/new WeakMap(); -var _unitTypeOptions = /*#__PURE__*/new WeakMap(); -var _value = /*#__PURE__*/new WeakMap(); -var _defaultValue = /*#__PURE__*/new WeakMap(); -var _usesMultipleValues = /*#__PURE__*/new WeakMap(); -var frmBorderRadiusComponent = /*#__PURE__*/function (_frmWebComponent) { - function frmBorderRadiusComponent() { - var _this; - _classCallCheck(this, frmBorderRadiusComponent); - _this = _callSuper(this, frmBorderRadiusComponent); - _classPrivateFieldInitSpec(_this, _onChange, function () {}); - _classPrivateFieldInitSpec(_this, _unitTypeOptions, ['px', 'em', '%']); - _classPrivateFieldInitSpec(_this, _value, '0px'); - _classPrivateFieldInitSpec(_this, _defaultValue, '0px'); - _classPrivateFieldInitSpec(_this, _usesMultipleValues, false); - _this.componentStyle = _frm_border_radius_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; - return _this; - } - _inherits(frmBorderRadiusComponent, _frmWebComponent); - return _createClass(frmBorderRadiusComponent, [{ - key: "initOptions", - value: function initOptions() { - _superPropGet(frmBorderRadiusComponent, "initOptions", this, 3)([]); - if (null === this.componentId) { - var _frmBorderRadiusCompo; - this.componentId = "frm-border-radius-web-component-".concat(_instanceCount._ = (_frmBorderRadiusCompo = _instanceCount._, ++_frmBorderRadiusCompo)); - } - } - }, { - key: "initView", - value: function initView() { - this.wrapper = document.createElement('div'); - this.container = document.createElement('div'); - this.wrapper.classList.add('frm-border-radius-component'); - this.container.classList.add('frm-border-radius-container'); - this.container.append(this.getInputWrapper(), this.getButton(), this.getBorderIndividualInputsWrapper()); - this.wrapper.append(this.container); - return this.wrapper; - } - }, { - key: "parseDefaultValues", - value: function parseDefaultValues() { - if (!_classPrivateFieldGet(_defaultValue, this)) { - return { - top: { - value: 0, - unit: 'px' - }, - bottom: { - value: 0, - unit: 'px' - }, - left: { - value: 0, - unit: 'px' - }, - right: { - value: 0, - unit: 'px' - } - }; - } - var parts = _classPrivateFieldGet(_defaultValue, this).split(' '); - return { - top: frmBorderRadiusComponent.parseValueUnit(parts[0] || '0px'), - bottom: frmBorderRadiusComponent.parseValueUnit(parts[2] || parts[0] || '0px'), - left: frmBorderRadiusComponent.parseValueUnit(parts[3] || parts[1] || parts[0] || '0px'), - right: frmBorderRadiusComponent.parseValueUnit(parts[1] || parts[0] || '0px') - }; - } - }, { - key: "getInputWrapper", - value: function getInputWrapper() { - this.inputWrapper = document.createElement('div'); - this.inputWrapper.classList.add('frm-input-wrapper'); - this.inputWrapper.append(this.getInputValue(), this.getInputUnit(), this.getHiddenInput()); - return this.inputWrapper; - } - }, { - key: "getHiddenInput", - value: function getHiddenInput() { - this.hiddenInput = document.createElement('input'); - this.hiddenInput.type = 'hidden'; - this.hiddenInput.value = _classPrivateFieldGet(_value, this); - if (this.fieldName) { - this.hiddenInput.name = this.fieldName; - } - return this.hiddenInput; - } - }, { - key: "getInputValue", - value: function getInputValue() { - var _this2 = this; - this.inputValue = document.createElement('input'); - this.inputValue.type = 'text'; - this.inputValue.id = "".concat(this.componentId, "-value"); - this.inputValue.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Border radius value', 'formidable')); - this.inputValue.classList.add('frm-input-value'); - if (!_classPrivateFieldGet(_usesMultipleValues, this)) { - this.inputValue.value = parseInt(_classPrivateFieldGet(_defaultValue, this)) || 0; - } - this.inputValue.addEventListener('change', function () { - var value = _this2.inputValue.value + _this2.inputUnit.value; - _this2.hiddenInput.value = value; - _this2.borderInputBottom.value = _this2.inputValue.value; - _this2.borderInputTop.value = _this2.inputValue.value; - _this2.borderInputLeft.value = _this2.inputValue.value; - _this2.borderInputRight.value = _this2.inputValue.value; - _this2.updateValue(value); - }); - return this.inputValue; - } - }, { - key: "getInputUnit", - value: function getInputUnit() { - var _this3 = this; - this.inputUnit = document.createElement('select'); - this.inputUnit.id = "".concat(this.componentId, "-unit"); - this.inputUnit.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Border radius unit', 'formidable')); - this.inputUnit.classList.add('frm-input-unit'); - _classPrivateFieldGet(_unitTypeOptions, this).forEach(function (option) { - var opt = document.createElement('option'); - opt.value = option; - opt.textContent = option; - _this3.inputUnit.append(opt); - }); - this.inputUnit.addEventListener('change', function () { - _this3.hiddenInput.value = _this3.inputValue.value + _this3.inputUnit.value; - }); - return this.inputUnit; - } - }, { - key: "getBorderIndividualInputsWrapper", - value: function getBorderIndividualInputsWrapper() { - this.borderIndividualInputsWrapper = document.createElement('div'); - this.borderIndividualInputsWrapper.classList.add('frm-border-individual-inputs-wrapper'); - if (!_classPrivateFieldGet(_usesMultipleValues, this)) { - this.borderIndividualInputsWrapper.classList.add('frm_hidden'); - } - this.borderIndividualInputsWrapper.append(this.getBorderInputTop(), this.getBorderInputRight(), this.getBorderInputLeft(), this.getBorderInputBottom()); - return this.borderIndividualInputsWrapper; - } - }, { - key: "getBorderInputTop", - value: function getBorderInputTop() { - var _this4 = this; - var defaultValues = this.parseDefaultValues(); - var span = document.createElement('span'); - span.classList.add('frm-border-input-top'); - this.borderInputTop = document.createElement('input'); - this.borderInputTop.type = 'text'; - this.borderInputTop.id = "".concat(this.componentId, "-top"); - this.borderInputTop.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Top border radius', 'formidable')); - this.borderInputTop.value = parseInt(defaultValues.top.value); - span.append(this.borderInputTop); - this.borderInputTop.addEventListener('change', function () { - return _this4.buildBorderRadiusIndividualValue(); - }); - return span; - } - }, { - key: "getBorderInputBottom", - value: function getBorderInputBottom() { - var _this5 = this; - var defaultValues = this.parseDefaultValues(); - var span = document.createElement('span'); - span.classList.add('frm-border-input-bottom'); - this.borderInputBottom = document.createElement('input'); - this.borderInputBottom.type = 'text'; - this.borderInputBottom.id = "".concat(this.componentId, "-bottom"); - this.borderInputBottom.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Bottom border radius', 'formidable')); - this.borderInputBottom.value = parseInt(defaultValues.bottom.value); - span.append(this.borderInputBottom); - this.borderInputBottom.addEventListener('change', function () { - return _this5.buildBorderRadiusIndividualValue(); - }); - return span; - } - }, { - key: "getBorderInputLeft", - value: function getBorderInputLeft() { - var _this6 = this; - var defaultValues = this.parseDefaultValues(); - var span = document.createElement('span'); - span.classList.add('frm-border-input-left'); - this.borderInputLeft = document.createElement('input'); - this.borderInputLeft.type = 'text'; - this.borderInputLeft.id = "".concat(this.componentId, "-left"); - this.borderInputLeft.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Left border radius', 'formidable')); - this.borderInputLeft.value = parseInt(defaultValues.left.value); - span.append(this.borderInputLeft); - this.borderInputLeft.addEventListener('change', function () { - return _this6.buildBorderRadiusIndividualValue(); - }); - return span; - } - }, { - key: "getBorderInputRight", - value: function getBorderInputRight() { - var _this7 = this; - var defaultValues = this.parseDefaultValues(); - var span = document.createElement('span'); - span.classList.add('frm-border-input-right'); - this.borderInputRight = document.createElement('input'); - this.borderInputRight.type = 'text'; - this.borderInputRight.id = "".concat(this.componentId, "-right"); - this.borderInputRight.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Right border radius', 'formidable')); - this.borderInputRight.value = parseInt(defaultValues.right.value); - span.append(this.borderInputRight); - this.borderInputRight.addEventListener('change', function () { - return _this7.buildBorderRadiusIndividualValue(); - }); - return span; - } - }, { - key: "buildBorderRadiusIndividualValue", - value: function buildBorderRadiusIndividualValue() { - var unit = this.inputUnit.value; - var value = "".concat(parseInt(this.borderInputTop.value, 10)).concat(unit, " ").concat(parseInt(this.borderInputRight.value, 10)).concat(unit, " ").concat(parseInt(this.borderInputBottom.value, 10)).concat(unit, " ").concat(parseInt(this.borderInputLeft.value, 10)).concat(unit); - this.updateValue(value); - } - }, { - key: "updateValue", - value: function updateValue(value) { - this.hiddenInput.value = value; - _classPrivateFieldGet(_onChange, this).call(this, value); - } - }, { - key: "getButton", - value: function getButton() { - var _this8 = this; - this.button = document.createElement('button'); - this.button.type = 'button'; - this.button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Border Radius', 'formidable'); - if (_classPrivateFieldGet(_usesMultipleValues, this)) { - this.button.classList.add('frm-active'); - } - this.button.addEventListener('click', function () { - _this8.button.classList.toggle('frm-active'); - _this8.borderIndividualInputsWrapper.classList.toggle('frm_hidden'); - }); - return this.button; - } - }, { - key: "onChange", - set: function set(callback) { - if ('function' !== typeof callback) { - throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); - } - _classPrivateFieldSet(_onChange, this, callback); - } - }, { - key: "borderRadiusDefaultValue", - set: function set(value) { - _classPrivateFieldSet(_defaultValue, this, value); - _classPrivateFieldSet(_usesMultipleValues, this, !/^(\d+)(px|em|%)?$/.test(value) && '' !== value); - } - }], [{ - key: "parseValueUnit", - value: function parseValueUnit(valueStr) { - var match = valueStr.match(/^(\d+)(px|em|%)?$/); - if (!match) { - return { - value: 0, - unit: 'px' - }; - } - return { - value: parseInt(match[1], 10), - unit: match[2] || 'px' - }; - } - }]); -}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); -var _instanceCount = { - _: 0 -}; - -/***/ }), - -/***/ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.js": -/*!**************************************************************************************!*\ - !*** ./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.js ***! - \**************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmColorpickerComponent: () => (/* binding */ frmColorpickerComponent) -/* harmony export */ }); -/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); -/* harmony import */ var _frm_colorpicker_component_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frm-colorpicker-component.css */ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } -function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } -function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } -function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } -function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } - - -var _onChange = /*#__PURE__*/new WeakMap(); -var _defaultValue = /*#__PURE__*/new WeakMap(); -var frmColorpickerLiteComponent = /*#__PURE__*/function (_frmWebComponent) { - function frmColorpickerLiteComponent() { - var _this; - _classCallCheck(this, frmColorpickerLiteComponent); - _this = _callSuper(this, frmColorpickerLiteComponent); - _classPrivateFieldInitSpec(_this, _onChange, function () {}); - _classPrivateFieldInitSpec(_this, _defaultValue, '#ffffff'); - _this.input = document.createElement('input'); - _this.componentStyle = _frm_colorpicker_component_css__WEBPACK_IMPORTED_MODULE_1__["default"]; - _this.attachInternals(); - return _this; - } - _inherits(frmColorpickerLiteComponent, _frmWebComponent); - return _createClass(frmColorpickerLiteComponent, [{ - key: "initView", - value: function initView() { - var wrapper = document.createElement('div'); - wrapper.classList.add('frm-colorpicker-component', 'frm-colorpicker'); - wrapper.append(this.getInput()); - return wrapper; - } - }, { - key: "getInput", - value: function getInput() { - var _this2 = this; - this.input.type = 'text'; - this.input.classList.add('hex'); - if (null !== this.fieldName) { - this.input.name = this.fieldName; - } - if (null !== _classPrivateFieldGet(_defaultValue, this)) { - this.input.value = _classPrivateFieldGet(_defaultValue, this); - } - if (null !== this.componentId) { - this.input.id = this.componentId; - } - this.input.addEventListener('blur', function (event) { - return _classPrivateFieldGet(_onChange, _this2).call(_this2, event, null); - }); - return this.input; - } - }, { - key: "useShadowDom", - value: function useShadowDom() { - return false; - } - }, { - key: "afterViewInit", - value: function afterViewInit() { - var _this3 = this; - var colorPickerOptions = { - defaultColor: _classPrivateFieldGet(_defaultValue, this) - }; - if ('function' === typeof _classPrivateFieldGet(_onChange, this)) { - // Use the setTimeout when calling the callback for onChange to make sure the latest color is fetched. - colorPickerOptions.change = function (event, ui) { - return setTimeout(function () { - return _classPrivateFieldGet(_onChange, _this3).call(_this3, event, ui); - }, 20); - }; - } - jQuery(this.input).wpColorPicker(colorPickerOptions); - } - - /** - * A method to get the color value. - * - * @return {string} - The color value. - */ - }, { - key: "color", - get: function get() { - return jQuery(this.input).wpColorPicker('color'); - } - - /** - * A method to set the color value. - * - * @param {string} value - The value to set the color value for. - * @return {void} - */, - set: function set(value) { - _classPrivateFieldSet(_defaultValue, this, value); - this.input.value = value; - } - - /** - * A method to set the change event listener for the color picker component. - * - * @param {Function} callback - The callback function to call when the color picker component is changed. - * @return {void} - */ - }, { - key: "onChange", - set: function set(callback) { - if ('function' !== typeof callback) { - throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); - } - _classPrivateFieldSet(_onChange, this, callback); - } - }]); -}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); // The color picker component that may be a mixin of the color picker pro component. -_defineProperty(frmColorpickerLiteComponent, "formAssociated", true); -var frmColorpickerComponent = window.frmColorpickerProComponent ? window.frmColorpickerProComponent(frmColorpickerLiteComponent) : frmColorpickerLiteComponent; - -/***/ }), - -/***/ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.js": -/*!********************************************************************************!*\ - !*** ./js/src/web-components/frm-dropdown-component/frm-dropdown-component.js ***! - \********************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmDropdownComponent: () => (/* binding */ frmDropdownComponent) -/* harmony export */ }); -/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); -/* harmony import */ var _frm_dropdown_component_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frm-dropdown-component.css */ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.css"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } -function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } -function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } -function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } -function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } - - -var _onChange = /*#__PURE__*/new WeakMap(); -var _select = /*#__PURE__*/new WeakMap(); -var frmDropdownComponent = /*#__PURE__*/function (_frmWebComponent) { - function frmDropdownComponent() { - var _this; - _classCallCheck(this, frmDropdownComponent); - _this = _callSuper(this, frmDropdownComponent); - _classPrivateFieldInitSpec(_this, _onChange, function () {}); - _classPrivateFieldInitSpec(_this, _select, document.createElement('select')); - _this.componentStyle = _frm_dropdown_component_css__WEBPACK_IMPORTED_MODULE_1__["default"]; - _this.attachInternals(); - return _this; - } - - /** - * Initializes the view. Called when the component is rendered. - * - * @return {Element} - The wrapper element. - */ - _inherits(frmDropdownComponent, _frmWebComponent); - return _createClass(frmDropdownComponent, [{ - key: "initView", - value: function initView() { - this.wrapper = document.createElement('div'); - this.wrapper.classList.add('frm-dropdown-component'); - this.wrapper.append(this.getSelect()); - return this.wrapper; - } - - /** - * Gets the select element. - * - * @return {Element} - The select element. - */ - }, { - key: "getSelect", - value: function getSelect() { - if (this.componentId) { - _classPrivateFieldGet(_select, this).id = this.componentId; - } - if (this.fieldName) { - _classPrivateFieldGet(_select, this).name = this.fieldName; - } - return _classPrivateFieldGet(_select, this); - } - - /** - * Determines if the component should use shadow DOM. The dropdown component can utilize shadow DOM as it does not require external functional dependencies. - * - * @return {boolean} - True if the component should use shadow DOM, false otherwise. - */ - }, { - key: "useShadowDom", - value: function useShadowDom() { - return true; - } - - /** - * Initializes the select options. It will retrieve the all the options from the component and create new option elements. - * - * @return {void} - */ - }, { - key: "initSelectOptions", - value: function initSelectOptions() { - var _this2 = this; - var optionsNodes = this.querySelectorAll('option'); - optionsNodes.forEach(function (option) { - var opt = document.createElement('option'); - opt.value = option.value; - opt.textContent = option.textContent; - option.remove(); - _classPrivateFieldGet(_select, _this2).append(opt); - }); - } - - /** - * Called when the component is visible in the viewport. - * - * @return {void} - */ - }, { - key: "afterViewInit", - value: function afterViewInit() { - var _this3 = this; - this.initSelectOptions(); - _classPrivateFieldGet(_select, this).addEventListener('change', function () { - _classPrivateFieldGet(_onChange, _this3).call(_this3, _classPrivateFieldGet(_select, _this3).value); - }); - } - - /** - * A method to add options dynamically to the select element. - * - * @param {Array} options - The options to add. - * @return {void} - */ - }, { - key: "addOptions", - set: function set(options) { - var _this4 = this; - options.forEach(function (option) { - var opt = document.createElement('option'); - opt.value = option.value; - opt.textContent = option.label; - opt.selected = option.selected; - _classPrivateFieldGet(_select, _this4).append(opt); - }); - } - - /** - * A method to set the disabled state of the select element. - * - * @param {boolean} value - The value to set. - * @return {void} - */ - }, { - key: "disabled", - set: function set(value) { - _classPrivateFieldGet(_select, this).disabled = value; - } - - /** - * A method to set the change event listener for the select element. - * - * @param {Function} callback - The callback function to call when the select element is changed. - * @return {void} - */ - }, { - key: "onChange", - set: function set(callback) { - if ('function' !== typeof callback) { - throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); - } - _classPrivateFieldSet(_onChange, this, callback); - } - - /** - * A method to set the selected value of the select element. - * - * @param {string} value - The value to set. - * @return {void} - */ - }, { - key: "selectedValue", - set: function set(value) { - var option = Array.from(_classPrivateFieldGet(_select, this).options).find(function (option) { - return option.value === value; - }); - if (option) { - option.selected = true; - } - } - }]); -}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); - -// A shorthand function to create a dropdown component. -_defineProperty(frmDropdownComponent, "formAssociated", true); -window.frmDropdownComponent = function (id, options, onChangeCallback) { - var dropdown = document.createElement('frm-dropdown-component'); - dropdown.id = id; - dropdown.addOptions = options; - dropdown.onChange = onChangeCallback; - return dropdown; -}; - -/***/ }), - -/***/ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.js": -/*!****************************************************************************************!*\ - !*** ./js/src/web-components/frm-range-slider-component/frm-range-slider-component.js ***! - \****************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmRangeSliderComponent: () => (/* binding */ frmRangeSliderComponent) -/* harmony export */ }); -/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); -/* harmony import */ var _settings_components_components_slider_component_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../settings-components/components/slider-component.js */ "./js/src/settings-components/components/slider-component.js"); -/* harmony import */ var _frm_range_slider_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-range-slider-component.css */ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.css"); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _superPropGet(t, o, e, r) { var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } -function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } -function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } -function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } -function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } -function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } -function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } - - - - -var _onChange = /*#__PURE__*/new WeakMap(); -var _sliderDefaultValue = /*#__PURE__*/new WeakMap(); -var _sliderDefaultMultipleValues = /*#__PURE__*/new WeakMap(); -var _hasMultipleValues = /*#__PURE__*/new WeakMap(); -var _sliderAvailableUnits = /*#__PURE__*/new WeakMap(); -var _sliderMaxValue = /*#__PURE__*/new WeakMap(); -var _sliderSteps = /*#__PURE__*/new WeakMap(); -var frmRangeSliderComponent = /*#__PURE__*/function (_frmWebComponent) { - function frmRangeSliderComponent() { - var _this; - _classCallCheck(this, frmRangeSliderComponent); - _this = _callSuper(this, frmRangeSliderComponent); - _classPrivateFieldInitSpec(_this, _onChange, function () {}); - _classPrivateFieldInitSpec(_this, _sliderDefaultValue, '0px'); - _classPrivateFieldInitSpec(_this, _sliderDefaultMultipleValues, { - vertical: { - value: 0, - unit: 'px' - }, - top: { - value: 0, - unit: 'px' - }, - bottom: { - value: 0, - unit: 'px' - }, - horizontal: { - value: 0, - unit: 'px' - }, - left: { - value: 0, - unit: 'px' - }, - right: { - value: 0, - unit: 'px' - } - }); - _classPrivateFieldInitSpec(_this, _hasMultipleValues, false); - _classPrivateFieldInitSpec(_this, _sliderAvailableUnits, ['px', 'em', '%']); - _classPrivateFieldInitSpec(_this, _sliderMaxValue, 100); - _classPrivateFieldInitSpec(_this, _sliderSteps, null); - _this.componentStyle = _frm_range_slider_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; - return _this; - } - _inherits(frmRangeSliderComponent, _frmWebComponent); - return _createClass(frmRangeSliderComponent, [{ - key: "initOptions", - value: function initOptions() { - _superPropGet(frmRangeSliderComponent, "initOptions", this, 3)([]); - if (null === this.componentId) { - var _frmRangeSliderCompon; - this.componentId = "frm-range-slider-web-component-".concat(_instanceCount._ = (_frmRangeSliderCompon = _instanceCount._, ++_frmRangeSliderCompon)); - } - } - - /** - * A method to set the change event listener for the slider component. - * - * @param {Function} callback - The callback function to call when the slider component is changed. - * @return {void} - */ - }, { - key: "onChange", - set: function set(callback) { - if ('function' !== typeof callback) { - throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); - } - _classPrivateFieldSet(_onChange, this, callback); - } - - /** - * A method to set the has multiple values flag. This flag is used to determine if the slider component should display multiple values. - * - * @param {boolean} value - The value to set. - * @return {void} - */ - }, { - key: "hasMultipleValues", - set: function set(value) { - _classPrivateFieldSet(_hasMultipleValues, this, value); - } - - /** - * A method to set the default multiple values. This values are used to determine the default values for the slider component. - * - * @param {Object} value - The value to set. - * @return {void} - */ - }, { - key: "sliderDefaultMultipleValues", - set: function set(value) { - _classPrivateFieldSet(_sliderDefaultMultipleValues, this, value); - } - - /** - * A method to set the default value for the single slider component. This value is used to determine the default value for the single slider component. - * - * @param {string|number} value - The value to set. - * @return {void} - */ - }, { - key: "sliderDefaultValue", - set: function set(value) { - _classPrivateFieldSet(_sliderDefaultValue, this, String(value)); - } - - /** - * A method to set the available units for the slider component. This units are used to determine the available units for the slider component. - * - * @param {Array} value - The value to set. - * @return {void} - */ - }, { - key: "sliderAvailableUnits", - set: function set(value) { - _classPrivateFieldSet(_sliderAvailableUnits, this, value); - } - - /** - * A method to set the max value that the slider can take. - * - * @param {string|number} value - The value to set. - * @return {void} - */ - }, { - key: "sliderMaxValue", - set: function set(value) { - _classPrivateFieldSet(_sliderMaxValue, this, value.toString()); - } - }, { - key: "steps", - set: function set(value) { - _classPrivateFieldSet(_sliderSteps, this, value); - } - }, { - key: "useShadowDom", - value: function useShadowDom() { - return false; - } - }, { - key: "initView", - value: function initView() { - this.wrapper = document.createElement('div'); - this.slidersContainer = document.createElement('div'); - this.slidersContainer.classList.add('frm-sliders-container'); - this.wrapper.classList.add('frm-style-component'); - var config = { - maxValue: parseInt(this.getAttribute('data-max-value') || _classPrivateFieldGet(_sliderMaxValue, this), 10), - units: this.getAvailableUnits(), - componentClass: this.getAttribute('data-component-class') || '', - componentId: this.componentId, - fieldName: this.fieldName ? "name=\"".concat(this.fieldName, "\"") : '', - fieldValue: this.defaultValue || _classPrivateFieldGet(_sliderDefaultValue, this) - }; - if (this.hasMultipleSliderValues()) { - this.createMultipleValuesSlider(this.slidersContainer, _objectSpread(_objectSpread({}, config), {}, { - defaultValues: this.parseDefaultMultipleValues() - })); - this.wrapper.append(this.slidersContainer); - return this.wrapper; - } - this.slidersContainer.append(this.createSlider({ - maxValue: config.maxValue, - units: config.units, - value: frmRangeSliderComponent.parseValueUnit(config.fieldValue), - addHiddenInputValue: true - })); - this.wrapper.append(this.slidersContainer); - return this.wrapper; - } - - /** - * A method to get the available units for the slider component. It will checke the data-units attribute first and if it is not set, it will return the default available units. - * - * @return {Array} - The available units. - */ - }, { - key: "getAvailableUnits", - value: function getAvailableUnits() { - var attr = this.getAttribute('data-units'); - if (!attr) { - return _classPrivateFieldGet(_sliderAvailableUnits, this); - } - return attr.split(',').map(function (u) { - return u.trim(); - }); - } - - /** - * A method to parse the default values for the multiple values slider component. It will check the data-values attribute first and if it is not set, it will return the default values. - * If the values haven't been set via data-values attribute or dynamically via this._sliderDefaultMultipleValues it will return the default values. - * - * @return {Object} - The default values. - */ - }, { - key: "parseDefaultMultipleValues", - value: function parseDefaultMultipleValues() { - var valuesAttr = this.getAttribute('data-values') || _classPrivateFieldGet(_sliderDefaultMultipleValues, this); - var parts = valuesAttr.split(' '); - var getPart = function getPart(id, fallbackId) { - return parts[id] || parts[fallbackId] || '0px'; - }; - return { - vertical: frmRangeSliderComponent.parseValueUnit(getPart(0)), - top: frmRangeSliderComponent.parseValueUnit(getPart(0)), - bottom: frmRangeSliderComponent.parseValueUnit(getPart(2, 0)), - horizontal: frmRangeSliderComponent.parseValueUnit(getPart(1, 0)), - left: frmRangeSliderComponent.parseValueUnit(getPart(3, 1)), - right: frmRangeSliderComponent.parseValueUnit(getPart(1, 0)) - }; - } - - /** - * A method to parse the value and unit for the slider component. - * - * @param {string} valueStr - The value string to parse. - * @return {Object} - The value and unit object. - */ - }, { - key: "hasMultipleSliderValues", - value: - /** - * A method to check if the slider component has multiple values. It will check the data-has-multiple-values attribute first and if it is not set, it will return the default value. - * - * @return {boolean} - The has multiple values flag. - */ - function hasMultipleSliderValues() { - return this.getAttribute('data-has-multiple-values') === 'true' || _classPrivateFieldGet(_hasMultipleValues, this); - } - - /** - * A method to create the multiple values slider. - * - * @param {Element} wrapper - The wrapper element. - * @param {Object} options - The options for the slider. - * @return {void} - */ - }, { - key: "createMultipleValuesSlider", - value: function createMultipleValuesSlider(wrapper, options) { - var _this2 = this; - var maxValue = options.maxValue, - units = options.units, - componentClass = options.componentClass, - fieldValue = options.fieldValue, - defaultValues = options.defaultValues; - var groups = [{ - type: 'vertical', - displaySliders: 'top,bottom', - iconSvgId: 'frm-margin-top-bottom', - ariaLabel: 'Vertical value', - defaultValues: defaultValues.vertical - }, { - type: 'horizontal', - displaySliders: 'left,right', - iconSvgId: 'frm-margin-left-right', - ariaLabel: 'Horizontal value', - defaultValues: defaultValues.horizontal - }]; - if (componentClass) { - wrapper.className = componentClass; - } - groups.forEach(function (group) { - wrapper.append(_this2.createSliderGroup({ - type: group.type, - displaySliders: group.displaySliders, - maxValue: maxValue, - units: units, - value: group.defaultValues, - iconSvgId: group.iconSvgId, - ariaLabel: group.ariaLabel, - defaultValues: defaultValues, - addHiddenInputValue: false - })); - }); - if (fieldValue) { - wrapper.append(this.createSliderHiddenInputValue(fieldValue)); - } - } - - /** - * A method to create the hidden input value for the slider component. This hidden input value is used to store the value of the slider component. - * - * @param {string} fieldValue - The field value to set. - * @return {Element} - The hidden input value element. - */ - }, { - key: "createSliderHiddenInputValue", - value: function createSliderHiddenInputValue(fieldValue) { - var _this3 = this; - if (!fieldValue) { - return null; - } - var input = document.createElement('input'); - Object.assign(input, { - type: 'hidden', - value: fieldValue - }); - if (this.fieldName) { - input.setAttribute('name', this.fieldName); - } - if (this.componentId) { - input.id = this.componentId; - } - if (_classPrivateFieldGet(_onChange, this)) { - input.addEventListener('change', function () { - _classPrivateFieldGet(_onChange, _this3).call(_this3, input.value); - }); - } - return input; - } - - /** - * A method to create the slider group. This method is used to create the slider group. - * - * @param {Object} options - The options for the slider. - * @return {Element} - The slider group element. - */ - }, { - key: "createSliderGroup", - value: function createSliderGroup(options) { - var _this4 = this; - var slider = this.createSlider(options); - slider.classList.add('frm-group-sliders', 'frm-has-multiple-values'); - slider.setAttribute('data-display-sliders', options.displaySliders); - var slidersGroupItems = options.displaySliders.split(','); - slidersGroupItems.forEach(function (item) { - slider.append(_this4.createSlider({ - type: item, - maxValue: options.maxValue, - units: options.units, - value: options.defaultValues[item], - iconSvgId: "frm-margin-".concat(item), - ariaLabel: "".concat(item, " value"), - hidden: true, - addHiddenInputValue: false - })); - }); - return slider; - } - - /** - * A method to create the slider track. This method is used to create the slider track. - * - * @param {Object} value - The value of the slider. - * @return {Element} - The slider track element. - */ - }, { - key: "createSlider", - value: - /** - * A method to create the slider. This method is used to create the slider. - * - * @param {Object} options - The options for the slider. - * @return {Element} - The slider element. - */ - function createSlider(options) { - var type = options.type, - maxValue = options.maxValue, - units = options.units, - value = options.value, - iconSvgId = options.iconSvgId, - ariaLabel = options.ariaLabel, - hidden = options.hidden, - addHiddenInputValue = options.addHiddenInputValue; - var sliderWrapper = document.createElement('div'); - sliderWrapper.classList.add('frm-slider-component'); - sliderWrapper.setAttribute('data-max-value', maxValue.toString()); - if (hidden) { - sliderWrapper.classList.add('frm_hidden'); - } - if (type) { - sliderWrapper.setAttribute('data-type', type); - } - var flexContainer = document.createElement('div'); - flexContainer.classList.add('frm-flex-justify'); - - // Slider container - var sliderContainer = document.createElement('div'); - sliderContainer.classList.add('frm-slider-container'); - - // Icon - if (iconSvgId) { - sliderContainer.append(frmRangeSliderComponent.createSvgIcon(iconSvgId)); - } - - // Slider track - sliderContainer.append(frmRangeSliderComponent.createSliderTrack(value)); - flexContainer.append(sliderContainer); - - // Value input and unit select - var baseId = "".concat(this.componentId).concat(type ? "-".concat(type) : ''); - var valueContainer = frmRangeSliderComponent.createSliderValueAndUnitSelection(value, ariaLabel, units, baseId); - if (addHiddenInputValue) { - valueContainer.append(this.createSliderHiddenInputValue(options)); - } - flexContainer.append(valueContainer); - sliderWrapper.append(flexContainer); - return sliderWrapper; - } - }, { - key: "afterViewInit", - value: function afterViewInit() { - var defaultValues = this.hasMultipleSliderValues() ? this.parseDefaultMultipleValues() : frmRangeSliderComponent.parseValueUnit(this.defaultValue); - var options = Object.assign({ - defaultValues: defaultValues - }, { - steps: _classPrivateFieldGet(_sliderSteps, this) - }); - new _settings_components_components_slider_component_js__WEBPACK_IMPORTED_MODULE_1__["default"](this.wrapper.querySelectorAll('.frm-slider-component'), options); - } - }], [{ - key: "parseValueUnit", - value: function parseValueUnit(valueStr) { - var defaultValue = { - value: 0, - unit: 'px' - }; - if (!valueStr) { - return defaultValue; - } - var match = valueStr.match(/^(\d+)(px|em|%|\s)?$/); - if (!match) { - return defaultValue; - } - return { - value: parseInt(match[1], 10), - unit: match[2] || 'px' - }; - } - }, { - key: "createSliderTrack", - value: function createSliderTrack(value) { - var slider = document.createElement('span'); - slider.classList.add('frm-slider'); - slider.setAttribute('tabindex', '0'); - var activeTrack = document.createElement('span'); - activeTrack.classList.add('frm-slider-active-track'); - var bullet = document.createElement('span'); - bullet.classList.add('frm-slider-bullet'); - var valueLabel = document.createElement('span'); - valueLabel.classList.add('frm-slider-value-label'); - valueLabel.textContent = value.value.toString(); - bullet.append(valueLabel); - activeTrack.append(bullet); - slider.append(activeTrack); - return slider; - } - - /** - * A method to create the value and unit selection. This method is used to create the value and unit selection. - * - * @param {Object} value - The value of the slider. - * @param {string} ariaLabel - The aria label of the slider. - * @param {Array} units - The units of the slider. - * @param {string} baseId - The base ID for the form elements. - * @return {Element} - The value and unit selection element. - */ - }, { - key: "createSliderValueAndUnitSelection", - value: function createSliderValueAndUnitSelection(value, ariaLabel, units, baseId) { - var valueContainer = document.createElement('div'); - valueContainer.classList.add('frm-slider-value'); - var valueInput = document.createElement('input'); - valueInput.type = 'text'; - valueInput.value = value.value.toString(); - if (ariaLabel) { - valueInput.setAttribute('aria-label', ariaLabel); - } - var unitSelect = document.createElement('select'); - unitSelect.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_3__.__)('Value unit', 'formidable')); - if (baseId) { - valueInput.id = "".concat(baseId, "-value"); - unitSelect.id = "".concat(baseId, "-unit"); - } - units.forEach(function (unit) { - return unitSelect.append(frmRangeSliderComponent.createDropdownOption(unit, unit, value.unit === unit)); - }); - valueContainer.append(valueInput, unitSelect); - return valueContainer; - } - - /** - * A method to create the dropdown option. This method is used to create the dropdown option. - * - * @param {string} value - The value of the option. - * @param {string} label - The label of the option. - * @param {boolean} selected - Whether the option is selected. - * @return {Element} - The dropdown option element. - */ - }, { - key: "createDropdownOption", - value: function createDropdownOption(value, label) { - var selected = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - var option = document.createElement('option'); - option.value = value; - option.textContent = label; - option.selected = selected; - return option; - } - - /** - * A method to create the SVG icon. This method is used to create the SVG icon. - * - * @param {string} iconSvgId - The ID of the SVG icon. - * @return {Element} - The SVG icon element. - */ - }, { - key: "createSvgIcon", - value: function createSvgIcon(iconSvgId) { - var svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg'); - svg.classList.add('frmsvg'); - var use = document.createElementNS('http://www.w3.org/2000/svg', 'use'); - use.setAttribute('href', "#".concat(iconSvgId)); - svg.append(use); - return svg; - } - }]); -}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); -var _instanceCount = { - _: 0 -}; - -/***/ }), - -/***/ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.js": -/*!******************************************************************************************!*\ - !*** ./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.js ***! - \******************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmTabNavigatorComponent: () => (/* binding */ frmTabNavigatorComponent) -/* harmony export */ }); -/* harmony import */ var _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../components/class-tabs-navigator */ "./js/src/components/class-tabs-navigator.js"); -/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); -/* harmony import */ var _frm_tab_navigator_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-tab-navigator-component.css */ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } - - - -var frmTabNavigatorComponent = /*#__PURE__*/function (_frmWebComponent) { - function frmTabNavigatorComponent() { - var _this; - _classCallCheck(this, frmTabNavigatorComponent); - _this = _callSuper(this, frmTabNavigatorComponent); - _this.componentStyle = _frm_tab_navigator_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; - return _this; - } - - /** - * Initializes the view. - * - * @return {Element} - The wrapper element. - */ - _inherits(frmTabNavigatorComponent, _frmWebComponent); - return _createClass(frmTabNavigatorComponent, [{ - key: "initView", - value: function initView() { - this.tabs = this.querySelectorAll('.frm-tab'); - if (0 === this.tabs.length) { - return null; - } - var wrapper = document.createElement('div'); - wrapper.classList.add('frm-tabs-wrapper'); - wrapper.append(this.getTabDelimiter()); - wrapper.append(this.getTabs()); - wrapper.append(this.getTabContainer()); - return wrapper; - } - }, { - key: "afterViewInit", - value: function afterViewInit(wrapper) { - this.tabsNavigator = new _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_0__.frmTabsNavigator(wrapper); - } - - /** - * Gets the tab delimiter. - * - * @return {string} - The tab delimiter. - */ - }, { - key: "getTabDelimiter", - value: function getTabDelimiter() { - var delimiter = document.createElement('div'); - var underline = document.createElement('span'); - underline.classList.add('frm-tabs-active-underline'); - delimiter.className = 'frm-tabs-delimiter'; - delimiter.append(underline); - return delimiter; - } - - /** - * Gets the tab headings. - * - * @return {string} - The tab headings. - */ - }, { - key: "getTabs", - value: function getTabs() { - var _this2 = this; - var tabHeadings = document.createElement('div'); - var ul = document.createElement('ul'); - tabHeadings.className = 'frm-tabs-navs'; - tabHeadings.append(ul); - Array.from(this.tabs).forEach(function (tab, index) { - ul.append(_this2.createTabHeading(tab, index)); - }); - return tabHeadings; - } - - /** - * Gets the tab container. - * - * @return {string} - The tab container. - */ - }, { - key: "getTabContainer", - value: function getTabContainer() { - var _this3 = this; - var tabContainer = document.createElement('div'); - var slideTrack = document.createElement('div'); - tabContainer.className = 'frm-tabs-container'; - slideTrack.className = 'frm-tabs-slide-track frm-flex-box'; - tabContainer.append(slideTrack); - Array.from(this.tabs).forEach(function (tab, index) { - slideTrack.append(_this3.createTabContainer(tab, index)); - }); - return tabContainer; - } - - /** - * Creates a tab heading. - * - * @param {Element} tab - The tab element. - * @param {number} index - The index of the tab. - * @return {string} - The tab heading. - */ - }, { - key: "createTabHeading", - value: function createTabHeading(tab, index) { - var className = index === 0 ? 'frm-active' : ''; - var li = document.createElement('li'); - li.className = className; - li.innerText = tab.getAttribute('data-tab-title'); - return li; - } - - /** - * Creates a tab container. - * - * @param {Element} tab - The tab element. - * @param {number} index - The index of the tab. - * @return {string} - The tab container. - */ - }, { - key: "createTabContainer", - value: function createTabContainer(tab, index) { - var className = index === 0 ? 'frm-active' : ''; - var container = document.createElement('div'); - container.className = "frm-tab-container ".concat(className); - Array.from(tab.children).forEach(function (child) { - container.append(child); - }); - return container; - } - - /** - * Gets the tab underline. - * - * @return {Element} - The tab underline. - */ - }, { - key: "getTabUnderline", - value: function getTabUnderline() { - return this.shadowRoot.querySelector('.frm-tabs-active-underline'); - } - }, { - key: "getLabelText", - value: function getLabelText() { - return null; - } - }]); -}(_frm_web_component__WEBPACK_IMPORTED_MODULE_1__.frmWebComponent); - -/***/ }), - -/***/ "./js/src/web-components/frm-typography-component/frm-typography-component.js": -/*!************************************************************************************!*\ - !*** ./js/src/web-components/frm-typography-component/frm-typography-component.js ***! - \************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmTypographyComponent: () => (/* binding */ frmTypographyComponent) -/* harmony export */ }); -/* harmony import */ var _frm_web_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../frm-web-component */ "./js/src/web-components/frm-web-component.js"); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var _frm_typography_component_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-typography-component.css */ "./js/src/web-components/frm-typography-component/frm-typography-component.css"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _superPropGet(t, o, e, r) { var p = _get(_getPrototypeOf(1 & r ? t.prototype : t), o, e); return 2 & r && "function" == typeof p ? function (t) { return p.apply(e, t); } : p; } -function _get() { return _get = "undefined" != typeof Reflect && Reflect.get ? Reflect.get.bind() : function (e, t, r) { var p = _superPropBase(e, t); if (p) { var n = Object.getOwnPropertyDescriptor(p, t); return n.get ? n.get.call(arguments.length < 3 ? e : r) : n.value; } }, _get.apply(null, arguments); } -function _superPropBase(t, o) { for (; !{}.hasOwnProperty.call(t, o) && null !== (t = _getPrototypeOf(t));); return t; } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -function _classPrivateFieldInitSpec(e, t, a) { _checkPrivateRedeclaration(e, t), t.set(e, a); } -function _checkPrivateRedeclaration(e, t) { if (t.has(e)) throw new TypeError("Cannot initialize the same private elements twice on an object"); } -function _classPrivateFieldGet(s, a) { return s.get(_assertClassBrand(s, a)); } -function _classPrivateFieldSet(s, a, r) { return s.set(_assertClassBrand(s, a), r), r; } -function _assertClassBrand(e, t, n) { if ("function" == typeof e ? e === t : e.has(t)) return arguments.length < 3 ? t : n; throw new TypeError("Private element is not present on this object"); } - - - -var _onChange = /*#__PURE__*/new WeakMap(); -var _defaultOptions = /*#__PURE__*/new WeakMap(); -var _unitTypeOptions = /*#__PURE__*/new WeakMap(); -var _defaultValue = /*#__PURE__*/new WeakMap(); -var frmTypographyComponent = /*#__PURE__*/function (_frmWebComponent) { - function frmTypographyComponent() { - var _this; - _classCallCheck(this, frmTypographyComponent); - _this = _callSuper(this, frmTypographyComponent); - _classPrivateFieldInitSpec(_this, _onChange, function () {}); - _classPrivateFieldInitSpec(_this, _defaultOptions, [{ - value: '21px', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Default', 'formidable') - }]); - _classPrivateFieldInitSpec(_this, _unitTypeOptions, ['px', 'em', '%']); - _classPrivateFieldInitSpec(_this, _defaultValue, '21px'); - _this.componentStyle = _frm_typography_component_css__WEBPACK_IMPORTED_MODULE_2__["default"]; - _classPrivateFieldSet(_defaultOptions, _this, [{ - value: '', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Default', 'formidable') - }, { - value: '18px', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Small', 'formidable') - }, { - value: '21px', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Regular', 'formidable') - }, { - value: '26px', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Large', 'formidable') - }, { - value: '32px', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Larger', 'formidable') - }, { - value: 'custom', - label: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Custom', 'formidable') - }]); - return _this; - } - _inherits(frmTypographyComponent, _frmWebComponent); - return _createClass(frmTypographyComponent, [{ - key: "initOptions", - value: function initOptions() { - _superPropGet(frmTypographyComponent, "initOptions", this, 3)([]); - if (null === this.componentId) { - var _frmTypographyCompone; - this.componentId = "frm-typography-web-component-".concat(_instanceCount._ = (_frmTypographyCompone = _instanceCount._, ++_frmTypographyCompone)); - } - } - }, { - key: "initView", - value: function initView() { - this.wrapper = document.createElement('div'); - this.container = document.createElement('div'); - this.wrapper.classList.add('frm-typography-component', 'frm-typography'); - this.container.classList.add('frm-typography-container'); - this.container.append(this.getSelect(), this.getUnitValueWrapper(), this.getHiddenInput()); - this.wrapper.append(this.container); - return this.wrapper; - } - - /** - * A method to get the select element. - * - * @return {Element} - The select element. - */ - }, { - key: "getSelect", - value: function getSelect() { - this.select = document.createElement('select'); - this.select.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Font size', 'formidable')); - if (null !== this.componentId) { - this.select.id = this.componentId; - } - if (null !== this.fieldName) { - this.select.name = "".concat(this.fieldName, "[size]"); - } - this.getDefaultOptions(this.select); - return this.select; - } - - /** - * A method to get the default options for the select element. - * - * @param {Element} select - The select element. - * @return {void} - */ - }, { - key: "getDefaultOptions", - value: function getDefaultOptions(select) { - var _this2 = this; - _classPrivateFieldGet(_defaultOptions, this).forEach(function (option) { - var opt = document.createElement('option'); - opt.value = option.value; - opt.textContent = option.label; - opt.selected = option.value === 'custom' && frmTypographyComponent.isCustomFonSize(_classPrivateFieldGet(_defaultValue, _this2)) || option.value === _classPrivateFieldGet(_defaultValue, _this2); - select.append(opt); - }); - } - - /** - * A method to check if the value is a custom font size. - * - * @param {string} value - The value to check if it is a custom font size. - * @return {boolean} - True if the value is a custom font size, false otherwise. - */ - }, { - key: "changeSelectValue", - value: - /** - * A method to change the select value. - * - * @param {string} value - The value to change the select value for. - * @return {void} - */ - function changeSelectValue(value) { - var isCustomFonSize = frmTypographyComponent.isCustomFonSize(value); - Array.from(this.select.options).forEach(function (option) { - option.selected = option.value === 'custom' && isCustomFonSize || option.value === value; - }); - } - - /** - * A method to get the unit value wrapper element. - * - * @return {Element} - The unit value wrapper element. - */ - }, { - key: "getUnitValueWrapper", - value: function getUnitValueWrapper() { - this.unitValueWrapper = document.createElement('div'); - this.unitValueWrapper.classList.add('frm-unit-value'); - this.unitValueWrapper.append(this.getUnitValueInput()); - this.unitValueWrapper.append(this.getUnitTypeSelect()); - return this.unitValueWrapper; - } - - /** - * A method to get the unit value input element. - * - * @return {Element} - The unit value input element. - */ - }, { - key: "getUnitValueInput", - value: function getUnitValueInput() { - var _this3 = this; - this.unitValueInput = document.createElement('input'); - this.unitValueInput.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Font size value', 'formidable')); - if (null !== this.componentId) { - this.unitValueInput.id = "".concat(this.componentId, "-unit"); - } - if (null !== this.fieldName) { - this.unitValueInput.name = "".concat(this.fieldName, "[unit]"); - } - this.unitValueInput.type = 'text'; - this.unitValueInput.value = '' !== _classPrivateFieldGet(_defaultValue, this) ? "".concat(parseInt(_classPrivateFieldGet(_defaultValue, this), 10)) : ''; - this.unitValueInput.addEventListener('change', function (event) { - var value = '' !== event.target.value ? event.target.value + _this3.unitTypeSelect.value : ''; - _this3.changeSelectValue(value); - _classPrivateFieldGet(_onChange, _this3).call(_this3, value); - }); - return this.unitValueInput; - } - - /** - * A method to get the unit type select element. - * - * @return {Element} - The unit type select element. - */ - }, { - key: "getUnitTypeSelect", - value: function getUnitTypeSelect() { - var _this4 = this; - this.unitTypeSelect = document.createElement('select'); - this.unitTypeSelect.setAttribute('aria-label', (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Font size unit', 'formidable')); - if (null !== this.componentId) { - this.unitTypeSelect.id = "".concat(this.componentId, "-unit-type"); - } - if (null !== this.fieldName) { - this.unitTypeSelect.name = "".concat(this.fieldName, "[unit-type]"); - } - _classPrivateFieldGet(_unitTypeOptions, this).forEach(function (option) { - var opt = document.createElement('option'); - opt.value = option; - opt.textContent = option; - _this4.unitTypeSelect.append(opt); - }); - return this.unitTypeSelect; - } - - /** - * A method to get the hidden input element. - * - * @return {Element} - The hidden input element. - */ - }, { - key: "getHiddenInput", - value: function getHiddenInput() { - this.hiddenInput = document.createElement('input'); - this.hiddenInput.type = 'hidden'; - if (null !== this.fieldName) { - this.hiddenInput.name = "".concat(this.fieldName, "[value]"); - } - this.hiddenInput.value = _classPrivateFieldGet(_defaultValue, this); - return this.hiddenInput; - } - - /** - * A method to set the change event listener for the select element. - * - * @return {void} - The unit value. - */ - }, { - key: "afterViewInit", - value: function afterViewInit() { - var _this5 = this; - this.select.addEventListener('change', function () { - var value = frmTypographyComponent.getUnitValue(_this5.select.value); - _this5.unitValueInput.value = value.value; - _this5.hiddenInput.value = value.value + value.unit; - _classPrivateFieldGet(_onChange, _this5).call(_this5, _this5.hiddenInput.value); - _this5.unitTypeSelect.value = value.unit; - }); - } - - /** - * A method to get the unit value. - * - * @param {string} value - The value to get the unit value for. - * @return {Object} - The unit value. - */ - }, { - key: "onChange", - set: - /** - * A method to set the change event listener for the select element. - * - * @param {Function} callback - The callback function to call when the select element is changed. - * @return {void} - */ - function set(callback) { - if ('function' !== typeof callback) { - throw new TypeError("Expected a function, but received ".concat(_typeof(callback))); - } - _classPrivateFieldSet(_onChange, this, callback); - } - - /** - * A method to set dynamically the default value for the typography component. - * - * @param {string} value - The value to set dynamically the default value for. - * @return {void} - */ - }, { - key: "typographyDefaultValue", - set: function set(value) { - _classPrivateFieldSet(_defaultValue, this, value); - } - }], [{ - key: "isCustomFonSize", - value: function isCustomFonSize(value) { - return !['', '18px', '21px', '26px', '32px'].includes(value); - } - }, { - key: "getUnitValue", - value: function getUnitValue(value) { - var defaultValue = { - value: '', - unit: '' - }; - if (!value) { - return defaultValue; - } - var match = value.match(/^([\d.]+)(px|em|%)?$/); - if (!match) { - return defaultValue; - } - return { - value: parseInt(value, 10), - unit: match[2] || 'px' - }; - } - }]); -}(_frm_web_component__WEBPACK_IMPORTED_MODULE_0__.frmWebComponent); -var _instanceCount = { - _: 0 -}; - -/***/ }), - -/***/ "./js/src/web-components/frm-web-component.js": -/*!****************************************************!*\ - !*** ./js/src/web-components/frm-web-component.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmWebComponent: () => (/* binding */ frmWebComponent) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } -function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _wrapNativeSuper(t) { var r = "function" == typeof Map ? new Map() : void 0; return _wrapNativeSuper = function _wrapNativeSuper(t) { if (null === t || !_isNativeFunction(t)) return t; if ("function" != typeof t) throw new TypeError("Super expression must either be null or a function"); if (void 0 !== r) { if (r.has(t)) return r.get(t); r.set(t, Wrapper); } function Wrapper() { return _construct(t, arguments, _getPrototypeOf(this).constructor); } return Wrapper.prototype = Object.create(t.prototype, { constructor: { value: Wrapper, enumerable: !1, writable: !0, configurable: !0 } }), _setPrototypeOf(Wrapper, t); }, _wrapNativeSuper(t); } -function _construct(t, e, r) { if (_isNativeReflectConstruct()) return Reflect.construct.apply(null, arguments); var o = [null]; o.push.apply(o, e); var p = new (t.bind.apply(t, o))(); return r && _setPrototypeOf(p, r.prototype), p; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _isNativeFunction(t) { try { return -1 !== Function.toString.call(t).indexOf("[native code]"); } catch (n) { return "function" == typeof t; } } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -var frmWebComponent = /*#__PURE__*/function (_HTMLElement) { - function frmWebComponent() { - var _this; - _classCallCheck(this, frmWebComponent); - if ((this instanceof frmWebComponent ? this.constructor : void 0) === frmWebComponent) { - throw new Error('frmWebComponent is an abstract class and cannot be instantiated directly'); - } - _this = _callSuper(this, frmWebComponent); - if (_this.useShadowDom()) { - _this.attachShadow({ - mode: 'open' - }); - } - return _this; - } - _inherits(frmWebComponent, _HTMLElement); - return _createClass(frmWebComponent, [{ - key: "initOptions", - value: function initOptions() { - this.fieldName = this.getAttribute('name') || null; - this.defaultValue = this.getAttribute('value') || null; - this.componentId = this.getAttribute('id') || null; - } - }, { - key: "getLabelText", - value: function getLabelText() { - if (this._labelText) { - return this._labelText; - } - var label = this.querySelector('span.frm-component-label'); - if (null === label) { - return null; - } - return label.innerText; - } - }, { - key: "useShadowDom", - value: function useShadowDom() { - return 'false' !== this.getAttribute('data-shadow-dom'); - } - - /* - * Load the component style. - * @return string - */ - }, { - key: "loadStyle", - value: function loadStyle() { - var _frmGlobal; - var style = document.createElement('style'); - this.componentStyle = this.componentStyle.replace('--frm-plugin-url', ((_frmGlobal = frmGlobal) === null || _frmGlobal === void 0 ? void 0 : _frmGlobal.url) || ''); - style.textContent += this.componentStyle; - return style; - } - }, { - key: "getWrapper", - value: function getWrapper() { - return this.useShadowDom() ? this.shadowRoot : this; - } - - /* - * Render the component inside the shadow root. - * @return void - */ - }, { - key: "render", - value: function render() { - var _this2 = this; - var view = this.initView(); - if (!view) { - return; - } - var wrapper = this.getWrapper(); - wrapper.innerHTML = ''; - view.classList.add('frm-component'); - wrapper.append.apply(wrapper, _toConsumableArray(this.getViewItems(view))); - this.addLabelToView(view); - this.whenElementBecomesVisible().then(function () { - return _this2.afterViewInit(_this2); - }); - } - }, { - key: "addLabelToView", - value: function addLabelToView(view) { - var labelText = this.getLabelText(); - if (null === labelText || null === view) { - return; - } - var label = document.createElement('span'); - label.classList.add('frm-component-label'); - label.textContent = labelText; - view.prepend(label); - } - }, { - key: "getViewItems", - value: function getViewItems(view) { - return [this.loadStyle(), view].filter(function (item) { - return item !== null; - }); - } - - /** - * Waits for the element to become visible in the viewport. - * - * @return {Promise} - A promise that resolves when the element is visible. - */ - }, { - key: "whenElementBecomesVisible", - value: function whenElementBecomesVisible() { - var _this3 = this; - return new Promise(function (resolve) { - if (window.IntersectionObserver === undefined) { - requestAnimationFrame(function () { - return resolve(); - }); - return; - } - var observer = new IntersectionObserver(function (entries) { - entries.forEach(function (entry) { - // The element is in viewport and its visibility is greater than 0. - if (entry.isIntersecting && entry.intersectionRatio > 0) { - observer.disconnect(); - requestAnimationFrame(function () { - return resolve(); - }); - } - }); - }, { - threshold: 0.1 - }); - var element = _this3.useShadowDom() ? _this3.shadowRoot.host : _this3; - if (element) { - observer.observe(_this3); - } - }); - } - }, { - key: "frmLabel", - set: function set(text) { - this._labelText = text; - } - - /** - * After the view is initialized and the element/wrapper is visible in the viewport. - * - * @param {Element} wrapper - The wrapper element. - */ - }, { - key: "afterViewInit", - value: function afterViewInit(wrapper) { - // Override in child class. - } - - /** - * Constructs the view in the DOM. - * return {Element} - The wrapper element. - */ - }, { - key: "initView", - value: function initView() { - // Override in child class. - } - - /* - * Called by browser when the component is rendered to the DOM. - * @return void - */ - }, { - key: "connectedCallback", - value: function connectedCallback() { - this.initOptions(); - this.render(); - } - - /* - * Called by browser when the component is removed from the DOM. - * @return void - */ - }, { - key: "disconnectedCallback", - value: function disconnectedCallback() {} - }]); -}(/*#__PURE__*/_wrapNativeSuper(HTMLElement)); - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.css": -/*!*******************************************************************************************!*\ - !*** ./js/src/web-components/frm-border-radius-component/frm-border-radius-component.css ***! - \*******************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!********************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-border-radius-component/frm-border-radius-component.scss ***!\n \\********************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-border-radius-component .frm-border-radius-container {\n width: 100%;\n display: flex;\n justify-content: space-between;\n flex-wrap: wrap;\n}\n.frm-border-radius-component .frm-border-radius-container button {\n overflow: hidden;\n text-indent: -9999px;\n cursor: pointer;\n width: 36px;\n height: 36px;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n background: white;\n display: flex;\n justify-content: center;\n align-items: center;\n box-sizing: border-box;\n background: url('data:image/svg+xml,') no-repeat center center;\n background-size: 20px;\n}\n.frm-border-radius-component .frm-border-radius-container button.frm-active, .frm-border-radius-component .frm-border-radius-container button:hover {\n background-color: rgba(0, 0, 0, 0.05);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper {\n width: 100%;\n justify-content: space-between;\n flex-wrap: wrap;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden) {\n display: flex;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span {\n position: relative;\n display: block;\n overflow: hidden;\n width: calc(50% - 6px);\n height: 36px;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n margin-top: 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input {\n width: 100%;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding: 0 12px 0px 20px;\n box-sizing: border-box;\n border: none;\n text-align: right;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus {\n outline: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before {\n content: \"\";\n position: absolute;\n display: block;\n width: 12px;\n height: 12px;\n left: 12px;\n top: 0;\n bottom: 0;\n right: auto;\n margin: auto;\n background: url('data:image/svg+xml,') center center no-repeat;\n background-size: 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before {\n transform: rotate(180deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before {\n transform: rotate(0deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before {\n transform: rotate(90deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before {\n transform: rotate(-90deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper {\n width: calc(100% - 36px - 12px);\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n overflow: hidden;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper > * {\n border: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input {\n width: calc(100% - 44px);\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 12px;\n box-sizing: border-box;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus {\n outline: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select {\n text-align: right;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 44px;\n background: url(\"../../images/style/small-arrow.svg\") no-repeat;\n background-position: center right 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus {\n outline: none;\n}\n\n/*# sourceMappingURL=frm-border-radius-component.css.map*/"); - -/***/ }), - -/***/ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css": -/*!***************************************************************************************!*\ - !*** ./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css ***! - \***************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!****************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.scss ***!\n \\****************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-colorpicker-component .wp-picker-container button[type=button] {\n position: relative;\n height: 36px !important;\n background-image: none !important;\n background-color: #fff !important;\n overflow: hidden;\n}\n.frm-colorpicker-component .wp-picker-container button[type=button]:after {\n content: \"\";\n width: 20px;\n height: 20px;\n display: block;\n position: absolute;\n top: 0;\n right: 8px;\n bottom: 0;\n margin: auto;\n background: url(\"--frm-plugin-url/images/style/small-arrow.svg\") no-repeat;\n background-position: center;\n z-index: 10;\n}\n.frm-colorpicker-component .wp-picker-container button[type=button]:focus {\n border-color: var(--primary-500) !important;\n}\n.frm-colorpicker-component .wp-color-result-text {\n line-height: 36px !important;\n padding: 0 12px;\n border: 0;\n}\n.frm-colorpicker-component .color-alpha {\n width: 20px !important;\n height: 20px !important;\n border-radius: 50% !important;\n border: 1px solid rgb(208, 213, 221);\n top: 0;\n left: 0;\n bottom: 0;\n margin: auto;\n margin-left: 12px;\n}\n.frm-colorpicker-component .wp-picker-input-wrap input {\n width: calc(100% - 10px) !important;\n margin: 1px 5px;\n height: 32px;\n line-height: 32px;\n}\n\n/*# sourceMappingURL=frm-colorpicker-component.css.map*/"); - -/***/ }), - -/***/ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.css": -/*!*********************************************************************************!*\ - !*** ./js/src/web-components/frm-dropdown-component/frm-dropdown-component.css ***! - \*********************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!**********************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-dropdown-component/frm-dropdown-component.scss ***!\n \\**********************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-dropdown-component select {\n width: 100%;\n outline: 0;\n box-shadow: var(--box-shadow-xs);\n border-radius: var(--small-radius);\n padding: 5px var(--gap-lg) 5px 14px;\n border-color: var(--grey-300);\n color: var(--grey-800);\n font-size: var(--text-md);\n margin: 0;\n line-height: var(--leading);\n border-width: 1px;\n border-style: solid;\n background-position: center 5px;\n background: transparent url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E\") no-repeat right 8px top 50%;\n background-color: #fff;\n appearance: none;\n -webkit-appearance: none;\n -moz-appearance: none;\n}\n.frm-dropdown-component select:focus {\n border-color: var(--primary-500);\n box-shadow: none;\n}\n\n/*# sourceMappingURL=frm-dropdown-component.css.map*/"); - -/***/ }), - -/***/ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.css": -/*!*****************************************************************************************!*\ - !*** ./js/src/web-components/frm-range-slider-component/frm-range-slider-component.css ***! - \*****************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!******************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-range-slider-component/frm-range-slider-component.scss ***!\n \\******************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Sliders component styles\n */\n.frm-style-component .frm-slider-container {\n width: calc(100% - 91px);\n display: flex;\n align-items: center;\n color: rgb(29, 41, 57);\n}\n.frm-style-component .frm-slider-container svg.frmsvg {\n color: currentColor;\n margin-right: 8px;\n margin-left: -5px;\n position: relative;\n z-index: 15;\n}\n\n.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover {\n color: rgb(65, 153, 253);\n cursor: pointer;\n}\n\n.frm-style-component .frm-slider-container .frm-slider-active-track {\n display: block;\n height: 100%;\n width: 0;\n position: relative;\n border-radius: 200px;\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track,\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet {\n background: rgb(65, 153, 253);\n box-shadow: 0 1.88px 4px -1px rgba(16, 24, 40, 0.03), 0 6px 8px -2px rgba(16, 24, 40, 0.08);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet {\n position: absolute;\n display: block;\n width: 16px;\n height: 16px;\n border-radius: 50%;\n transform: translateX(15px);\n cursor: grab;\n right: 0;\n top: 0;\n bottom: 0;\n margin: auto;\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label {\n position: absolute;\n display: block;\n width: 48px;\n height: 36px;\n background: rgb(16, 24, 40);\n color: white;\n font-weight: 400;\n font-size: var(--text-sm);\n line-height: 36px;\n border-radius: var(--small-radius);\n transform: translate(-18px, -42px) scale3d(0.7, 1, 1);\n opacity: 0;\n z-index: -2;\n pointer-events: none;\n text-align: center;\n user-select: none;\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label {\n z-index: 12;\n transform: translate(-18px, -42px) scale3d(1, 1, 1);\n opacity: 1;\n transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before {\n content: \"\";\n display: block;\n position: absolute;\n width: 18px;\n height: 18px;\n border-radius: 50%;\n left: 0;\n top: 0;\n transform: translate(-5px, -5px) scale3d(0.7, 0.7, 1);\n border: 4px solid rgb(65, 153, 253);\n opacity: 0;\n transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before {\n opacity: 0.5;\n transform: translate(-5px, -5px) scale3d(1, 1, 1);\n transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after {\n content: \"\";\n position: absolute;\n display: block;\n width: 180%;\n height: 200%;\n border-radius: 50%;\n left: 0;\n top: 0;\n transform: translate(-24%, -24%);\n}\n\n.frm-style-component .frm-slider-value {\n width: 86px;\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n}\n.frm-style-component .frm-slider-value > * {\n border: none;\n}\n.frm-style-component .frm-slider-value input {\n width: 40px;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 12px;\n box-sizing: border-box;\n}\n.frm-style-component .frm-slider-value select {\n text-align: right;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 44px;\n background: url(\"../../images/style/small-arrow.svg\") no-repeat;\n background-position: center right 12px;\n padding-right: 24px !important;\n}\n.frm-style-component .frm-slider-value select.frm-single-unit {\n pointer-events: none;\n background-image: none;\n padding-right: 12px !important;\n}\n.frm-style-component .frm-slider {\n display: block;\n width: calc(100% - 5px);\n height: 4px;\n background: rgb(234, 236, 240);\n border-radius: 200px;\n cursor: pointer;\n}\n\n.frm-slider-component .frm-independent-slider-field {\n margin-top: 10px;\n}\n.frm-slider-component.frm-disabled .frm-slider-container {\n pointer-events: none;\n opacity: 0.5;\n}\n.frm-slider-component.frm-disabled .frm-slider-value input[type=text] {\n width: 28px;\n}\n.frm-slider-component.frm-disabled .frm-slider-value select {\n width: 56px;\n}\n.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text] {\n width: 56px;\n}\n.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select {\n width: 28px;\n}\n\n.frm-style-component .frm-slider-component.frm-has-multiple-values {\n margin-bottom: 10px;\n}\n\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-component .frmsvg {\n width: 18px;\n height: 18px;\n}\n.frm-component .frm-sliders-container {\n width: 100%;\n}\n.frm-component .frm-group-sliders .frm-slider-component {\n margin-top: 5px;\n}\n\n/*# sourceMappingURL=frm-range-slider-component.css.map*/"); - -/***/ }), - -/***/ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css": -/*!*******************************************************************************************!*\ - !*** ./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css ***! - \*******************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!********************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.scss ***!\n \\********************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-tabs-wrapper {\n position: relative;\n overflow: hidden;\n}\n.frm-tabs-wrapper .frm-tabs-navigator {\n margin: 0;\n padding: 0;\n display: flex;\n gap: var(--gap-xs);\n justify-content: space-between;\n align-items: center;\n background: rgb(242, 244, 247);\n border-radius: var(--small-radius);\n box-sizing: border-box;\n height: 44px;\n position: relative;\n z-index: 2;\n}\n.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item {\n flex: 1;\n text-align: center;\n cursor: pointer;\n}\n.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background {\n display: block;\n height: 100%;\n background: white;\n position: absolute;\n top: 0;\n left: 0;\n z-index: 1;\n}\n\n.frm-tabs-navs {\n padding: 0;\n min-height: 44px;\n}\n.frm-tabs-navs ul {\n margin: 0;\n height: var(--h-md);\n position: relative;\n display: flex;\n justify-content: space-between;\n list-style-type: none;\n padding: 0px;\n}\n.frm-tabs-navs ul li,\n.frm-tabs-navs ul li a {\n color: var(--grey-500);\n font-weight: 500;\n font-size: var(--text-sm);\n line-height: 28px;\n}\n.frm-tabs-navs ul li {\n flex: 1;\n height: 28px;\n text-align: center;\n margin-top: var(--gap-xs);\n margin-bottom: 0;\n cursor: pointer;\n}\n\n.frm-tabs-navs ul li.frm-active, .frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a {\n color: var(--grey-900);\n}\n\n.frm-tabs-navs ul li:first-child {\n margin-left: var(--gap-xs);\n}\n\n.frm-tabs-navs ul li:last-child {\n margin-right: var(--gap-xs);\n}\n\n.frm-tabs-delimiter {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n background: rgb(242, 244, 247);\n height: 44px;\n margin: 0;\n border-radius: var(--small-radius);\n}\n.frm-tabs-delimiter .frm-tabs-active-underline {\n height: 28px;\n background: white;\n position: absolute;\n left: 0;\n bottom: 8px;\n transition: 0.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n border-radius: var(--small-radius);\n box-shadow: var(--button-shadow);\n display: none;\n}\n\n.frm-tabs-container {\n position: relative;\n overflow: hidden;\n margin-top: var(--gap-md);\n height: 100%;\n}\n\n.frm-tabs-container .frm-tabs-slide-track {\n display: flex;\n transition: 0.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);\n}\n\n.frm-tabs-slide-track > div {\n flex: 0 0 100%;\n opacity: 0;\n transition: 0.25s opacity linear;\n position: relative;\n height: auto;\n max-height: unset;\n overflow: hidden;\n box-sizing: border-box;\n}\n\n.frm-tabs-slide-track > div > div {\n overflow: auto;\n position: relative;\n width: 100%;\n padding: 0;\n box-sizing: border-box;\n}\n\n.frm-tabs-slide-track > div > div:first-child {\n height: 100%;\n}\n\n.frm-tabs-slide-track > div.frm-active {\n opacity: 1;\n transition: 0.35s opacity linear;\n}\n\n/*# sourceMappingURL=frm-tab-navigator-component.css.map*/"); - -/***/ }), - -/***/ "./js/src/web-components/frm-typography-component/frm-typography-component.css": -/*!*************************************************************************************!*\ - !*** ./js/src/web-components/frm-typography-component/frm-typography-component.css ***! - \*************************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("/*!**************************************************************************************************************************************************************************************************************************************************************************!*\\\n !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-typography-component/frm-typography-component.scss ***!\n \\**************************************************************************************************************************************************************************************************************************************************************************/\n/**\n * Base - Variables\n */\n:root,\n.frm-white-body,\n.frm_wrap {\n --grey-900: #101828;\n --grey-800: #1d2939;\n --grey-700: #344054;\n --grey-600: #475467;\n --grey-500: #667085; /* Roughly 65% opacity */\n --grey-400: #98a2b3;\n --grey-300: #d0d5dd;\n --grey-200: #eaecf0;\n --grey-100: #f2f4f7;\n --grey-50: #f9fafb;\n --grey-25: #fcfcfd;\n --dark-grey: var(--grey-700); /* Deprecated */\n --medium-grey: rgba(40, 47, 54, 0.65);\n --grey: var(--grey-500); /* Deprecated */\n --grey-border: var(--grey-300); /* Deprecated */\n --lightest-grey: rgb(250, 250, 250);\n --sidebar-color: var(--grey-50);\n --sidebar-hover: var(--grey-200);\n --primary-700: #2b66a9;\n --primary-500: #4199fd;\n --primary-300: #80bbfe;\n --primary-200: #c0ddfe;\n --primary-50: #ecf5ff;\n --primary-25: #f5faff;\n --primary-color: var(--primary-500); /* Deprecated */\n --primary-hover: var(--primary-700); /* Deprecated */\n --light-blue: var(--primary-25); /* Deprecated */\n --blue-border: rgb(188, 224, 253);\n --error-700: #b42318;\n --error-500: #f04438;\n --error-300: #fecdca;\n --error-100: #fee4e2;\n --error-25: #fff5f4;\n --green: rgb(63, 172, 37);\n --orange: #f15a24;\n --warning-500: #f79009;\n --pink: rgb(226, 42, 110);\n --purple: rgb(141, 53, 245);\n --success-900: #054f31;\n --success-800: #065f46;\n --success-500: #12b76a;\n --success-100: #d1fae5;\n --success-200: #a6f4c5;\n --success-50: #ecfdf3;\n --success-25: #f6fef9;\n --border-radius: 35px;\n --small-radius: 8px;\n --medium-radius: 16px;\n --small-sidebar: 275px;\n --medium-sidebar: 350px;\n --big-sidebar: 390px;\n --biggest-sidebar: 450px;\n --text-xs: 12px;\n --text-sm: 14px;\n --text-md: 16px;\n --text-lg: 18px;\n --text-xl: 20px;\n --h-xs: 24px;\n --h-sm: 30px;\n --h-md: 36px;\n --leading: 1.5;\n --gap-2xs: 4px;\n --gap-xs: 8px;\n --gap-sm: 16px;\n --gap-md: 24px;\n --gap-lg: 32px;\n --gap-xl: 40px;\n --gap-2xl: 48px;\n --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);\n --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);\n --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);\n --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);\n --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);\n /* Override front-end CSS */\n --check-label-color: var(--grey-700);\n}\n\n.frm_hidden {\n display: none;\n}\n\n.frm-component:not(.frm-tabs-wrapper) {\n display: flex;\n justify-content: space-between;\n align-items: center;\n}\n.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-typography-component .frm-typography-container {\n display: flex;\n justify-content: space-between;\n width: 100%;\n}\n.frm-typography-component .frm-typography-container select {\n width: calc(70% - 6px);\n outline: 0;\n box-shadow: var(--box-shadow-xs);\n border-radius: var(--small-radius);\n padding: 5px 14px;\n border-color: var(--grey-300);\n color: var(--grey-800);\n font-size: var(--text-md);\n margin: 0;\n background-color: #fff;\n line-height: var(--leading);\n border-width: 1px;\n border-style: solid;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value {\n width: 28%;\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n overflow: hidden;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value > * {\n border: none;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value input {\n width: 32px;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 8px;\n box-sizing: border-box;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value input:focus {\n outline: none;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value select {\n text-align: left;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 36px;\n background: url(\"../../images/style/small-arrow.svg\") no-repeat;\n background-position: center right 12px;\n}\n.frm-typography-component .frm-typography-container .frm-unit-value select:focus {\n outline: none;\n}\n\n/*# sourceMappingURL=frm-typography-component.css.map*/"); - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. -(() => { -"use strict"; -/*!****************************************!*\ - !*** ./js/src/web-components/index.js ***! - \****************************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _frm_tab_navigator_component_frm_tab_navigator_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./frm-tab-navigator-component/frm-tab-navigator-component */ "./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.js"); -/* harmony import */ var _frm_colorpicker_component_frm_colorpicker_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./frm-colorpicker-component/frm-colorpicker-component */ "./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.js"); -/* harmony import */ var _frm_range_slider_component_frm_range_slider_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./frm-range-slider-component/frm-range-slider-component */ "./js/src/web-components/frm-range-slider-component/frm-range-slider-component.js"); -/* harmony import */ var _frm_dropdown_component_frm_dropdown_component__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./frm-dropdown-component/frm-dropdown-component */ "./js/src/web-components/frm-dropdown-component/frm-dropdown-component.js"); -/* harmony import */ var _frm_typography_component_frm_typography_component__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./frm-typography-component/frm-typography-component */ "./js/src/web-components/frm-typography-component/frm-typography-component.js"); -/* harmony import */ var _frm_border_radius_component_frm_border_radius_component__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./frm-border-radius-component/frm-border-radius-component */ "./js/src/web-components/frm-border-radius-component/frm-border-radius-component.js"); - - - - - - -customElements.define('frm-tab-navigator-component', _frm_tab_navigator_component_frm_tab_navigator_component__WEBPACK_IMPORTED_MODULE_0__.frmTabNavigatorComponent); -customElements.define('frm-colorpicker-component', _frm_colorpicker_component_frm_colorpicker_component__WEBPACK_IMPORTED_MODULE_1__.frmColorpickerComponent); -customElements.define('frm-range-slider-component', _frm_range_slider_component_frm_range_slider_component__WEBPACK_IMPORTED_MODULE_2__.frmRangeSliderComponent); -customElements.define('frm-dropdown-component', _frm_dropdown_component_frm_dropdown_component__WEBPACK_IMPORTED_MODULE_3__.frmDropdownComponent); -customElements.define('frm-typography-component', _frm_typography_component_frm_typography_component__WEBPACK_IMPORTED_MODULE_4__.frmTypographyComponent); -customElements.define('frm-border-radius-component', _frm_border_radius_component_frm_border_radius_component__WEBPACK_IMPORTED_MODULE_5__.frmBorderRadiusComponent); -})(); - -/******/ })() -; -//# sourceMappingURL=formidable-web-components.js.map \ No newline at end of file +(()=>{var e={8616:e=>{e.exports=function(e,t){var n,r,i=0;function o(){var o,a,s=n,l=arguments.length;e:for(;s;){if(s.args.length===arguments.length){for(a=0;a{var r;!function(){"use strict";var i={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function o(e){return function(e,t){var n,r,a,s,l,u,c,p,d,f=1,m=e.length,h="";for(r=0;r=0),s.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,s.width?parseInt(s.width):0);break;case"e":n=s.precision?parseFloat(n).toExponential(s.precision):parseFloat(n).toExponential();break;case"f":n=s.precision?parseFloat(n).toFixed(s.precision):parseFloat(n);break;case"g":n=s.precision?String(Number(n.toPrecision(s.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=s.precision?n.substring(0,s.precision):n;break;case"t":n=String(!!n),n=s.precision?n.substring(0,s.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=s.precision?n.substring(0,s.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=s.precision?n.substring(0,s.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}i.json.test(s.type)?h+=n:(!i.number.test(s.type)||p&&!s.sign?d="":(d=p?"+":"-",n=n.toString().replace(i.sign,"")),u=s.pad_char?"0"===s.pad_char?"0":s.pad_char.charAt(1):" ",c=s.width-(d+n).length,l=s.width&&c>0?u.repeat(c):"",h+=s.align?d+n+l:"0"===u?d+l+n:l+d+n)}return h}(function(e){if(s[e])return s[e];for(var t,n=e,r=[],o=0;n;){if(null!==(t=i.text.exec(n)))r.push(t[0]);else if(null!==(t=i.modulo.exec(n)))r.push("%");else{if(null===(t=i.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){o|=1;var a=[],l=t[2],u=[];if(null===(u=i.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(u[1]);""!==(l=l.substring(u[0].length));)if(null!==(u=i.key_access.exec(l)))a.push(u[1]);else{if(null===(u=i.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(u[1])}t[2]=a}else o|=2;if(3===o)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}n=n.substring(t[0].length)}return s[e]=r}(e),arguments)}function a(e,t){return o.apply(null,[e].concat(t||[]))}var s=Object.create(null);"undefined"!=typeof window&&(window.sprintf=o,window.vsprintf=a,void 0===(r=function(){return{sprintf:o,vsprintf:a}}.call(t,n,t,e))||(e.exports=r))}()}},t={};function n(r){var i=t[r];if(void 0!==i)return i.exports;var o=t[r]={exports:{}};return e[r](o,o.exports,n),o.exports}n.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return n.d(t,{a:t}),t},n.d=(e,t)=>{for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(e,t){for(var n=0;n li"),this.slideTrackLine=this.wrapper.querySelector(".frm-tabs-active-underline"),this.slideTrack=this.wrapper.querySelector(".frm-tabs-slide-track"),this.slides=this.wrapper.querySelectorAll(".frm-tabs-slide-track > div"),this.isRTL="rtl"===document.documentElement.dir||"rtl"===document.body.dir,this.resizeObserver=null,this.init()))},(n=[{key:"init",value:function(){var e=this;null!==this.wrapper&&this.navs.length&&null!==this.slideTrackLine&&null!==this.slideTrack&&this.slides.length&&(this.navs.forEach(function(t,n){t.addEventListener("click",function(t){return e.onNavClick(t,n)}),t.classList.contains("frm-active")&&e.initSlideTrackUnderline(t)}),this.slideTrackLine.style.display="block",this.setupScrollbarObserver(),window.addEventListener("beforeunload",this.cleanupObservers))}},{key:"onNavClick",value:function(e,t){var n=e.currentTarget;e.preventDefault(),this.removeActiveClassnameFromNavs(),n.classList.add("frm-active"),this.initSlideTrackUnderline(n),this.changeSlide(t);var r,i,o=n.querySelector("a");o&&"frm_insert_fields_tab"===o.id&&!o.closest("#frm_adv_info")&&(null===(r=window.frmAdminBuild)||void 0===r||null===(i=r.clearSettingsBox)||void 0===i||i.call(r))}},{key:"initSlideTrackUnderline",value:function(e){var t=void 0!==e?e:this.navs.filter(function(e){return e.classList.contains("frm-active")});this.positionUnderlineIndicator(t)}},{key:"setupScrollbarObserver",value:function(){var e=this,t=document.querySelector(".frm-scrollbar-wrapper, .styling_settings")||document.body;t&&"ResizeObserver"in window&&(this.resizeObserver=new ResizeObserver(function(){var t=e.wrapper.querySelector(".frm-tabs-navs ul > li.frm-active");t&&e.positionUnderlineIndicator(t)}),this.resizeObserver.observe(t))}},{key:"cleanupObservers",value:function(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null)}},{key:"positionUnderlineIndicator",value:function(e){var t=this;requestAnimationFrame(function(){var n=t.isRTL?-(e.parentElement.offsetWidth-e.offsetLeft-e.offsetWidth):e.offsetLeft;t.slideTrackLine.style.transform="translateX(".concat(n,"px)"),t.slideTrackLine.style.width="".concat(e.clientWidth,"px")})}},{key:"changeSlide",value:function(e){this.removeActiveClassnameFromSlides();var t=0==e?"0px":"calc( ( ".concat(100*e,"% + ").concat(parseInt(this.flexboxSlidesGap,10)*e,"px ) * ").concat(this.isRTL?1:-1," )");"0px"!==t?this.slideTrack.style.transform="translateX(".concat(t,")"):this.slideTrack.style.removeProperty("transform"),e in this.slides&&this.slides[e].classList.add("frm-active")}},{key:"removeActiveClassnameFromSlides",value:function(){this.slides.forEach(function(e){return e.classList.remove("frm-active")})}},{key:"removeActiveClassnameFromNavs",value:function(){this.navs.forEach(function(e){return e.classList.remove("frm-active")})}}])&&t(e.prototype,n),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,n}();function o(e){return o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},o(e)}function a(e,t){(null==t||t>e.length)&&(t=e.length);for(var n=0,r=Array(t);n0&&(n.disconnect(),requestAnimationFrame(function(){return t()}))})},{threshold:.1});(e.useShadowDom()?e.shadowRoot.host:e)&&n.observe(e)}else requestAnimationFrame(function(){return t()})})}},{key:"frmLabel",set:function(e){this._labelText=e}},{key:"afterViewInit",value:function(e){}},{key:"initView",value:function(){}},{key:"connectedCallback",value:function(){this.initOptions(),this.render()}},{key:"disconnectedCallback",value:function(){}}])&&s(n.prototype,r),Object.defineProperty(n,"prototype",{writable:!1}),n;var n,r}(u(HTMLElement));function m(e){return m="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},m(e)}function h(e,t){for(var n=0;n span.frm-component-label {\n font-weight: 500;\n font-size: var(--text-sm) !important;\n color: var(--grey-900) !important;\n width: 40% !important;\n display: block !important;\n margin-right: 12px !important;\n}\n\n.frm-colorpicker-component .wp-picker-container button[type=button] {\n position: relative;\n height: 36px !important;\n background-image: none !important;\n background-color: #fff !important;\n overflow: hidden;\n}\n.frm-colorpicker-component .wp-picker-container button[type=button]:after {\n content: "";\n width: 20px;\n height: 20px;\n display: block;\n position: absolute;\n top: 0;\n right: 8px;\n bottom: 0;\n margin: auto;\n background: url("--frm-plugin-url/images/style/small-arrow.svg") no-repeat;\n background-position: center;\n z-index: 10;\n}\n.frm-colorpicker-component .wp-picker-container button[type=button]:focus {\n border-color: var(--primary-500) !important;\n}\n.frm-colorpicker-component .wp-color-result-text {\n line-height: 36px !important;\n padding: 0 12px;\n border: 0;\n}\n.frm-colorpicker-component .color-alpha {\n width: 20px !important;\n height: 20px !important;\n border-radius: 50% !important;\n border: 1px solid rgb(208, 213, 221);\n top: 0;\n left: 0;\n bottom: 0;\n margin: auto;\n margin-left: 12px;\n}\n.frm-colorpicker-component .wp-picker-input-wrap input {\n width: calc(100% - 10px) !important;\n margin: 1px 5px;\n height: 32px;\n line-height: 32px;\n}\n\n/*# sourceMappingURL=frm-colorpicker-component.css.map*/',e.attachInternals(),e}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),Object.defineProperty(e,"prototype",{writable:!1}),t&&j(e,t)}(t,e),n=t,(r=[{key:"initView",value:function(){var e=document.createElement("div");return e.classList.add("frm-colorpicker-component","frm-colorpicker"),e.append(this.getInput()),e}},{key:"getInput",value:function(){var e=this;return this.input.type="text",this.input.classList.add("hex"),null!==this.fieldName&&(this.input.name=this.fieldName),null!==V(A,this)&&(this.input.value=V(A,this)),null!==this.componentId&&(this.input.id=this.componentId),this.input.addEventListener("blur",function(t){return V(D,e).call(e,t,null)}),this.input}},{key:"useShadowDom",value:function(){return!1}},{key:"afterViewInit",value:function(){var e=this,t={defaultColor:V(A,this)};"function"==typeof V(D,this)&&(t.change=function(t,n){return setTimeout(function(){return V(D,e).call(e,t,n)},20)}),jQuery(this.input).wpColorPicker(t)}},{key:"color",get:function(){return jQuery(this.input).wpColorPicker("color")},set:function(e){_(A,this,e),this.input.value=e}},{key:"onChange",set:function(e){if("function"!=typeof e)throw new TypeError("Expected a function, but received ".concat(w(e)));_(D,this,e)}}])&&k(n.prototype,r),Object.defineProperty(n,"prototype",{writable:!1}),n;var n,r}(f);P=M,C=!0,(T=O(T="formAssociated"))in P?Object.defineProperty(P,T,{value:C,enumerable:!0,configurable:!0,writable:!0}):P[T]=C;var z=window.frmColorpickerProComponent?window.frmColorpickerProComponent(M):M,R=window.frmGlobal;function W(e){return W="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},W(e)}function B(e,t){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:[],r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.loadedByWebComponent=n.length>0,this.sliderElements=n.length>0?n:document.querySelectorAll(".frm-slider-component"),this.settings=r,0!==this.sliderElements.length){this.sliderBulletWidth=16,this.sliderMarginRight=5,this.eventsChange=[];var i=frmDom.util.debounce;this.valueChangeDebouncer=i(function(e){return t.triggerValueChange(e)},25),this.initOptions(),this.init()}}return function(e,t,n){return t&&N(e.prototype,t),n&&N(e,n),Object.defineProperty(e,"prototype",{writable:!1}),e}(e,[{key:"initOptions",value:function(){var e=this;this.options=[],this.sliderElements.forEach(function(t,n){var r=t.classList.contains("frm-has-multiple-values")?t.closest(".frm-style-component"):t,i=e.settings.steps||(t.dataset.steps?JSON.parse(t.dataset.steps):null);e.options.push({dragging:!1,startX:0,translateX:0,maxValue:parseInt(t.dataset.maxValue,10),element:t,index:n,value:0,steps:i,dependentUpdater:r.classList.contains("frm-style-dependent-updater-component")?new F(r):null})})}},{key:"init",value:function(){this.initDraggable(),this.loadedByWebComponent?this.initSlidersPositionInsideWebComponent():this.initSlidersPosition()}},{key:"initDraggable",value:function(){var t=this;this.sliderElements.forEach(function(n,r){t.eventsChange[r]=new Event("change",{bubbles:!0,cancelable:!0});var i=n.querySelector(".frm-slider-bullet"),o=n.querySelector('.frm-slider-value input[type="text"]');o.addEventListener("change",function(e){var i=n.querySelector("select").value;t.getMaxValue(i,r)1&&void 0!==arguments[1]?arguments[1]:null;if(!t.classList.contains("frm-disabled")){var r=null!==n?n:this.getSliderIndex(t),i=t.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth,o=parseInt(t.querySelector('.frm-slider-value input[type="text"]').value,10),a=t.querySelector("select").value,s=this.options[r].steps,l=Math.ceil(o/this.options[r].maxValue*i);"%"===a?l=Math.round(i*o/100):s&&s.length>0&&(l=e.calculateDeltaXFromSteps(o,s,i)),t.querySelector(".frm-slider-active-track").style.width="".concat(l,"px"),this.options[r].translateX=l,this.options[r].value=o+a}}},{key:"initChildSlidersWidth",value:function(e,t,n,r){var i=this;(e.classList.contains("frm-has-independent-fields")||e.classList.contains("frm-has-multiple-values"))&&(e.classList.contains("frm-has-independent-fields")?e.querySelectorAll(".frm-independent-slider-field"):this.getSliderGroupItems(e)).forEach(function(e,o){e.querySelector(".frm-slider-active-track").style.width="".concat(t,"px"),i.options[n+o+1].translateX=t,i.options[n+o+1].value=r})}},{key:"getSliderIndex",value:function(e){return this.options.filter(function(t){return t.element===e})[0].index}},{key:"moveTracker",value:function(t,n){if(this.options[n].dragging){var r=t.clientX-this.options[n].startX,i=this.sliderElements[n],o=i.querySelector(".frm-slider").offsetWidth-this.sliderBulletWidth;r=Math.max(r,0),r=Math.min(r,o);var a=i.querySelector("select").value,s=e.calculateValue(o,r,this.getMaxValue(a,n),this.options[n].steps);i.querySelector('.frm-slider-value input[type="text"]').value=s,i.querySelector(".frm-slider-bullet .frm-slider-value-label").innerText=s,i.querySelector(".frm-slider-active-track").style.width="".concat(r,"px"),this.initChildSlidersWidth(i,r,n,s+a),this.options[n].translateX=r,this.options[n].value=s+a,this.options[n].fullValue=this.updateValue(i,this.options[n].value),this.valueChangeDebouncer(n)}}},{key:"getMaxValue",value:function(e,t){return"%"===e?100:this.options[t].maxValue}},{key:"enableDragging",value:function(e,t){e.target.classList.add("frm-dragging"),this.options[t].dragging=!0,this.options[t].startX=e.clientX-this.options[t].translateX}},{key:"disableDragging",value:function(e){!1!==this.options[e].dragging&&(this.sliderElements[e].querySelector(".frm-slider-bullet").classList.remove("frm-dragging"),this.options[e].dragging=!1,this.triggerValueChange(e))}},{key:"triggerValueChange",value:function(e){var t=this;if(null===this.options[e].dependentUpdater){var n=this.sliderElements[e].classList.contains("frm-has-multiple-values")?this.sliderElements[e].closest(".frm-style-component").querySelector('input[type="hidden"]'):this.sliderElements[e].querySelectorAll('.frm-slider-value input[type="hidden"]');n instanceof NodeList?n.forEach(function(n){n.dispatchEvent(t.eventsChange[e])}):n.dispatchEvent(this.eventsChange[e])}else this.options[e].dependentUpdater.updateAllDependentElements(this.options[e].fullValue)}},{key:"updateValue",value:function(e,t){var n=this;if(e.classList.contains("frm-base-font-size")){var r=document.querySelector('input[name="frm_style_setting[post_content][use_base_font_size]"]');r&&(r.value="true")}if(e.classList.contains("frm-has-multiple-values")){var i=e.closest(".frm-style-component").querySelector('input[type="hidden"]'),o=i.value.split(" "),a=e.dataset.type;switch(o[2]||(o[2]="0px"),o[3]||(o[3]="0px"),a){case"vertical":o[0]=t,o[2]=t;break;case"horizontal":o[1]=t,o[3]=t;break;case"top":o[0]=t;break;case"bottom":o[2]=t;break;case"left":o[3]=t;break;case"right":o[1]=t}var s=o.join(" ");return i.value=s,this.getSliderGroupItems(e).forEach(function(e){var r=n.getUnitMeasureFromValue(t);e.querySelector('.frm-slider-value input[type="text"]').value=parseInt(t,10),e.querySelector("select").value=r}),s}if(e.classList.contains("frm-has-independent-fields")){var l=e.querySelectorAll('.frm-slider-value input[type="hidden"]'),u=e.querySelectorAll('.frm-slider-value input[type="text"]');return l.forEach(function(e,n){e.value=t,u[n+1].value=parseInt(t,10)}),t}return e.querySelector('.frm-slider-value input[type="hidden"]').value=t,t}},{key:"getUnitMeasureFromValue",value:function(e){return["%","px","em"].find(function(t){return e.includes(t)})||""}}],[{key:"maybeDisableUnitDropdown",value:function(e){var t=e.querySelector("select");t&&1>=Array.from(t.options).filter(function(e){return""!==e.value}).length&&(t.classList.add("frm-single-unit"),t.addEventListener("mousedown",function(e){return e.preventDefault()}))}},{key:"calculateDeltaXFromSteps",value:function(t,n,r){var i=n.indexOf(t);if(-1===i){var o=e.snapToStep(t,n),a=n.indexOf(o);return Math.round(a/(n.length-1)*r)}return Math.round(i/(n.length-1)*r)}},{key:"calculateValue",value:function(e,t,n){var r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null;if(r&&r.length>0){var i=t/e,o=Math.round(i*(r.length-1));return r[Math.max(0,Math.min(o,r.length-1))]}var a=Math.round(t/e*n);return Math.min(a,n)}},{key:"snapToStep",value:function(e,t){for(var n=t[0],r=Math.abs(e-n),i=1;i":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},G=["(","?"],$={")":["("],":":["?","?:"]},J=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var te={"!":function(e){return!e},"*":function(e,t){return e*t},"/":function(e,t){return e/t},"%":function(e,t){return e%t},"+":function(e,t){return e+t},"-":function(e,t){return e-t},"<":function(e,t){return e":function(e,t){return e>t},">=":function(e,t){return e>=t},"==":function(e,t){return e===t},"!=":function(e,t){return e!==t},"&&":function(e,t){return e&&t},"||":function(e,t){return e||t},"?:":function(e,t,n){if(e)throw t;return n}};var ne={contextDelimiter:"",onMissingKey:null};function re(e,t){var n;for(n in this.data=e,this.pluralForms={},this.options={},ne)this.options[n]=void 0!==t&&n in t?t[n]:ne[n]}function ie(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,r)}return n}function oe(e){for(var t=1;t=0||X[i]3&&void 0!==arguments[3]?arguments[3]:10,a=e[t];if(ue(n)&&le(r))if("function"==typeof i)if("number"==typeof o){var s={callback:i,priority:o,namespace:r};if(a[n]){var l,u=a[n].handlers;for(l=u.length;l>0&&!(o>=u[l-1].priority);l--);l===u.length?u[l]=s:u.splice(l,0,s),a.__current.forEach(function(e){e.name===n&&e.currentIndex>=l&&e.currentIndex++})}else a[n]={handlers:[s],runs:0};"hookAdded"!==n&&e.doAction("hookAdded",n,r,i,o)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},pe=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,i){var o=e[t];if(ue(r)&&(n||le(i))){if(!o[r])return 0;var a=0;if(n)a=o[r].handlers.length,o[r]={runs:o[r].runs,handlers:[]};else for(var s=o[r].handlers,l=function(e){s[e].namespace===i&&(s.splice(e,1),a++,o.__current.forEach(function(t){t.name===r&&t.currentIndex>=e&&t.currentIndex--}))},u=s.length-1;u>=0;u--)l(u);return"hookRemoved"!==r&&e.doAction("hookRemoved",r,i),a}}},de=function(e,t){return function(n,r){var i=e[t];return void 0!==r?n in i&&i[n].handlers.some(function(e){return e.namespace===r}):n in i}},fe=function(e,t){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var i=e[t];i[r]||(i[r]={handlers:[],runs:0}),i[r].runs++;for(var o=i[r].handlers,a=arguments.length,s=new Array(a>1?a-1:0),l=1;l1&&void 0!==arguments[1]?arguments[1]:"default";r.data[t]=oe(oe(oe({},ae),r.data[t]),e),r.data[t][""]=oe(oe({},ae[""]),r.data[t][""])},s=function(e,t){a(e,t),o()},l=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",t=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,i=arguments.length>3?arguments[3]:void 0,o=arguments.length>4?arguments[4]:void 0;return r.data[e]||a(void 0,e),r.dcnpgettext(e,t,n,i,o)},u=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},c=function(e,t,r){var i=l(r,t,e);return n?(i=n.applyFilters("i18n.gettext_with_context",i,e,t,r),n.applyFilters("i18n.gettext_with_context_"+u(r),i,e,t,r)):i};if(n){var p=function(e){se.test(e)&&o()};n.addAction("hookAdded","core/i18n",p),n.addAction("hookRemoved","core/i18n",p)}return{getLocaleData:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[e]},setLocaleData:s,resetLocaleData:function(e,t){r.data={},r.pluralForms={},s(e,t)},subscribe:function(e){return i.add(e),function(){return i.delete(e)}},__:function(e,t){var r=l(t,void 0,e);return n?(r=n.applyFilters("i18n.gettext",r,e,t),n.applyFilters("i18n.gettext_"+u(t),r,e,t)):r},_x:c,_n:function(e,t,r,i){var o=l(i,void 0,e,t,r);return n?(o=n.applyFilters("i18n.ngettext",o,e,t,r,i),n.applyFilters("i18n.ngettext_"+u(i),o,e,t,r,i)):o},_nx:function(e,t,r,i,o){var a=l(o,i,e,t,r);return n?(a=n.applyFilters("i18n.ngettext_with_context",a,e,t,r,i,o),n.applyFilters("i18n.ngettext_with_context_"+u(o),a,e,t,r,i,o)):a},isRTL:function(){return"rtl"===c("ltr","text direction")},hasTranslation:function(e,t,i){var o,a,s=t?t+""+e:e,l=!(null===(o=r.data)||void 0===o||null===(a=o[null!=i?i:"default"])||void 0===a||!a[s]);return n&&(l=n.applyFilters("i18n.has_translation",l,e,t,i),l=n.applyFilters("i18n.has_translation_"+u(i),l,e,t,i)),l}}}(0,0,ye));ge.getLocaleData.bind(ge),ge.setLocaleData.bind(ge),ge.resetLocaleData.bind(ge),ge.subscribe.bind(ge);var ve=ge.__.bind(ge);function xe(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),n.push.apply(n,r)}return n}function we(e){for(var t=1;t2&&void 0!==arguments[2]&&arguments[2],r=document.createElement("option");return r.value=e,r.textContent=t,r.selected=n,r}},{key:"createSvgIcon",value:function(e){var t=document.createElementNS("http://www.w3.org/2000/svg","svg");t.classList.add("frmsvg");var n=document.createElementNS("http://www.w3.org/2000/svg","use");return n.setAttribute("href","#".concat(e)),t.append(n),t}}])}(f),Fe={_:0};function qe(e){return qe="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},qe(e)}function Ne(e,t){for(var n=0;n\') no-repeat center center;\n background-size: 20px;\n}\n.frm-border-radius-component .frm-border-radius-container button.frm-active, .frm-border-radius-component .frm-border-radius-container button:hover {\n background-color: rgba(0, 0, 0, 0.05);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper {\n width: 100%;\n justify-content: space-between;\n flex-wrap: wrap;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden) {\n display: flex;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span {\n position: relative;\n display: block;\n overflow: hidden;\n width: calc(50% - 6px);\n height: 36px;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n margin-top: 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input {\n width: 100%;\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding: 0 12px 0px 20px;\n box-sizing: border-box;\n border: none;\n text-align: right;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus {\n outline: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before {\n content: "";\n position: absolute;\n display: block;\n width: 12px;\n height: 12px;\n left: 12px;\n top: 0;\n bottom: 0;\n right: auto;\n margin: auto;\n background: url(\'data:image/svg+xml,\') center center no-repeat;\n background-size: 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before {\n transform: rotate(180deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before {\n transform: rotate(0deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before {\n transform: rotate(90deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before {\n transform: rotate(-90deg);\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper {\n width: calc(100% - 36px - 12px);\n height: 36px;\n display: flex;\n justify-content: center;\n box-sizing: border-box;\n background: white;\n border-radius: var(--small-radius);\n border: 1px solid var(--grey-300);\n overflow: hidden;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper > * {\n border: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input {\n width: calc(100% - 44px);\n height: 100%;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(16, 24, 40);\n padding-left: 12px;\n box-sizing: border-box;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus {\n outline: none;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select {\n text-align: right;\n padding: 0;\n font-size: var(--text-sm);\n color: rgb(102, 112, 133);\n width: 44px;\n background: url("../../images/style/small-arrow.svg") no-repeat;\n background-position: center right 12px;\n}\n.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus {\n outline: none;\n}\n\n/*# sourceMappingURL=frm-border-radius-component.css.map*/',e}return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),Object.defineProperty(e,"prototype",{writable:!1}),t&&Et(e,t)}(t,e),function(e,t,n){return t&&vt(e.prototype,t),n&&vt(e,n),Object.defineProperty(e,"prototype",{writable:!1}),e}(t,[{key:"initOptions",value:function(){var e;(function(e,t,n){var r=kt(St(e.prototype),"initOptions",n);return"function"==typeof r?function(e){return r.apply(n,e)}:r})(t,0,this)([]),null===this.componentId&&(this.componentId="frm-border-radius-web-component-".concat(At._=(e=At._,++e)))}},{key:"initView",value:function(){return this.wrapper=document.createElement("div"),this.container=document.createElement("div"),this.wrapper.classList.add("frm-border-radius-component"),this.container.classList.add("frm-border-radius-container"),this.container.append(this.getInputWrapper(),this.getButton(),this.getBorderIndividualInputsWrapper()),this.wrapper.append(this.container),this.wrapper}},{key:"parseDefaultValues",value:function(){if(!It(Tt,this))return{top:{value:0,unit:"px"},bottom:{value:0,unit:"px"},left:{value:0,unit:"px"},right:{value:0,unit:"px"}};var e=It(Tt,this).split(" ");return{top:t.parseValueUnit(e[0]||"0px"),bottom:t.parseValueUnit(e[2]||e[0]||"0px"),left:t.parseValueUnit(e[3]||e[1]||e[0]||"0px"),right:t.parseValueUnit(e[1]||e[0]||"0px")}}},{key:"getInputWrapper",value:function(){return this.inputWrapper=document.createElement("div"),this.inputWrapper.classList.add("frm-input-wrapper"),this.inputWrapper.append(this.getInputValue(),this.getInputUnit(),this.getHiddenInput()),this.inputWrapper}},{key:"getHiddenInput",value:function(){return this.hiddenInput=document.createElement("input"),this.hiddenInput.type="hidden",this.hiddenInput.value=It(Pt,this),this.fieldName&&(this.hiddenInput.name=this.fieldName),this.hiddenInput}},{key:"getInputValue",value:function(){var e=this;return this.inputValue=document.createElement("input"),this.inputValue.type="text",this.inputValue.id="".concat(this.componentId,"-value"),this.inputValue.setAttribute("aria-label",ve("Border radius value","formidable")),this.inputValue.classList.add("frm-input-value"),It(Ct,this)||(this.inputValue.value=parseInt(It(Tt,this))||0),this.inputValue.addEventListener("change",function(){var t=e.inputValue.value+e.inputUnit.value;e.hiddenInput.value=t,e.borderInputBottom.value=e.inputValue.value,e.borderInputTop.value=e.inputValue.value,e.borderInputLeft.value=e.inputValue.value,e.borderInputRight.value=e.inputValue.value,e.updateValue(t)}),this.inputValue}},{key:"getInputUnit",value:function(){var e=this;return this.inputUnit=document.createElement("select"),this.inputUnit.id="".concat(this.componentId,"-unit"),this.inputUnit.setAttribute("aria-label",ve("Border radius unit","formidable")),this.inputUnit.classList.add("frm-input-unit"),It(Lt,this).forEach(function(t){var n=document.createElement("option");n.value=t,n.textContent=t,e.inputUnit.append(n)}),this.inputUnit.addEventListener("change",function(){e.hiddenInput.value=e.inputValue.value+e.inputUnit.value}),this.inputUnit}},{key:"getBorderIndividualInputsWrapper",value:function(){return this.borderIndividualInputsWrapper=document.createElement("div"),this.borderIndividualInputsWrapper.classList.add("frm-border-individual-inputs-wrapper"),It(Ct,this)||this.borderIndividualInputsWrapper.classList.add("frm_hidden"),this.borderIndividualInputsWrapper.append(this.getBorderInputTop(),this.getBorderInputRight(),this.getBorderInputLeft(),this.getBorderInputBottom()),this.borderIndividualInputsWrapper}},{key:"getBorderInputTop",value:function(){var e=this,t=this.parseDefaultValues(),n=document.createElement("span");return n.classList.add("frm-border-input-top"),this.borderInputTop=document.createElement("input"),this.borderInputTop.type="text",this.borderInputTop.id="".concat(this.componentId,"-top"),this.borderInputTop.setAttribute("aria-label",ve("Top border radius","formidable")),this.borderInputTop.value=parseInt(t.top.value),n.append(this.borderInputTop),this.borderInputTop.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),n}},{key:"getBorderInputBottom",value:function(){var e=this,t=this.parseDefaultValues(),n=document.createElement("span");return n.classList.add("frm-border-input-bottom"),this.borderInputBottom=document.createElement("input"),this.borderInputBottom.type="text",this.borderInputBottom.id="".concat(this.componentId,"-bottom"),this.borderInputBottom.setAttribute("aria-label",ve("Bottom border radius","formidable")),this.borderInputBottom.value=parseInt(t.bottom.value),n.append(this.borderInputBottom),this.borderInputBottom.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),n}},{key:"getBorderInputLeft",value:function(){var e=this,t=this.parseDefaultValues(),n=document.createElement("span");return n.classList.add("frm-border-input-left"),this.borderInputLeft=document.createElement("input"),this.borderInputLeft.type="text",this.borderInputLeft.id="".concat(this.componentId,"-left"),this.borderInputLeft.setAttribute("aria-label",ve("Left border radius","formidable")),this.borderInputLeft.value=parseInt(t.left.value),n.append(this.borderInputLeft),this.borderInputLeft.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),n}},{key:"getBorderInputRight",value:function(){var e=this,t=this.parseDefaultValues(),n=document.createElement("span");return n.classList.add("frm-border-input-right"),this.borderInputRight=document.createElement("input"),this.borderInputRight.type="text",this.borderInputRight.id="".concat(this.componentId,"-right"),this.borderInputRight.setAttribute("aria-label",ve("Right border radius","formidable")),this.borderInputRight.value=parseInt(t.right.value),n.append(this.borderInputRight),this.borderInputRight.addEventListener("change",function(){return e.buildBorderRadiusIndividualValue()}),n}},{key:"buildBorderRadiusIndividualValue",value:function(){var e=this.inputUnit.value,t="".concat(parseInt(this.borderInputTop.value,10)).concat(e," ").concat(parseInt(this.borderInputRight.value,10)).concat(e," ").concat(parseInt(this.borderInputBottom.value,10)).concat(e," ").concat(parseInt(this.borderInputLeft.value,10)).concat(e);this.updateValue(t)}},{key:"updateValue",value:function(e){this.hiddenInput.value=e,It(Vt,this).call(this,e)}},{key:"getButton",value:function(){var e=this;return this.button=document.createElement("button"),this.button.type="button",this.button.textContent=ve("Border Radius","formidable"),It(Ct,this)&&this.button.classList.add("frm-active"),this.button.addEventListener("click",function(){e.button.classList.toggle("frm-active"),e.borderIndividualInputsWrapper.classList.toggle("frm_hidden")}),this.button}},{key:"onChange",set:function(e){if("function"!=typeof e)throw new TypeError("Expected a function, but received ".concat(gt(e)));Ot(Vt,this,e)}},{key:"borderRadiusDefaultValue",set:function(e){Ot(Tt,this,e),Ot(Ct,this,!/^(\d+)(px|em|%)?$/.test(e)&&""!==e)}}],[{key:"parseValueUnit",value:function(e){var t=e.match(/^(\d+)(px|em|%)?$/);return t?{value:parseInt(t[1],10),unit:t[2]||"px"}:{value:0,unit:"px"}}}])}(f),At={_:0};customElements.define("frm-tab-navigator-component",x),customElements.define("frm-colorpicker-component",z),customElements.define("frm-range-slider-component",Ue),customElements.define("frm-dropdown-component",et),customElements.define("frm-typography-component",bt),customElements.define("frm-border-radius-component",Dt)})()})(); \ No newline at end of file diff --git a/js/formidable_admin.js b/js/formidable_admin.js index dbaa0bdc98..6fc69e80f0 100644 --- a/js/formidable_admin.js +++ b/js/formidable_admin.js @@ -1,13300 +1 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/admin/addon-state.js": -/*!*************************************!*\ - !*** ./js/src/admin/addon-state.js ***! - \*************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addonError: () => (/* binding */ addonError), -/* harmony export */ afterAddonInstall: () => (/* binding */ afterAddonInstall), -/* harmony export */ extractErrorFromAddOnResponse: () => (/* binding */ extractErrorFromAddOnResponse), -/* harmony export */ toggleAddonState: () => (/* binding */ toggleAddonState) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } -function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } - -var _frmDom = frmDom, - div = _frmDom.div, - svg = _frmDom.svg; - -/** - * Toggles the state of an add-on (ie. enable or disable an add-on). - * - * @param {Element} clicked - * @param {string} action - */ -function toggleAddonState(clicked, action) { - var _window$ajaxurl; - var ajaxurl = (_window$ajaxurl = window.ajaxurl) !== null && _window$ajaxurl !== void 0 ? _window$ajaxurl : frm_js.ajax_url; - - // Remove any leftover error messages, output an icon and get the plugin basename that needs to be activated. - jQuery('.frm-addon-error').remove(); - var button = jQuery(clicked); - var plugin = button.attr('rel'); - var el = button.parent(); - var message = el.parent().find('.addon-status-label'); - button.addClass('frm_loading_button'); - - // Process the Ajax to perform the activation. - jQuery.ajax({ - url: ajaxurl, - type: 'POST', - async: true, - cache: false, - dataType: 'json', - data: { - action: action, - nonce: frmGlobal.nonce, - plugin: plugin - }, - success: function success(response) { - var _response$data, _response; - response = (_response$data = (_response = response) === null || _response === void 0 ? void 0 : _response.data) !== null && _response$data !== void 0 ? _response$data : response; - var saveAndReload; - if ('string' !== typeof response && 'string' === typeof response.message) { - if (response.saveAndReload !== undefined) { - saveAndReload = response.saveAndReload; - } - response = response.message; - } - var error = extractErrorFromAddOnResponse(response); - if (error) { - addonError(error, el, button); - return; - } - afterAddonInstall(response, button, message, el, saveAndReload, action); - - /** - * Trigger an action after successfully toggling the addon state. - * - * @param {Object} response - */ - wp.hooks.doAction('frm_update_addon_state', response); - }, - error: function error() { - button.removeClass('frm_loading_button'); - } - }); -} -function extractErrorFromAddOnResponse(response) { - if (typeof response !== 'string') { - if (response.success) { - return false; - } - if (response.form) { - if (jQuery(response.form).is('#message')) { - return { - message: jQuery(response.form).find('p').html() - }; - } - } - return response; - } - return false; -} -function afterAddonInstall(response, button, message, el, saveAndReload) { - var action = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 'frm_activate_addon'; - var frmAdminJs = frm_admin_js; - var addonStatuses = document.querySelectorAll('.frm-addon-status'); - addonStatuses.forEach(function (addonStatus) { - addonStatus.textContent = response; - addonStatus.style.display = 'block'; - }); - - // The Ajax request was successful, so let's update the output. - button.css({ - opacity: '0' - }); - document.querySelectorAll('.frm-oneclick').forEach(function (oneClick) { - oneClick.style.display = 'none'; - }); - showUpgradeModalSuccess(); - - // Proceed with CSS changes - var actionMap = { - frm_activate_addon: { - class: 'frm-addon-active', - message: frmAdminJs.active - }, - frm_deactivate_addon: { - class: 'frm-addon-installed', - message: frmAdminJs.installed - }, - frm_uninstall_addon: { - class: 'frm-addon-not-installed', - message: frmAdminJs.not_installed - } - }; - actionMap.frm_install_addon = actionMap.frm_activate_addon; - var _message = _slicedToArray(message, 1), - messageElement = _message[0]; - if (messageElement) { - messageElement.textContent = actionMap[action].message; - } - var _el = _slicedToArray(el, 1), - parentElement = _el[0].parentElement; - parentElement.classList.remove('frm-addon-not-installed', 'frm-addon-installed', 'frm-addon-active'); - parentElement.classList.add(actionMap[action].class); - var _button = _slicedToArray(button, 1), - buttonElement = _button[0]; - buttonElement.classList.remove('frm_loading_button'); - - // Maybe refresh import and SMTP pages - var refreshPage = document.querySelectorAll('.frm-admin-page-import, #frm-admin-smtp, #frm-welcome'); - if (refreshPage.length > 0) { - window.location.reload(); - return; - } - if (['settings', 'form_builder'].includes(saveAndReload)) { - addonStatuses.forEach(function (addonStatus) { - var inModal = null !== addonStatus.closest('#frm_upgrade_modal'); - addonStatus.append(getSaveAndReloadSettingsOptions(saveAndReload, inModal)); - }); - } -} -function addonError(response, el, button) { - if (response.form) { - jQuery('.frm-inline-error').remove(); - button.closest('.frm-card').html(response.form).css({ - padding: 5 - }).find('#upgrade').attr('rel', button.attr('rel')).on('click', installAddonWithCreds); - } else { - el.append("

            ".concat(response.message, "

            ")); - button.removeClass('frm_loading_button'); - jQuery('.frm-addon-error').delay(4000).fadeOut(); - } -} -function getSaveAndReloadSettingsOptions(saveAndReload, inModal) { - var className = 'frm-save-and-reload-options'; - var children = [saveAndReloadSettingsButton(saveAndReload)]; - if (inModal) { - children.push(closePopupButton()); - } - return div({ - className: className, - children: children - }); -} -function saveAndReloadSettingsButton(saveAndReload) { - var button = document.createElement('button'); - button.classList.add('frm-save-and-reload', 'button', 'button-primary', 'frm-button-primary'); - button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Save and Reload', 'formidable'); - button.addEventListener('click', function () { - if (saveAndReload === 'form_builder') { - saveAndReloadFormBuilder(); - } else if (saveAndReload === 'settings') { - saveAndReloadSettings(); - } - }); - return button; -} -function saveAndReloadSettings() { - var page = document.getElementById('form_settings_page'); - if (page) { - var form = page.querySelector('form.frm_form_settings'); - if (null !== form) { - wp.hooks.doAction('frm_reset_fields_updated'); - form.submit(); - } - } -} -function closePopupButton() { - var a = document.createElement('a'); - a.setAttribute('href', '#'); - a.classList.add('button', 'button-secondary', 'frm-button-secondary', 'dismiss'); - a.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Not Now', 'formidable'); - return a; -} -function saveAndReloadFormBuilder() { - var submitButton = document.getElementById('frm_submit_side_top'); - if (submitButton.classList.contains('frm_submit_ajax')) { - submitButton.setAttribute('data-new-addon-installed', true); - } - submitButton.click(); -} - -/** - * Updates the upgrade modal to show successful addon installation state. - * - * @private - * @return {void} - */ -function showUpgradeModalSuccess() { - var upgradeModal = document.getElementById('frm_upgrade_modal'); - if (!upgradeModal) { - return; - } - upgradeModal.classList.add('frm-success'); - var upgradeMessage = upgradeModal.querySelector('.frm-upgrade-message'); - if (upgradeMessage) { - var image = upgradeMessage.querySelector('img'); - upgradeMessage.replaceChildren((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Great! Everything\'s ready to go!', 'formidable'), document.createElement('br'), (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You just need to refresh the builder so the new field becomes available.', 'formidable')); - if (image) { - upgradeMessage.append(image); - } - } - var frmAddonStatus = document.querySelector('.frm-addon-status'); - if (frmAddonStatus) { - frmAddonStatus.textContent = ''; - } - var circledIcon = upgradeModal.querySelector('.frm-circled-icon'); - if (circledIcon) { - var _circledIcon$querySel; - circledIcon.classList.add('frm-circled-icon-green'); - (_circledIcon$querySel = circledIcon.querySelector('svg')) === null || _circledIcon$querySel === void 0 || _circledIcon$querySel.replaceWith(svg({ - href: '#frm_checkmark_icon' - })); - } -} -function installAddonWithCreds(e) { - // Prevent the default action, let the user know we are attempting to install again and go with it. - e.preventDefault(); - - // Now let's make another Ajax request once the user has submitted their credentials. - var proceed = jQuery(this); - var el = proceed.parent().parent(); - var plugin = proceed.attr('rel'); - proceed.addClass('frm_loading_button'); - jQuery.ajax({ - url: ajaxurl, - type: 'POST', - async: true, - cache: false, - dataType: 'json', - data: { - action: 'frm_install_addon', - nonce: frmAdminJs.nonce, - plugin: plugin, - hostname: el.find('#hostname').val(), - username: el.find('#username').val(), - password: el.find('#password').val() - }, - success: function success(response) { - var _response$data2, _response2; - response = (_response$data2 = (_response2 = response) === null || _response2 === void 0 ? void 0 : _response2.data) !== null && _response$data2 !== void 0 ? _response$data2 : response; - var error = extractErrorFromAddOnResponse(response); - if (error) { - addonError(error, el, proceed); - return; - } - afterAddonInstall(response, proceed, message, el); - }, - error: function error() { - proceed.removeClass('frm_loading_button'); - } - }); -} - -/***/ }), - -/***/ "./js/src/admin/upgrade-popup.js": -/*!***************************************!*\ - !*** ./js/src/admin/upgrade-popup.js ***! - \***************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addOneClick: () => (/* binding */ addOneClick), -/* harmony export */ initModal: () => (/* binding */ initModal), -/* harmony export */ initUpgradeModal: () => (/* binding */ initUpgradeModal) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); - -var _frmDom = frmDom, - svg = _frmDom.svg; -function getShowLinkHrefValue(link, showLink) { - var customLink = link.getAttribute('data-link'); - if (customLink === null || customLink === undefined || customLink === '') { - customLink = showLink.getAttribute('data-default'); - } - return customLink; -} - -/** - * Allow addons to be installed from the upgrade modal. - * - * @param {Element} link - * @param {string} context Either 'modal' or 'tab'. - * @param {string|undefined} upgradeLabel - */ -function addOneClick(link, context, upgradeLabel) { - var container; - if ('modal' === context) { - container = document.getElementById('frm_upgrade_modal'); - } else if ('tab' === context) { - container = document.getElementById(link.getAttribute('href').substr(1)); - } else { - return; - } - var oneclickMessage = container.querySelector('.frm-oneclick'); - var upgradeMessage = container.querySelector('.frm-upgrade-message'); - var showLink = container.querySelector('.frm-upgrade-link'); - var button = container.querySelector('.frm-oneclick-button'); - var addonStatus = container.querySelector('.frm-addon-status'); - var oneclick = link.getAttribute('data-oneclick'); - var newMessage = link.getAttribute('data-message'); - var showIt = 'block'; - var showMsg = 'block'; - var hideIt = 'none'; - var modalIconWrapper = container.querySelector('.frm-circled-icon'); - if (modalIconWrapper) { - var _modalIconWrapper$que; - modalIconWrapper.classList.remove('frm-circled-icon-green'); - (_modalIconWrapper$que = modalIconWrapper.querySelector('svg')) === null || _modalIconWrapper$que === void 0 || _modalIconWrapper$que.replaceWith(svg({ - href: '#frm_filled_lock_icon' - })); - } - var learnMoreLink = container.querySelector('.frm-learn-more'); - if (learnMoreLink) { - learnMoreLink.href = link.dataset.learnMore; - } - - // If one click upgrade, hide other content. - if (oneclickMessage !== null && button !== null && oneclick !== undefined && oneclick) { - if (newMessage === null) { - showMsg = 'none'; - } - showIt = 'none'; - hideIt = 'block'; - oneclick = JSON.parse(oneclick); - button.className = button.className.replace(' frm-install-addon', '').replace(' frm-activate-addon', ''); - button.className = "".concat(button.className, " ").concat(oneclick.class); - button.rel = oneclick.url; - oneclickMessage.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('This plugin is not activated. Would you like to activate it now?', 'formidable'); - button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Activate', 'formidable'); - var linkIcon = link.querySelector('use'); - if (linkIcon) { - modalIconWrapper === null || modalIconWrapper === void 0 || modalIconWrapper.querySelector('svg').replaceWith(svg({ - href: linkIcon.getAttribute('href') || linkIcon.getAttribute('xlink:href'), - // Get the icon from xlink:href if it has not been updated to use href - classList: ['frm_svg32'] - })); - } - } - if (!newMessage) { - newMessage = upgradeMessage.getAttribute('data-default'); - } - if (undefined !== upgradeLabel) { - newMessage = newMessage.replace('', upgradeLabel); - } - upgradeMessage.innerHTML = newMessage; - if (link.dataset.upsellImage) { - upgradeMessage.append(frmDom.img({ - src: link.dataset.upsellImage, - alt: link.dataset.upgrade - })); - } - - // Either set the link or use the default. - showLink.href = getShowLinkHrefValue(link, showLink); - addonStatus.style.display = 'none'; - if (oneclickMessage) { - oneclickMessage.style.display = hideIt; - } - if (button) { - button.style.display = hideIt === 'block' ? 'inline-block' : hideIt; - } - upgradeMessage.style.display = showMsg; - showLink.style.display = showIt === 'block' ? 'inline-block' : showIt; - var showLinkParent = showLink.closest('.frm-upgrade-modal-actions'); - if (showLinkParent) { - showLinkParent.style.display = showIt === 'block' ? 'flex' : showIt; - } -} -function initModal(id, width) { - var $info = jQuery(id); - if (!$info.length) { - return false; - } - if (width === undefined) { - width = '552px'; - } - var dialogArgs = { - dialogClass: 'frm-dialog', - modal: true, - autoOpen: false, - closeOnEscape: true, - width: width, - resizable: false, - draggable: false, - open: function open() { - jQuery('.ui-dialog-titlebar').addClass('frm_hidden').removeClass('ui-helper-clearfix'); - jQuery('#wpwrap').addClass('frm_overlay'); - jQuery('.frm-dialog').removeClass('ui-widget ui-widget-content ui-corner-all'); - $info.removeClass('ui-dialog-content ui-widget-content'); - bindClickForDialogClose($info); - }, - close: function close() { - jQuery('#wpwrap').removeClass('frm_overlay'); - jQuery('.spinner').css('visibility', 'hidden'); - this.removeAttribute('data-option-type'); - var optionType = document.getElementById('bulk-option-type'); - if (optionType) { - optionType.value = ''; - } - } - }; - $info.dialog(dialogArgs); - return $info; -} -function bindClickForDialogClose($modal) { - var closeModal = function closeModal() { - $modal.dialog('close'); - }; - jQuery('.ui-widget-overlay').on('click', closeModal); - $modal.on('click', 'a.dismiss', closeModal); -} -function initUpgradeModal() { - var $info = initModal('#frm_upgrade_modal'); - if ($info === false) { - return; - } - document.addEventListener('click', handleUpgradeClick); - frmDom.util.documentOn('change', 'select.frm_select_with_upgrade', handleUpgradeClick); - function handleUpgradeClick(event) { - var element; - var link; - var content; - element = event.target; - if (!element.classList) { - return; - } - var showExpiredModal = element.classList.contains('frm_show_expired_modal') || null !== element.querySelector('.frm_show_expired_modal') || element.closest('.frm_show_expired_modal'); - - // If a `select` element is clicked, check if the selected option has a 'data-upgrade' attribute - if (event.type === 'change' && element.classList.contains('frm_select_with_upgrade')) { - var selectedOption = element.options[element.selectedIndex]; - if (selectedOption && selectedOption.dataset.upgrade) { - element = selectedOption; - } - } - if (!element.dataset.upgrade) { - var parent = element.closest('[data-upgrade]'); - if (!parent) { - parent = element.closest('.frm_field_box'); - if (!parent) { - return; - } - // Fake it if it's missing to avoid error. - element.dataset.upgrade = ''; - } - element = parent; - } - if (showExpiredModal) { - var hookName = 'frm_show_expired_modal'; - wp.hooks.doAction(hookName, element); - return; - } - var upgradeLabel = element.dataset.upgrade; - if (!upgradeLabel || element.classList.contains('frm_show_upgrade_tab')) { - return; - } - event.preventDefault(); - var modal = $info.get(0); - modal.classList.remove('frm-success'); - var lockIcon = modal.querySelector('.frm_lock_icon'); - if (lockIcon) { - lockIcon.style.display = 'block'; - lockIcon.classList.remove('frm_lock_open_icon'); - lockIcon.querySelector('use').setAttribute('href', '#frm_lock_icon'); - } - var upgradeImageId = 'frm_upgrade_modal_image'; - var oldImage = document.getElementById(upgradeImageId); - if (oldImage) { - oldImage.remove(); - } - if (element.dataset.image && lockIcon) { - lockIcon.style.display = 'none'; - lockIcon.parentNode.insertBefore(frmDom.img({ - id: upgradeImageId, - src: "".concat(frmGlobal.url, "/images/").concat(element.dataset.image) - }), lockIcon); - } - var level = modal.querySelector('.license-level'); - if (level) { - level.textContent = getRequiredLicenseFromTrigger(element); - } - - // If one click upgrade, hide other content - addOneClick(element, 'modal', upgradeLabel); - var notInstalled = modal.querySelector('.frm_are_not_installed'); - notInstalled.style.display = element.dataset.image || element.dataset.oneclick ? 'none' : 'inline-block'; - notInstalled.textContent = notInstalled.dataset.default; - modal.querySelector('.frm-upgrade-modal-title-prefix').style.display = element.dataset.oneclick ? 'inline' : 'none'; - modal.querySelector('.frm_feature_label').textContent = upgradeLabel; - modal.querySelector('.frm-upgrade-modal-title-suffix').style.display = 'none'; - modal.querySelector('h2').style.display = 'block'; - $info.dialog('open'); - - // set the utm medium - var button = modal.querySelector('.button-primary:not(.frm-oneclick-button)'); - link = button.getAttribute('href').replace(/(medium=)[a-z_-]+/ig, "$1".concat(element.getAttribute('data-medium'))); - content = element.getAttribute('data-content'); - if (content === null) { - content = ''; - } - link = link.replace(/(content=)[a-z_-]+/ig, "$1".concat(content)); - button.setAttribute('href', link); - if (element.classList.contains('frm_show_update')) { - applyUpdateModalOverrides(modal); - } - } -} - -/** - * Override upgrade modal content for update prompts. - * - * @since 6.29 - * - * @param {Element} modal The upgrade modal element. - */ -function applyUpdateModalOverrides(modal) { - var titlePrefix = modal.querySelector('.frm-upgrade-modal-title-prefix'); - if (titlePrefix) { - titlePrefix.style.display = 'none'; - } - var notInstalled = modal.querySelector('.frm_are_not_installed'); - if (notInstalled) { - notInstalled.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('require an update', 'formidable'); - notInstalled.style.display = ''; // Clear inline style, span defaults to display:inline. - } - var oneclickMsg = modal.querySelector('.frm-oneclick'); - if (oneclickMsg) { - oneclickMsg.style.display = 'none'; - } - var button = modal.querySelector('.frm-oneclick-button'); - if (button) { - button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Update Now', 'formidable'); - } -} -function getRequiredLicenseFromTrigger(element) { - if (element.dataset.requires) { - return element.dataset.requires; - } - return 'Pro'; -} - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. -(() => { -/*!*******************************!*\ - !*** ./js/src/admin/admin.js ***! - \*******************************/ -function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } -function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } -function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/* exported frm_add_logic_row, frm_remove_tag, frm_show_div, frmCheckAll, frmCheckAllLevel */ - -window.FrmFormsConnect = window.FrmFormsConnect || function (document, window, $) { - var el = { - messageBox: null, - reset: null, - setElements: function setElements() { - el.messageBox = document.querySelector('.frm_pro_license_msg'); - el.reset = document.getElementById('frm_reconnect_link'); - } - }; - - /** - * Public functions and properties. - * - * @since 4.03 - * - * @type {Object} - */ - var app = { - /** - * Register connect button event. - * - * @since 4.03 - */ - init: function init() { - el.setElements(); - $(document.getElementById('frm_deauthorize_link')).on('click', app.deauthorize); - $('.frm_authorize_link').on('click', app.authorize); - // Handles FF dashboard Authorize & Reauthorize events. - // Attach click event to parent as #frm_deauthorize_link & #frm_reconnect_link dynamically recreated by bootstrap.setupBootstrapDropdowns in dom.js - $('.frm-dashboard-license-options').on('click', '#frm_deauthorize_link', app.deauthorize); - $('.frm-dashboard-license-options').on('click', '#frm_reconnect_link', app.reauthorize); - if (el.reset !== null) { - $(el.reset).on('click', app.reauthorize); - } - }, - /* Manual license authorization */authorize: function authorize() { - /*jshint validthis:true */ - var button = this; - var pluginSlug = this.getAttribute('data-plugin'); - var input = document.getElementById("edd_".concat(pluginSlug, "_license_key")); - var license = input.value; - var wpmu = document.getElementById('proplug-wpmu'); - this.classList.add('frm_loading_button'); - if (!wpmu) { - wpmu = 0; - } else if (wpmu.checked) { - wpmu = 1; - } else { - wpmu = 0; - } - $.ajax({ - type: 'POST', - url: ajaxurl, - dataType: 'json', - data: { - action: 'frm_addon_activate', - license: license, - plugin: pluginSlug, - wpmu: wpmu, - nonce: frmGlobal.nonce - }, - success: function success(msg) { - app.afterAuthorize(msg, input); - button.classList.remove('frm_loading_button'); - } - }); - }, - afterAuthorize: function afterAuthorize(msg, input) { - if (msg.success === true) { - input.value = '•••••••••••••••••••'; - } - wp.hooks.doAction('frm_after_authorize', msg); - app.showMessage(msg); - }, - showProgress: function showProgress(msg) { - if (el.messageBox === null) { - // In case the message box was added after page load. - el.setElements(); - } - var messageBox = el.messageBox; - if (messageBox === null) { - return; - } - if (msg.success === true) { - messageBox.classList.remove('frm_error_style'); - messageBox.classList.add('frm_message', 'frm_updated_message'); - } else { - messageBox.classList.add('frm_error_style'); - messageBox.classList.remove('frm_message', 'frm_updated_message'); - } - messageBox.classList.remove('frm_hidden'); - messageBox.innerHTML = msg.message; - }, - showMessage: function showMessage(msg) { - if (el.messageBox === null) { - // In case the message box was added after page load. - el.setElements(); - } - var messageBox = el.messageBox; - if (msg.success === true) { - app.showAuthorized(true); - app.showInlineSuccess(); - - /** - * Triggers the after license is authorized action for a confirmation/success modal. - * - * @param {Object} msg An object containing message data received from Authorize request. - */ - wp.hooks.doAction('frmAdmin.afterLicenseAuthorizeSuccess', { - msg: msg - }); - } - app.showProgress(msg); - if (msg.message !== '') { - setTimeout(function () { - messageBox.innerHTML = ''; - messageBox.classList.add('frm_hidden'); - messageBox.classList.remove('frm_error_style', 'frm_message', 'frm_updated_message'); - }, 10000); - var refreshPage = document.querySelector('.frm-admin-page-dashboard'); - if (refreshPage) { - setTimeout(function () { - window.location.reload(); - }, 1000); - } - } - }, - showAuthorized: function showAuthorized(show) { - var from = show ? 'unauthorized' : 'authorized'; - var to = show ? 'authorized' : 'unauthorized'; - var container = document.querySelectorAll(".frm_".concat(from, "_box")); - if (container.length) { - // Replace all authorized boxes with unauthorized boxes. - container.forEach(function (box) { - box.className = box.className.replace("frm_".concat(from, "_box"), "frm_".concat(to, "_box")); - }); - } - }, - /** - * Use the data-success element to replace the element content. - */ - showInlineSuccess: function showInlineSuccess() { - var successElement = document.querySelectorAll('.frm-confirm-msg [data-success]'); - if (successElement.length) { - successElement.forEach(function (element) { - element.innerHTML = frmAdminBuild.purifyHtml(element.getAttribute('data-success')); - }); - } - }, - /* Clear the site license cache */reauthorize: function reauthorize() { - /*jshint validthis:true */ - this.innerHTML = ''; - $.ajax({ - type: 'POST', - url: ajaxurl, - dataType: 'json', - data: { - action: 'frm_reset_cache', - plugin: 'formidable_pro', - nonce: frmGlobal.nonce - }, - success: function success(msg) { - el.reset.textContent = msg.message; - if (el.reset.getAttribute('data-refresh') === '1') { - window.location.reload(); - } - } - }); - return false; - }, - deauthorize: function deauthorize() { - /*jshint validthis:true */ - if (!confirm(frmGlobal.deauthorize)) { - return false; - } - var pluginSlug = this.getAttribute('data-plugin'); - var input = document.getElementById("edd_".concat(pluginSlug, "_license_key")); - var license = input.value; - var link = this; - this.innerHTML = ''; - $.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_addon_deactivate', - license: license, - plugin: pluginSlug, - nonce: frmGlobal.nonce - }, - success: function success() { - app.showAuthorized(false); - input.value = ''; - link.replaceWith('Disconnected'); - - /** - * Triggers the after license is deauthorized sruccess action. - */ - wp.hooks.doAction('frmAdmin.afterLicenseDeauthorizeSuccess', {}); - } - }); - return false; - } - }; - - // Provide access to public functions/properties. - return app; -}(document, window, jQuery); -window.frmAdminBuildJS = function () { - //'use strict'; - - var MAX_FIELD_GROUP_SIZE = 12; - var frmAdminJs = frm_admin_js; - var _frmDom = frmDom, - tag = _frmDom.tag, - div = _frmDom.div, - span = _frmDom.span, - a = _frmDom.a, - svg = _frmDom.svg, - img = _frmDom.img; - var onClickPreventDefault = frmDom.util.onClickPreventDefault; - var doJsonPost = frmDom.ajax.doJsonPost; - frmAdminJs.contextualShortcodes = getContextualShortcodes(); - var icons = { - save: svg({ - href: '#frm_save_icon' - }), - drag: svg({ - href: '#frm_drag_icon', - classList: ['frm_drag_icon', 'frm-drag'] - }) - }; - var $newFields = jQuery(document.getElementById('frm-show-fields')); - var builderForm = document.getElementById('new_fields'); - var thisForm = document.getElementById('form_id'); - var copyHelper = false; - var fieldsUpdated = 0; - var thisFormId = 0; - var autoId = 0; - var optionMap = {}; - var lastNewActionIdReturned = 0; - var _wp$i18n = wp.i18n, - __ = _wp$i18n.__, - sprintf = _wp$i18n.sprintf; - var debouncedSyncAfterDragAndDrop; - var postBodyContent; - var $postBodyContent; - var dragState = { - dragging: false - }; - if (thisForm) { - thisFormId = thisForm.value; - } - var currentURL = new URL(window.location.href); - var urlParams = currentURL.searchParams; - var builderPage = document.getElementById('frm_builder_page'); - - // Global settings - var s; - function showElement(element) { - if (!element[0]) { - return; - } - element[0].style.display = ''; - } - function empty($obj) { - if ($obj !== null) { - while ($obj.firstChild) { - $obj.firstChild.remove(); - } - } - } - function addClass($obj, className) { - if ($obj.classList) { - $obj.classList.add(className); - } else { - $obj.className += " ".concat(className); - } - } - function confirmClick(e) { - /*jshint validthis:true */ - e.stopPropagation(); - e.preventDefault(); - confirmLinkClick(this); - } - function confirmLinkClick(link) { - var message = link.getAttribute('data-frmverify'); - var loadedFrom = link.getAttribute('data-loaded-from'); - if (message === null || link.id === 'frm-confirmed-click') { - return true; - } - if ('entries-list' === loadedFrom) { - return wp.hooks.applyFilters('frm_on_multiple_entries_delete', { - link: link, - initModal: initModal - }); - } - return confirmModal(link); - } - function confirmModal(link) { - var $info = initModal('#frm_confirm_modal', '400px'); - var continueButton = document.getElementById('frm-confirmed-click'); - if ($info === false) { - return false; - } - - // The confirm button is hidden when showLimitModal is called, - // so make sure it is visible every time we open the modal. - if (continueButton) { - continueButton.style.display = 'block'; - } - var verify = link.getAttribute('data-frmverify'); - var btnClass = verify ? link.getAttribute('data-frmverify-btn') : ''; - var $confirmMessage = jQuery('.frm-confirm-msg'); - $confirmMessage.empty(); - if (verify) { - $confirmMessage.append(document.createTextNode(verify)); - if (btnClass) { - continueButton === null || continueButton === void 0 || continueButton.classList.add(btnClass); - } - } - var dataAtts = link.dataset; - if (continueButton) { - for (var i in continueButton.dataset) { - continueButton.removeAttribute("data-".concat(i)); - } - for (var _i in dataAtts) { - if (_i !== 'frmverify') { - continueButton.setAttribute("data-".concat(_i), dataAtts[_i]); - } - } - } - - /** - * Triggers the pre-open action for a confirmation modal. This action passes - * relevant modal information and associated link to any listening hooks. - * - * @param {Object} options An object containing modal elements and data. - * @param {HTMLElement} options.$info The HTML element containing modal information. - * @param {string} options.link The link associated with the modal action. - */ - wp.hooks.doAction('frmAdmin.beforeOpenConfirmModal', { - $info: $info, - link: link - }); - $info.dialog('open'); - continueButton === null || continueButton === void 0 || continueButton.setAttribute('href', link.getAttribute('href') || link.getAttribute('data-href')); - return false; - } - function infoModal(msg) { - var $info = initModal('#frm_info_modal', '400px'); - if ($info === false) { - return false; - } - jQuery('.frm-info-msg').html(msg); - $info.dialog('open'); - return false; - } - function toggleItem(e) { - /*jshint validthis:true */ - var toggle = this.getAttribute('data-frmtoggle'); - var text = this.getAttribute('data-toggletext'); - var $items = jQuery(toggle); - e.preventDefault(); - $items.toggle(); - if (text !== null && text !== '') { - this.setAttribute('data-toggletext', this.innerHTML); - this.textContent = text; - } - return false; - } - - /** - * Toggle a class on target elements when an anchor is clicked, or when a radio or checkbox has been selected. - * - * @param {Event} e Event with either the change or click type. - * @return {false} Always returns false to prevent default behavior. - */ - function hideShowItem(e) { - /*jshint validthis:true */ - var hide = this.getAttribute('data-frmhide'); - var show = this.getAttribute('data-frmshow'); - var uncheckList = this.getAttribute('data-frmuncheck'); - var uncheckListArray = uncheckList ? uncheckList.split(',') : []; - - // Flip unchecked checkboxes so an off value undoes the on value. - if (isUncheckedCheckbox(this)) { - if (hide !== null) { - show = hide; - hide = null; - } else if (show !== null) { - hide = show; - show = null; - } - } - e.preventDefault(); - var toggleClass = this.getAttribute('data-toggleclass') || 'frm_hidden'; - if (hide !== null) { - jQuery(hide).addClass(toggleClass); - } - if (show !== null) { - jQuery(show).removeClass(toggleClass); - } - var current = this.parentNode.querySelectorAll('a.current'); - if (current !== null) { - for (var i = 0; i < current.length; i++) { - current[i].classList.remove('current'); - } - this.classList.add('current'); - } - if (uncheckListArray.length) { - uncheckListArray.forEach(function (uncheckItem) { - var uncheckItemElement = document.querySelector(uncheckItem); - if (uncheckItemElement) { - uncheckItemElement.checked = false; - } - }); - } - return false; - } - function isUncheckedCheckbox(element) { - return 'INPUT' === element.nodeName && 'checkbox' === element.type && !element.checked; - } - - /** - * Load a tooltip for a single element. - * - * @since 6.26 - * - * @param {HTMLElement} element - * @param {boolean} show - */ - function loadTooltip(element) { - var show = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - var tooltipTarget = element; - - // Bootstrap 5 does not allow tooltips on dropdown triggers, so move the tooltip to the parent element. - if (tooltipTarget.hasAttribute('data-toggle') || tooltipTarget.hasAttribute('data-bs-toggle')) { - tooltipTarget.parentElement.setAttribute('title', tooltipTarget.getAttribute('title')); - tooltipTarget.removeAttribute('title'); - tooltipTarget.classList.remove('frm_bstooltip'); - tooltipTarget.parentElement.classList.add('frm_bstooltip'); - tooltipTarget = tooltipTarget.parentElement; - } - jQuery(tooltipTarget).tooltip(); - if (show) { - deleteTooltips(); - jQuery(tooltipTarget).tooltip('show'); - } - } - function loadTooltips() { - var wrapClass = jQuery('.wrap, .frm_wrap'); - var confirmModal = document.getElementById('frm_confirm_modal'); - var doAction = false; - var confirmedBulkDelete = false; - jQuery(confirmModal).on('click', '[data-deletefield]', deleteFieldConfirmed); - jQuery(confirmModal).on('click', '[data-removeid]', removeThisTag); - jQuery(confirmModal).on('click', '[data-trashtemplate]', trashTemplate); - wrapClass.on('click', '.frm_remove_tag, .frm_remove_form_action', removeThisTag); - wrapClass.on('click', 'a[data-frmverify]', confirmClick); - wrapClass.on('click', 'a[data-frmtoggle]', toggleItem); - wrapClass.on('click', 'a[data-frmhide], a[data-frmshow]', hideShowItem); - wrapClass.on('change', 'input[data-frmhide], input[data-frmshow]', hideShowItem); - wrapClass.on('click', '.widget-top,a.widget-action', clickWidget); - wrapClass.on('mouseenter.frm', '.frm_bstooltip, .frm_help', function () { - jQuery(this).off('mouseenter.frm'); - loadTooltip(this, true); - }); - jQuery(document).on('click', '#doaction, #doaction2', function (event) { - var isTop = this.id === 'doaction'; - var suffix = isTop ? 'top' : 'bottom'; - var bulkActionSelector = document.getElementById("bulk-action-selector-".concat(suffix)); - var confirmBulkDelete = document.getElementById("confirm-bulk-delete-".concat(suffix)); - if (bulkActionSelector && confirmBulkDelete) { - doAction = this; - if (!confirmedBulkDelete && bulkActionSelector.value === 'bulk_delete') { - event.preventDefault(); - confirmLinkClick(confirmBulkDelete); - return false; - } - } else { - doAction = false; - } - }); - jQuery(document).on('click', '#frm-confirmed-click', function (event) { - if (doAction === false || event.target.classList.contains('frm-btn-inactive')) { - return; - } - if (this.getAttribute('href') === 'confirm-bulk-delete') { - event.preventDefault(); - confirmedBulkDelete = true; - doAction.click(); - return false; - } - }); - } - function deleteTooltips() { - document.querySelectorAll('.tooltip').forEach(function (tooltip) { - tooltip.remove(); - }); - } - function removeThisTag() { - /*jshint validthis:true */ - var show; - var hide; - var removeMore; - if (parseInt(this.getAttribute('data-skip-frm-js')) || confirmLinkClick(this) === false) { - return; - } - var deleteButton = jQuery(this); - var id = deleteButton.attr('data-removeid'); - show = deleteButton.attr('data-showlast'); - if (show === undefined) { - show = ''; - } - hide = deleteButton.attr('data-hidelast'); - if (hide === undefined) { - hide = ''; - } - removeMore = deleteButton.attr('data-removemore'); - if (show !== '') { - if (deleteButton.closest('.frm_add_remove').find('.frm_remove_tag:visible').length > 1) { - show = ''; - hide = ''; - } - } else if (id.indexOf('frm_postmeta_') === 0) { - if (jQuery('#frm_postmeta_rows .frm_postmeta_row').length < 2) { - show = '.frm_add_postmeta_row.button'; - } - if (jQuery('.frm_toggle_cf_opts').length && jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(id, ")")).last().length) { - if (show !== '') { - show += ','; - } - show += "#".concat(jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(id, ")")).last().attr('id'), " .frm_toggle_cf_opts"); - } - } - var fadeEle = document.getElementById(id); - var $fadeEle = jQuery(fadeEle); - $fadeEle.fadeOut(300, function () { - var _document$querySelect; - $fadeEle.remove(); - fieldUpdated(); - if (hide !== '') { - jQuery(hide).hide(); - } - if (show !== '') { - jQuery("".concat(show, " a,").concat(show)).removeClass('frm_hidden').fadeIn('slow'); - } - if (this.closest('.frm_form_action_settings')) { - var type = this.closest('.frm_form_action_settings').querySelector('.frm_action_name').value; - afterActionRemoved(type); - } - (_document$querySelect = document.querySelector('.tooltip')) === null || _document$querySelect === void 0 || _document$querySelect.remove(); - }); - if (removeMore !== undefined) { - removeMore = jQuery(removeMore); - removeMore.fadeOut(400, function () { - removeMore.remove(); - }); - } - if (show !== '') { - jQuery(this).closest('.frm_logic_rows').fadeOut('slow'); - } - - /** - * Fires after a tag element has been removed in the admin interface. - * - * @param {string} id The ID of the removed element - * @param {HTMLElement} fadeEle The removed element that was faded out - */ - wp.hooks.doAction('frm_admin_tag_removed', id, fadeEle); - return false; - } - function afterActionRemoved(type) { - checkActiveAction(type); - var hookName = 'frm_after_action_removed'; - var hookArgs = { - type: type - }; - wp.hooks.doAction(hookName, hookArgs); - } - function clickWidget(event, b) { - /*jshint validthis:true */ - if (b === undefined) { - b = this; - } - popCalcFields(b, false); - var cont = jQuery(b).closest('.frm_form_action_settings'); - var target = event.target; - if (cont.length && target !== undefined) { - var className = target.parentElement.className; - if ('string' === typeof className) { - if (className.includes('frm_email_icons') || className.includes('frm_toggle')) { - // clicking on delete icon shouldn't open it - event.stopPropagation(); - return; - } - } - } - var inside = cont.children('.widget-inside'); - if (cont.length && inside.find('p, div, table').length < 1) { - var actionId = cont.find('input[name$="[ID]"]').val(); - var actionType = cont.find('input[name$="[post_excerpt]"]').val(); - if (actionType) { - inside.html(''); - cont.find('.spinner').fadeIn('slow'); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_form_action_fill', - action_id: actionId, - action_type: actionType, - nonce: frmGlobal.nonce - }, - success: function success(html) { - inside.html(html); - initiateMultiselect(); - showInputIcon("#".concat(cont.attr('id'))); - initAutocomplete(inside); - jQuery(b).trigger('frm-action-loaded'); - - /** - * Fires after filling form action content when opening. - * - * @since 5.5.4 - * - * @param {Object} insideElement JQuery object of form action inside element. - */ - wp.hooks.doAction('frm_filled_form_action', inside); - } - }); - } - } - jQuery(b).closest('.frm_field_box').siblings().find('.widget-inside').slideUp('fast'); - if (b.className !== undefined && b.className.includes('widget-action') || jQuery(b).closest('.start_divider').length < 1) { - return; - } - inside = jQuery(b).closest('div.widget').children('.widget-inside'); - if (inside.is(':hidden')) { - inside.slideDown('fast'); - } else { - inside.slideUp('fast'); - } - } - function clickNewTab() { - /*jshint validthis:true */ - var t = this.getAttribute('href'); - if (t === undefined) { - return false; - } - var c = t.replace('#', '.'); - var $link = jQuery(this); - $link.closest('li').addClass('frm-tabs active').siblings('li').removeClass('frm-tabs active starttab'); - $link.closest('div').children('.tabs-panel').not(t).not(c).hide(); - var tabContent = document.getElementById(t.replace('#', '')); - if (tabContent) { - tabContent.style.display = 'block'; - } - - // clearSettingsBox would hide field settings when opening the fields modal and we want to skip it there. - if (this.id === 'frm_insert_fields_tab' && !this.closest('#frm_adv_info')) { - clearSettingsBox(); - } - return false; - } - function clickTab(link, auto) { - link = jQuery(link); - var t = link.attr('href'); - if (t === undefined) { - return; - } - var c = t.replace('#', '.'); - link.closest('li').addClass('frm-tabs active').siblings('li').removeClass('frm-tabs active starttab'); - if (link.closest('div').find('.tabs-panel').length) { - link.closest('div').children('.tabs-panel').not(t).not(c).hide(); - } else if (document.getElementById('form_global_settings') !== null) { - /* global settings */ - var ajax = link.data('frmajax'); - link.closest('.frm_wrap').find('.tabs-panel, .hide_with_tabs').hide(); - if (ajax !== undefined && ajax == '1') { - loadSettingsTab(t); - } - } else { - /* form settings page */ - jQuery('#frm-categorydiv .tabs-panel, .hide_with_tabs').hide(); - } - jQuery(t).show(); - jQuery(c).show(); - hideShortcodes(); - if (auto !== 'auto') { - // Hide success message on tab change. - jQuery('.frm_updated_message').hide(); - jQuery('.frm_warning_style').hide(); - } - if (jQuery(link).closest('#frm_adv_info').length) { - return; - } - if (jQuery('.frm_form_settings').length) { - jQuery('.frm_form_settings').attr('action', "?page=formidable&frm_action=settings&id=".concat(jQuery('.frm_form_settings input[name="id"]').val(), "&t=").concat(t.replace('#', ''))); - } else { - jQuery('.frm_settings_form').attr('action', "?page=formidable-settings&t=".concat(t.replace('#', ''))); - } - } - function setupSortable(sortableSelector) { - document.querySelectorAll(sortableSelector).forEach(function (list) { - makeDroppable(list); - Array.from(list.children).forEach(function (child) { - return makeDraggable(child, '.frm-move'); - }); - var $sectionTitle = jQuery(list).children('[data-type="divider"]').children('.divider_section_only'); - if ($sectionTitle.length) { - makeDroppable($sectionTitle); - } - }); - setupFieldOptionSorting(jQuery('#frm_builder_page')); - } - function makeDroppable(list) { - jQuery(list).droppable({ - accept: '.frmbutton, li.frm_field_box', - deactivate: handleFieldDrop, - over: onDragOverDroppable, - out: onDraggableLeavesDroppable, - tolerance: 'pointer' - }); - } - function onDragOverDroppable(event, ui) { - var droppable = getDroppableForOnDragOver(event.target); - var draggable = ui.draggable[0]; - if (!allowDrop(draggable, droppable, event)) { - droppable.classList.remove('frm-over-droppable'); - jQuery(droppable).parents('ul.frm_sorting').addClass('frm-over-droppable'); - return; - } - document.querySelectorAll('.frm-over-droppable').forEach(function (droppable) { - return droppable.classList.remove('frm-over-droppable'); - }); - droppable.classList.add('frm-over-droppable'); - jQuery(droppable).parents('ul.frm_sorting').addClass('frm-over-droppable'); - } - - /** - * Maybe change the droppable. - * Section titles are made droppable, but are not a list, so we need to change the droppable to the section's list instead. - * - * @param {Element} droppable The droppable element. - * @return {Element} The adjusted droppable element. - */ - function getDroppableForOnDragOver(droppable) { - if (droppable.classList.contains('divider_section_only')) { - droppable = jQuery(droppable).nextAll('.start_divider.frm_sorting').get(0); - } - return droppable; - } - function onDraggableLeavesDroppable(event) { - var droppable = event.target; - droppable.classList.remove('frm-over-droppable'); - } - function makeDraggable(draggable, handle) { - var settings = { - helper: getDraggableHelper, - revert: 'invalid', - delay: 10, - start: handleDragStart, - stop: handleDragStop, - drag: handleDrag, - cursor: 'grabbing', - refreshPositions: true, - cursorAt: { - top: 0, - left: 90 // The width of draggable button is 180. 90 should center the draggable on the cursor. - } - }; - if ('string' === typeof handle) { - settings.handle = handle; - } - jQuery(draggable).draggable(settings); - } - function getDraggableHelper(event) { - var draggable = event.delegateTarget; - if (isFieldGroup(draggable)) { - var newTextFieldClone = document.getElementById('frm-insert-fields').querySelector('.frm_ttext').cloneNode(true); - newTextFieldClone.querySelector('use').setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_field_group_layout_icon'); - newTextFieldClone.querySelector('span').textContent = __('Field Group', 'formidable'); - newTextFieldClone.classList.add('frm_field_box'); - newTextFieldClone.classList.add('ui-sortable-helper'); - return newTextFieldClone; - } - var copyTarget; - var isNewField = draggable.classList.contains('frmbutton'); - if (isNewField) { - copyTarget = draggable.cloneNode(true); - copyTarget.classList.add('ui-sortable-helper'); - draggable.classList.add('frm-new-field'); - return copyTarget; - } - if (draggable.hasAttribute('data-ftype')) { - var fieldType = draggable.getAttribute('data-ftype'); - copyTarget = document.getElementById('frm-insert-fields').querySelector(".frm_t".concat(fieldType)); - if (copyTarget) { - copyTarget = copyTarget.cloneNode(true); - copyTarget.classList.add('form-field'); - copyTarget.classList.add('ui-sortable-helper'); - return copyTarget.cloneNode(true); - } - } - return div({ - className: 'frmbutton' - }); - } - function handleDragStart(event, ui) { - if (event.target.classList.contains('frm_at_limit')) { - showLimitModal(); - return false; - } - dragState.dragging = true; - var container = postBodyContent; - container.classList.add('frm-dragging-field'); - document.body.classList.add('frm-dragging'); - ui.helper.addClass('frm-sortable-helper'); - ui.helper.initialOffset = container.scrollTop; - event.target.classList.add('frm-drag-fade'); - unselectFieldGroups(); - deleteEmptyDividerWrappers(); - maybeRemoveGroupHoverTarget(); - closeOpenFieldDropdowns(); - deleteTooltips(); - } - function handleDragStop() { - var container = postBodyContent; - container.classList.remove('frm-dragging-field'); - document.body.classList.remove('frm-dragging'); - var fade = document.querySelector('.frm-drag-fade'); - if (fade) { - fade.classList.remove('frm-drag-fade'); - } - } - function handleDrag(event, ui) { - maybeScrollBuilder(event); - var draggable = event.target; - var droppable = getDroppableTarget(); - var placeholder = document.getElementById('frm_drag_placeholder'); - if (!allowDrop(draggable, droppable, event)) { - if (placeholder) { - placeholder.remove(); - } - return; - } - if (!placeholder) { - placeholder = tag('li', { - id: 'frm_drag_placeholder', - className: 'sortable-placeholder' - }); - } - var frmSortableHelper = ui.helper.get(0); - if (frmSortableHelper.classList.contains('form-field') || frmSortableHelper.classList.contains('frm_field_box')) { - // Sync the y position of the draggable so it still follows the cursor after scrolling up and down the field list. - frmSortableHelper.style.transform = "translateY(".concat(getDragOffset(ui.helper), "px)"); - } - if ('frm-show-fields' === droppable.id || droppable.classList.contains('start_divider')) { - placeholder.style.left = 0; - handleDragOverYAxis({ - droppable: droppable, - y: event.clientY, - placeholder: placeholder - }); - return; - } - placeholder.style.top = ''; - handleDragOverFieldGroup({ - droppable: droppable, - x: event.clientX, - placeholder: placeholder - }); - } - function maybeScrollBuilder(event) { - $postBodyContent.scrollTop(function (_, v) { - var moved = event.clientY; - var h = postBodyContent.offsetHeight; - var relativePos = event.clientY - postBodyContent.offsetTop; - var y = relativePos - h / 2; - if (relativePos > h - 50 && moved > 5) { - // Scrolling down. - return v + y * 0.1; - } - if (relativePos < 70 && moved < 130) { - // Scrolling up. - return v - Math.abs(y * 0.1); - } - return v; - }); - } - function getDragOffset($helper) { - return postBodyContent.scrollTop - $helper.initialOffset; - } - function getDroppableTarget() { - var droppable = document.getElementById('frm-show-fields'); - while (droppable.querySelector('.frm-over-droppable')) { - droppable = droppable.querySelector('.frm-over-droppable'); - } - if ('frm-show-fields' === droppable.id && !droppable.classList.contains('frm-over-droppable')) { - droppable = false; - } - return droppable; - } - function handleFieldDrop(_, ui) { - if (!dragState.dragging) { - // dragState.dragging is set to true on drag start. - // The deactivate event gets called for every droppable. This check to make sure it happens once. - return; - } - dragState.dragging = false; - var draggable = ui.draggable[0]; - var placeholder = document.getElementById('frm_drag_placeholder'); - if (!placeholder) { - ui.helper.remove(); - debouncedSyncAfterDragAndDrop(); - return; - } - maybeOpenCollapsedPage(placeholder); - var $previousFieldContainer = ui.helper.parent(); - var previousSection = ui.helper.get(0).closest('ul.start_divider'); - var newSection = placeholder.closest('ul.start_divider'); - if (draggable.classList.contains('frm-new-field')) { - insertNewFieldByDragging(draggable.id); - } else { - moveFieldThatAlreadyExists(draggable, placeholder); - maybeMakeFieldGroupDraggableAfterDragging(placeholder.parentElement); - } - var previousSectionId = previousSection ? parseInt(previousSection.closest('.edit_field_type_divider').getAttribute('data-fid')) : 0; - var newSectionId = newSection ? parseInt(newSection.closest('.edit_field_type_divider').getAttribute('data-fid')) : 0; - placeholder.remove(); - ui.helper.remove(); - var $previousContainerFields = $previousFieldContainer.length ? getFieldsInRow($previousFieldContainer) : []; - maybeUpdatePreviousFieldContainerAfterDrop($previousFieldContainer, $previousContainerFields); - maybeUpdateDraggableClassAfterDrop(draggable, $previousContainerFields); - if (previousSectionId !== newSectionId) { - updateFieldAfterMovingBetweenSections(jQuery(draggable), previousSection); - } - debouncedSyncAfterDragAndDrop(); - } - - /** - * When a field is moved into a field group, make sure the field group is draggable. - * - * @since 6.24 - * - * @param {HTMLElement} placeholderParent - * @return {void} - */ - function maybeMakeFieldGroupDraggableAfterDragging(placeholderParent) { - var isDroppingIntoFieldGroup = placeholderParent.nodeName === 'UL' && !placeholderParent.classList.contains('start_divider') && 'frm-show-fields' !== placeholderParent.id; - if (!isDroppingIntoFieldGroup) { - return; - } - var fieldGroupLi = placeholderParent.closest('li'); - if (fieldGroupLi && !fieldGroupLi.classList.contains('ui-draggable')) { - makeDraggable(fieldGroupLi, '.frm-move'); - } - } - - /** - * If a page if collapsed, expand it before dragging since only the page break will move. - * - * @param {Element} placeholder - * @return {void} - */ - function maybeOpenCollapsedPage(placeholder) { - if (!placeholder.previousElementSibling || !placeholder.previousElementSibling.classList.contains('frm-is-collapsed')) { - return; - } - var $pageBreakField = jQuery(placeholder).prevUntil('[data-type="break"]'); - if (!$pageBreakField.length) { - return; - } - var collapseButton = $pageBreakField.find('.frm-collapse-page').get(0); - if (collapseButton) { - collapseButton.click(); - } - } - function maybeUpdatePreviousFieldContainerAfterDrop($previousFieldContainer, $previousContainerFields) { - if (!$previousFieldContainer.length) { - return; - } - if ($previousContainerFields.length) { - syncLayoutClasses($previousContainerFields.first()); - } else { - maybeDeleteAnEmptyFieldGroup($previousFieldContainer.get(0)); - } - } - function maybeUpdateDraggableClassAfterDrop(draggable, $previousContainerFields) { - if (0 !== $previousContainerFields.length || 1 !== getFieldsInRow(jQuery(draggable.parentNode)).length) { - syncLayoutClasses(jQuery(draggable)); - } - } - - /** - * Remove an empty field group, but don't remove an empty section. - * - * @param {Element} previousFieldContainer - * @return {void} - */ - function maybeDeleteAnEmptyFieldGroup(previousFieldContainer) { - var closestFieldBox = previousFieldContainer.closest('li.frm_field_box'); - if (closestFieldBox && !closestFieldBox.classList.contains('edit_field_type_divider')) { - closestFieldBox.remove(); - } - } - function handleDragOverYAxis(_ref) { - var droppable = _ref.droppable, - y = _ref.y, - placeholder = _ref.placeholder; - var $list = jQuery(droppable); - var top; - var $children = $list.children().not('.edit_field_type_end_divider'); - if (0 === $children.length) { - $list.prepend(placeholder); - top = 0; - } else { - var insertAtIndex = determineIndexBasedOffOfMousePositionInList($list, y); - if (insertAtIndex === $children.length) { - var $lastChild = jQuery($children.get(insertAtIndex - 1)); - top = $lastChild.offset().top + $lastChild.outerHeight(); - $list.append(placeholder); - - // Make sure nothing gets inserted after the end divider. - var $endDivider = $list.children('.edit_field_type_end_divider'); - if ($endDivider.length) { - $list.append($endDivider); - } - } else { - top = jQuery($children.get(insertAtIndex)).offset().top; - jQuery($children.get(insertAtIndex)).before(placeholder); - } - } - top -= $list.offset().top; - placeholder.style.top = "".concat(top, "px"); - } - function determineIndexBasedOffOfMousePositionInList($list, y) { - var $items = $list.children().not('.edit_field_type_end_divider'); - var length = $items.length; - var index; - var item; - var itemTop; - var returnIndex; - if (!document.querySelector('.frm-has-fields .frm_no_fields')) { - // Always return 0 when there are no fields. - return 0; - } - returnIndex = 0; - for (index = length - 1; index >= 0; --index) { - item = $items.get(index); - itemTop = jQuery(item).offset().top; - if (y > itemTop) { - returnIndex = index; - if (y > itemTop + jQuery(item).outerHeight() / 2) { - returnIndex = index + 1; - } - break; - } - } - return returnIndex; - } - function handleDragOverFieldGroup(_ref2) { - var droppable = _ref2.droppable, - x = _ref2.x, - placeholder = _ref2.placeholder; - var $row = jQuery(droppable); - var $children = getFieldsInRow($row); - if (!$children.length) { - return; - } - var left; - var insertAtIndex = determineIndexBasedOffOfMousePositionInRow($row, x); - if (insertAtIndex === $children.length) { - var $lastChild = jQuery($children.get(insertAtIndex - 1)); - left = $lastChild.offset().left + $lastChild.outerWidth(); - $row.append(placeholder); - } else { - left = jQuery($children.get(insertAtIndex)).offset().left; - jQuery($children.get(insertAtIndex)).before(placeholder); - var amountToOffsetLeftBy = 0 === insertAtIndex ? 4 : 8; // Offset by 8 in between rows, but only 4 for the first item in a group. - left -= amountToOffsetLeftBy; // Offset the placeholder slightly so it appears between two fields. - } - left -= $row.offset().left; - placeholder.style.left = "".concat(left, "px"); - } - function syncAfterDragAndDrop() { - fixUnwrappedListItems(); - toggleSectionHolder(); - maybeFixEndDividers(); - maybeDeleteEmptyFieldGroups(); - updateFieldOrder(); - var event = new Event('frm_sync_after_drag_and_drop', { - bubbles: false - }); - document.dispatchEvent(event); - } - function maybeFixEndDividers() { - document.querySelectorAll('.edit_field_type_end_divider').forEach(function (endDivider) { - return endDivider.parentNode.append(endDivider); - }); - } - function maybeDeleteEmptyFieldGroups() { - document.querySelectorAll('li.form_field_box:not(.form-field)').forEach(function (fieldGroup) { - return !fieldGroup.children.length && fieldGroup.remove(); - }); - } - function fixUnwrappedListItems() { - var lists = document.querySelectorAll('ul#frm-show-fields, ul.start_divider'); - lists.forEach(function (list) { - list.childNodes.forEach(function (child) { - if (child.classList === undefined) { - return; - } - if (child.classList.contains('edit_field_type_end_divider')) { - // Never wrap end divider in place. - return; - } - if (child.classList !== undefined && child.classList.contains('form-field')) { - wrapFieldLiInPlace(child); - } - }); - }); - } - function deleteEmptyDividerWrappers() { - var dividers = document.querySelectorAll('ul.start_divider'); - if (!dividers.length) { - return; - } - dividers.forEach(function (divider) { - var children = [].slice.call(divider.children); - children.forEach(function (child) { - if (0 === child.children.length) { - child.remove(); - } else if (1 === child.children.length && 'ul' === child.firstElementChild.nodeName.toLowerCase() && 0 === child.firstElementChild.children.length) { - child.remove(); - } - }); - }); - } - function getFieldsInRow($row) { - var $fields = jQuery(); - var row = $row.get(0); - if (!row.children) { - return $fields; - } - Array.from(row.children).forEach(function (child) { - if ('none' === child.style.display) { - return; - } - var classes = child.classList; - if (!classes.contains('form-field') || classes.contains('edit_field_type_end_divider') || classes.contains('frm-sortable-helper')) { - return; - } - $fields = $fields.add(child); - }); - return $fields; - } - function determineIndexBasedOffOfMousePositionInRow($row, x) { - var $inputs = getFieldsInRow($row); - var length = $inputs.length; - var index; - var input; - var inputLeft; - var returnIndex; - returnIndex = 0; - for (index = length - 1; index >= 0; --index) { - input = $inputs.get(index); - inputLeft = jQuery(input).offset().left; - if (x > inputLeft) { - returnIndex = index; - if (x > inputLeft + jQuery(input).outerWidth() / 2) { - returnIndex = index + 1; - } - break; - } - } - return returnIndex; - } - function syncLayoutClasses($item, type) { - var classToAddFunction; - if (type === undefined) { - type = 'even'; - } - var $fields = $item.parent().children('li.form-field, li.frmbutton_loadingnow').not('.edit_field_type_end_divider'); - var size = $fields.length; - var layoutClasses = getLayoutClasses(); - if ('even' === type && 5 !== size) { - $fields.each(getSyncLayoutClass(layoutClasses, getEvenClassForSize(size))); - } else if ('clear' === type) { - $fields.each(getSyncLayoutClass(layoutClasses, '')); - } else { - if (['left', 'right', 'middle', 'even'].includes(type)) { - classToAddFunction = function classToAddFunction(index) { - return getClassForBlock(size, type, index); - }; - } else { - classToAddFunction = function classToAddFunction(index) { - var size = type[index]; - return getLayoutClassForSize(size); - }; - } - $fields.each(getSyncLayoutClass(layoutClasses, classToAddFunction)); - } - updateFieldGroupControls($item.parent(), $fields.length); - } - function updateFieldGroupControls($row, count) { - var rowOffset = $row.offset(); - if (rowOffset === undefined) { - return; - } - var shouldShowControls = count >= 2; - var controls = document.getElementById('frm_field_group_controls'); - if (!controls) { - if (!shouldShowControls) { - // exit early. if we do not need controls and they do not exist, do nothing. - return; - } - controls = div(); - controls.id = 'frm_field_group_controls'; - controls.setAttribute('role', 'group'); - controls.setAttribute('tabindex', 0); - setFieldControlsHtml(controls); - builderPage.append(controls); - } - $row.append(controls); - controls.style.display = shouldShowControls ? 'block' : 'none'; - } - function setFieldControlsHtml(controls) { - var layoutOption = document.createElement('span'); - layoutOption.innerHTML = ''; - var layoutOptionLabel = __('Set Row Layout', 'formidable'); - addTooltip(layoutOption, layoutOptionLabel); - makeTabbable(layoutOption, layoutOptionLabel); - var moveOption = document.createElement('span'); - moveOption.innerHTML = ''; - moveOption.classList.add('frm-move'); - var moveOptionLabel = __('Move Field Group', 'formidable'); - addTooltip(moveOption, moveOptionLabel); - makeTabbable(moveOption, moveOptionLabel); - controls.innerHTML = ''; - controls.append(layoutOption); - controls.append(moveOption); - controls.append(getFieldControlsDropdown()); - } - function addTooltip(element, title) { - element.setAttribute('data-bs-toggle', 'tooltip'); - element.setAttribute('data-bs-container', 'body'); - element.setAttribute('title', title); - element.addEventListener('mouseover', function () { - if (null === element.getAttribute('data-original-title')) { - jQuery(element).tooltip(); - } - }); - } - function getFieldControlsDropdown() { - var dropdown = span({ - className: 'dropdown' - }); - var trigger = a({ - className: 'frm_bstooltip frm-hover-icon frm-dropdown-toggle dropdown-toggle', - children: [span({ - child: svg({ - href: '#frm_thick_more_vert_icon' - }) - }), span({ - className: 'screen-reader-text', - text: __('Toggle More Options Dropdown', 'formidable') - })] - }); - frmDom.setAttributes(trigger, { - title: __('More Options', 'formidable'), - 'data-bs-toggle': 'dropdown', - 'data-bs-container': 'body', - 'data-bs-display': 'static' - }); - makeTabbable(trigger, __('More Options', 'formidable')); - dropdown.append(trigger); - var ul = div({ - className: 'frm-dropdown-menu dropdown-menu dropdown-menu-right' - }); - ul.setAttribute('role', 'menu'); - dropdown.append(ul); - return dropdown; - } - function getSyncLayoutClass(layoutClasses, classToAdd) { - return function (itemIndex) { - var currentClassToAdd = 'function' === typeof classToAdd ? classToAdd(itemIndex) : classToAdd; - var length = layoutClasses.length; - var activeLayoutClass = false; - for (var layoutClassIndex = 0; layoutClassIndex < length; ++layoutClassIndex) { - var currentClass = layoutClasses[layoutClassIndex]; - if (this.classList.contains(currentClass)) { - activeLayoutClass = currentClass; - break; - } - } - var fieldId = this.dataset.fid; - if (fieldId === undefined) { - // we are syncing the drag/drop placeholder before the actual field has loaded. - // this will get called again afterward and the input will exist then. - this.classList.add(currentClassToAdd); - return; - } - moveFieldSettings(document.getElementById("frm-single-settings-".concat(fieldId))); - var layoutClassesInput = document.getElementById("frm_classes_".concat(fieldId)); - if (!layoutClassesInput) { - // not every field type has a layout class input. - return; - } - if (false === activeLayoutClass) { - if ('' !== currentClassToAdd) { - layoutClassesInput.value = layoutClassesInput.value.concat(" ".concat(currentClassToAdd)); - } - } else { - this.classList.remove(activeLayoutClass); - layoutClassesInput.value = layoutClassesInput.value.replace(activeLayoutClass, currentClassToAdd); - } - if (this.classList.contains('frm_first')) { - this.classList.remove('frm_first'); - layoutClassesInput.value = layoutClassesInput.value.replace('frm_first', '').trim(); - } - if (0 === itemIndex) { - this.classList.add('frm_first'); - layoutClassesInput.value = layoutClassesInput.value.concat(' frm_first'); - } - jQuery(layoutClassesInput).trigger('change'); - }; - } - function getLayoutClasses() { - return ['frm_full', 'frm_half', 'frm_third', 'frm_fourth', 'frm_sixth', 'frm_two_thirds', 'frm_three_fourths', 'frm1', 'frm2', 'frm3', 'frm4', 'frm5', 'frm6', 'frm7', 'frm8', 'frm9', 'frm10', 'frm11', 'frm12']; - } - function setupFieldOptionSorting(sort) { - var opts = { - items: '.frm_sortable_field_opts li', - axis: 'y', - opacity: 0.65, - forcePlaceholderSize: false, - handle: '.frm-drag', - helper: function helper(e, li) { - copyHelper = li.clone().insertAfter(li); - return li.clone(); - }, - stop: function stop(e, ui) { - if (copyHelper) { - copyHelper.remove(); - } - var fieldId = ui.item.attr('id').replace('frm_delete_field_', '').replace("-".concat(ui.item.data('optkey'), "_container"), ''); - resetDisplayedOpts(fieldId); - fieldUpdated(); - } - }; - jQuery(sort).sortable(opts); - } - - // Get the section where a field is dropped - function getSectionForFieldPlacement(currentItem) { - var section = ''; - if (currentItem !== undefined && !currentItem.hasClass('edit_field_type_divider')) { - section = currentItem.closest('.edit_field_type_divider'); - } - return section; - } - - // Get the form ID where a field is dropped - function getFormIdForFieldPlacement(section) { - var formId = ''; - if (section[0] !== undefined) { - var sDivide = section.children('.start_divider'); - sDivide.children('.edit_field_type_end_divider').appendTo(sDivide); - if (section.attr('data-formid') !== undefined) { - var fieldId = section.attr('data-fid'); - formId = jQuery("input[name=\"field_options[form_select_".concat(fieldId, "]\"]")).val(); - } - } - if (formId === undefined || formId === '') { - formId = thisFormId; - } - return formId; - } - - // Get the section ID where a field is dropped - function getSectionIdForFieldPlacement(section) { - var sectionId = 0; - if (section[0] !== undefined) { - sectionId = section.attr('id').replace('frm_field_id_', ''); - } - return sectionId; - } - - /** - * Update a field after it is dragged and dropped into, out of, or between sections - * - * @param {Object} currentItem - * @param {Object} previousSection - * @return {void} - */ - function updateFieldAfterMovingBetweenSections(currentItem, previousSection) { - if (!currentItem.hasClass('form-field')) { - // currentItem is a field group. Call for children recursively. - getFieldsInRow(jQuery(currentItem.get(0).firstChild)).each(function () { - updateFieldAfterMovingBetweenSections(jQuery(this), previousSection); - }); - return; - } - var fieldId = currentItem.attr('id').replace('frm_field_id_', ''); - var section = getSectionForFieldPlacement(currentItem); - var formId = getFormIdForFieldPlacement(section); - var sectionId = getSectionIdForFieldPlacement(section); - var previousFormId = previousSection ? getFormIdForFieldPlacement(jQuery(previousSection.parentNode)) : 0; - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_update_field_after_move', - form_id: formId, - field: fieldId, - section_id: sectionId, - previous_form_id: previousFormId, - nonce: frmGlobal.nonce - }, - success: function success() { - toggleSectionHolder(); - updateInSectionValue(fieldId, sectionId); - } - }); - } - - // Update the in_section field value - function updateInSectionValue(fieldId, sectionId) { - document.getElementById("frm_in_section_".concat(fieldId)).value = sectionId; - } - - /** - * Get the arguments for inserting a new field. - * - * @since 6.23 - * - * @param {string} fieldType The type of field to insert. - * @param {string} sectionId The section ID to insert into. - * @param {string} formId The form ID. - * @param {number} hasBreak Whether the field has a page break. - * - * @return {Object} Data object for the new field AJAX request. - */ - function getInsertNewFieldArgs(fieldType, sectionId, formId, hasBreak) { - var fieldArgs = { - action: 'frm_insert_field', - form_id: formId, - field_type: fieldType, - section_id: sectionId, - nonce: frmGlobal.nonce, - has_break: hasBreak - }; - - // Only send last row field IDs to update their order if this field isn't added to a repeater. - var isInRepeater = sectionId > 0 && document.getElementById('form_id').value !== formId; - if (!isInRepeater) { - fieldArgs.last_row_field_ids = getFieldIdsInSubmitRow(); - } - return fieldArgs; - } - - /** - * Returns true if it's a range field type and slider type is not selected. - * - * @since 6.23 - * - * @param {string} fieldType The field type to check. - * @return {boolean} True if range field without slider type selected. - */ - function shouldStopInsertingField(fieldType) { - return wp.hooks.applyFilters('frm_should_stop_inserting_field', false, fieldType); - } - - /** - * Add a new field by dragging and dropping it from the Fields sidebar - * - * @param {string} fieldType - */ - function insertNewFieldByDragging(fieldType) { - if (shouldStopInsertingField(fieldType)) { - wp.hooks.doAction('frm_stopped_inserting_by_dragging', fieldType); - return; - } - var placeholder = document.getElementById('frm_drag_placeholder'); - var loadingID = "".concat(fieldType.replace('|', '-'), "_").concat(getAutoId()); - var loading = tag('li', { - id: loadingID, - className: 'frm-wait frmbutton_loadingnow' - }); - var $placeholder = jQuery(loading); - var currentItem = jQuery(placeholder); - var section = getSectionForFieldPlacement(currentItem); - var formId = getFormIdForFieldPlacement(section); - var sectionId = getSectionIdForFieldPlacement(section); - placeholder.parentNode.insertBefore(loading, placeholder); - placeholder.remove(); - syncLayoutClasses($placeholder); - var hasBreak = 0; - if ('summary' === fieldType) { - // see if we need to insert a page break before this newly-added summary field. Check for at least 1 page break - hasBreak = jQuery(".frmbutton_loadingnow#".concat(loadingID)).prevAll('li[data-type="break"]').length ? 1 : 0; - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: getInsertNewFieldArgs(fieldType, sectionId, formId, hasBreak), - success: function success(msg) { - handleInsertFieldByDraggingResponse(msg, $placeholder); - var fieldId = checkMsgForFieldId(msg); - if (fieldId) { - /** - * Fires after a field is added. - * - * @since 6.23 - * - * @param {Object} fieldData The field data. - * @param {string} fieldData.field The field HTML. - * @param {string} fieldData.field_type The field type. - * @param {string} fieldData.form_id The form ID. - */ - wp.hooks.doAction('frm_after_field_added_in_form_builder', { - field: msg, - fieldId: fieldId, - fieldType: fieldType, - form_id: formId - }); - } - }, - error: handleInsertFieldError - }); - } - - /** - * @param {string} msg - * @param {Object} $placeholder jQuery object. - */ - function handleInsertFieldByDraggingResponse(msg, $placeholder) { - var replaceWith; - document.getElementById('frm_form_editor_container').classList.add('frm-has-fields'); - var $siblings = $placeholder.siblings('li.form-field').not('.edit_field_type_end_divider'); - if (!$siblings.length) { - // if dragging into a new row, we need to wrap the li first. - replaceWith = wrapFieldLi(msg); - } else { - replaceWith = msgAsjQueryObject(msg); - if (!$placeholder.get(0).parentNode.parentNode.classList.contains('ui-draggable')) { - // If a field group wasn't draggable because it only had a single field, make it draggable. - makeDraggable($placeholder.get(0).parentNode.parentNode, '.frm-move'); - } - } - $placeholder.replaceWith(replaceWith); - updateFieldOrder(); - afterAddField(msg, false); - if ($siblings.length) { - syncLayoutClasses($siblings.first()); - } - toggleSectionHolder(); - if (!$siblings.length) { - makeDroppable(replaceWith.get(0).querySelector('ul.frm_sorting')); - makeDraggable(replaceWith.get(0).querySelector('li.form-field'), '.frm-move'); - } else { - makeDraggable(replaceWith.get(0), '.frm-move'); - } - } - - /** - * Get the field ID from the response message. - * - * @since 6.23 - * - * @param {string} msg The response message containing the field ID. - * @return {number} The extracted field ID. - */ - function checkMsgForFieldId(msg) { - var result = msg.match(/data-fid="(\d+)"/); - return result ? parseInt(result[1]) : 0; - } - function getFieldIdsInSubmitRow() { - var submitField = document.querySelector('.edit_field_type_submit'); - if (!submitField) { - return []; - } - var lastRowFields = submitField.parentNode.children; - var ids = []; - for (var i = 0; i < lastRowFields.length; i++) { - ids.push(lastRowFields[i].dataset.fid); - } - return ids; - } - function moveFieldThatAlreadyExists(draggable, placeholder) { - placeholder.parentNode.insertBefore(draggable, placeholder); - } - function msgAsjQueryObject(msg) { - var element = div(); - element.innerHTML = msg; - return jQuery(element.firstChild); - } - function handleInsertFieldError(jqXHR, _, errorThrown) { - maybeShowInsertFieldError(errorThrown, jqXHR); - } - function maybeShowInsertFieldError(errorThrown, jqXHR) { - if (!jqXHRAborted(jqXHR)) { - infoModal("".concat(errorThrown, ". Please try again.")); - } - } - function jqXHRAborted(jqXHR) { - return jqXHR.status === 0 || jqXHR.readyState === 0; - } - - /** - * Get a unique id that automatically increments with every function call. - * Can be used for any UI that requires a unique id. - * Not to be used in data. - * - * @return {number} A unique auto-incremented ID. - */ - function getAutoId() { - return ++autoId; - } - - /** - * Determine if a draggable element can be droppable into a droppable element. - * - * Don't allow page break, embed form, or section inside section field - * Don't allow page breaks inside of field groups. - * Don't allow field groups with sections inside of sections. - * Don't allow field groups in field groups. - * Don't allow hidden fields inside of field groups but allow them in sections. - * Don't allow any fields below the submit button field. - * Don't allow submit button field above any fields. - * Don't allow GDPR fields in repeaters. - * - * @param {HTMLElement} draggable - * @param {HTMLElement} droppable - * @param {Event} event - * @return {boolean} Whether the drag operation is allowed. - */ - function allowDrop(draggable, droppable, event) { - if (false === droppable) { - // Don't show drop placeholder if dragging somewhere off of the droppable area. - return false; - } - if (droppable.closest('.frm-sortable-helper')) { - // Do not allow drop into draggable. - return false; - } - var isSubmitBtn = draggable.classList.contains('edit_field_type_submit'); - var containSubmitBtn = !draggable.classList.contains('form_field') && !!draggable.querySelector('.edit_field_type_submit'); - if ('frm-show-fields' === droppable.id) { - var draggableIndex = determineIndexBasedOffOfMousePositionInList(jQuery(droppable), event.clientY); - if (isSubmitBtn || containSubmitBtn) { - // Do not allow dropping submit button to above position. - var lastRowIndex = droppable.childElementCount - 1; - return draggableIndex > lastRowIndex; - } - - // Do not allow dropping other fields to below submit button. - var submitButtonIndex = jQuery(droppable.querySelector('.edit_field_type_submit').closest('#frm-show-fields > li')).index(); - return draggableIndex <= submitButtonIndex; - } - if (isSubmitBtn) { - if (droppable.classList.contains('start_divider')) { - // Don't allow dropping submit button into a repeater. - return false; - } - if (isLastRow(droppable.parentElement)) { - // Allow dropping submit button into the last row. - return true; - } - if (!isLastRow(droppable.parentElement.nextElementSibling)) { - // Don't a dropping submit button into the row that isn't the second one from bottom. - return false; - } - - // Allow dropping submit button into the second row from bottom if there is only submit button in the last row. - return !draggable.parentElement.querySelector('li.frm_field_box:not(.edit_field_type_submit)'); - } - var droppableIsARepeater = droppable.classList.contains('start_divider') && null !== droppable.closest('.repeat_section'); - var droppableIsInsideOfARepeater = null !== droppable.closest('.repeat_section'); - if (droppableIsARepeater || droppableIsInsideOfARepeater) { - var isGdpr = draggable.classList.contains('edit_field_type_gdpr') || draggable.id === 'gdpr'; - if (isGdpr) { - return false; - } - - /** - * @since 6.27 - * - * @param {boolean} denyDropInRepeater - * @param {HTMLElement} draggable - */ - var shouldDenyDropInRepeater = wp.hooks.applyFilters('frm_deny_drop_in_repeater', false, draggable); - if (shouldDenyDropInRepeater) { - return false; - } - } - if (!droppableIsARepeater) { - var $fieldsInRow = getFieldsInRow(jQuery(droppable)); - if (!groupCanFitAnotherField($fieldsInRow, jQuery(draggable))) { - // Field group is full and cannot accept another field. - return false; - } - if (draggable.id === 'divider' && droppable.closest('.start_divider')) { - return false; - } - } - var isNewField = draggable.classList.contains('frm-new-field'); - if (isNewField) { - return allowNewFieldDrop(draggable, droppable); - } - return allowMoveField(draggable, droppable); - } - - /** - * Checks if given element is the last row in form builder. - * - * @param {HTMLElement} element Element. - * @return {boolean} True if the element is the last row. - */ - function isLastRow(element) { - return element && element.matches('#frm-show-fields > li:last-child'); - } - - // Don't allow a new page break or hidden field in a field group. - // Don't allow a new field into a field group that includes a page break or hidden field. - // Don't allow a new section inside of a section. - // Don't allow an embedded form in a section. - function allowNewFieldDrop(draggable, droppable) { - var classes = draggable.classList; - var newPageBreakField = classes.contains('frm_tbreak'); - var newHiddenField = classes.contains('frm_thidden'); - var newSectionField = classes.contains('frm_tdivider'); - var newEmbedField = classes.contains('frm_tform'); - var newUserIdField = classes.contains('frm_tuser_id'); - var newFieldWillBeAddedToAGroup = !('frm-show-fields' === droppable.id || droppable.classList.contains('start_divider')); - if (newFieldWillBeAddedToAGroup) { - if (groupIncludesBreakOrHiddenOrUserId(droppable)) { - // Never allow any field beside a page break or a hidden field. - return false; - } - return !newHiddenField && !newPageBreakField && !newUserIdField; - } - var fieldTypeIsAlwaysAllowed = !newPageBreakField && !newHiddenField && !newSectionField && !newEmbedField; - if (fieldTypeIsAlwaysAllowed) { - return true; - } - var newFieldWillBeAddedToASection = droppable.classList.contains('start_divider') || null !== droppable.closest('.start_divider'); - if (newFieldWillBeAddedToASection) { - // Don't allow a section or an embedded form in a section. - return !newEmbedField && !newSectionField; - } - return true; - } - function allowMoveField(draggable, droppable) { - if (isFieldGroup(draggable)) { - return allowMoveFieldGroup(draggable, droppable); - } - var isPageBreak = draggable.classList.contains('edit_field_type_break'); - if (isPageBreak) { - // Page breaks are only allowed in the main list of fields, not in sections or in field groups. - return false; - } - if (droppable.classList.contains('start_divider')) { - return allowMoveFieldToSection(draggable); - } - var isHiddenField = draggable.classList.contains('edit_field_type_hidden'); - var isUserIdField = draggable.classList.contains('edit_field_type_user_id'); - if (isHiddenField || isUserIdField) { - // Hidden fields and user id fields should not be added to field groups since they're not shown - // and don't make sense with the grid distribution. - return false; - } - return allowMoveFieldToGroup(draggable, droppable); - } - function isFieldGroup(draggable) { - return draggable.classList.contains('frm_field_box') && !draggable.classList.contains('form-field'); - } - function allowMoveFieldGroup(fieldGroup, droppable) { - if (droppable.classList.contains('start_divider') && null === fieldGroup.querySelector('.start_divider')) { - // Allow a field group with no section inside of a section. - return true; - } - return false; - } - function allowMoveFieldToSection(draggable) { - var draggableIncludeEmbedForm = draggable.classList.contains('edit_field_type_form') || draggable.querySelector('.edit_field_type_form'); - if (draggableIncludeEmbedForm) { - // Do not allow an embedded form inside of a section. - return false; - } - var draggableIncludesSection = draggable.classList.contains('edit_field_type_divider') || draggable.querySelector('.edit_field_type_divider'); - if (draggableIncludesSection) { - // Do not allow a section inside of a section. - return false; - } - return true; - } - function allowMoveFieldToGroup(draggable, group) { - if (groupIncludesBreakOrHiddenOrUserId(group)) { - // Never allow any field beside a page break or a hidden field. - return false; - } - var isFieldGroup = jQuery(draggable).children('ul.frm_sorting').not('.start_divider').length > 0; - if (isFieldGroup) { - // Do not allow a field group directly inside of a field group unless it's in a section. - return false; - } - var draggableIncludesASection = draggable.classList.contains('edit_field_type_divider') || draggable.querySelector('.edit_field_type_divider'); - var draggableIsEmbedField = draggable.classList.contains('edit_field_type_form'); - var groupIsInASection = null !== group.closest('.start_divider'); - if (groupIsInASection && (draggableIncludesASection || draggableIsEmbedField)) { - // Do not allow a section or an embed field inside of a section. - return false; - } - return true; - } - function groupIncludesBreakOrHiddenOrUserId(group) { - return null !== group.querySelector('.edit_field_type_break, .edit_field_type_hidden, .edit_field_type_user_id'); - } - function groupCanFitAnotherField(fieldsInRow, $field) { - if (fieldsInRow.length < MAX_FIELD_GROUP_SIZE) { - return true; - } - if (fieldsInRow.length > MAX_FIELD_GROUP_SIZE) { - return false; - } - var fieldId = $field.attr('data-fid'); - // Allow the maximum number if we're not changing field groups. - return 1 === jQuery(fieldsInRow).filter("[data-fid=\"".concat(fieldId, "\"]")).length; - } - function loadFields(fieldId) { - var thisField = document.getElementById(fieldId); - var $thisField = jQuery(thisField); - var field = []; - var addHtmlToField = function addHtmlToField(element) { - var frmHiddenFdata = element.querySelector('.frm_hidden_fdata'); - element.classList.add('frm_load_now'); - if (frmHiddenFdata !== null) { - field.push(frmHiddenFdata.innerHTML); - } - }; - addHtmlToField(thisField); - var nextField = getNextField(thisField); - while (nextField && field.length < 15) { - addHtmlToField(nextField); - nextField = getNextField(nextField); - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_load_field', - field: field, - form_id: thisFormId, - nonce: frmGlobal.nonce - }, - success: function success(html) { - return handleAjaxLoadFieldSuccess(html, $thisField, field); - } - }); - } - function getNextField(field) { - var _field$parentNode; - if (field.nextElementSibling) { - return field.nextElementSibling; - } - return (_field$parentNode = field.parentNode) === null || _field$parentNode === void 0 || (_field$parentNode = _field$parentNode.closest('.frm_field_box')) === null || _field$parentNode === void 0 || (_field$parentNode = _field$parentNode.nextElementSibling) === null || _field$parentNode === void 0 ? void 0 : _field$parentNode.querySelector('.form-field'); - } - function handleAjaxLoadFieldSuccess(html, $thisField, field) { - var key; - var $nextSet; - html = html.replace(/^\s+|\s+$/g, ''); - if (html.indexOf('{') !== 0) { - jQuery('.frm_load_now').removeClass('.frm_load_now').html('Error'); - return; - } - html = JSON.parse(html); - for (key in html) { - jQuery("#frm_field_id_".concat(key)).replaceWith(html[key]); - var newReplacedField = document.getElementById("frm_field_id_".concat(key)); - if (newReplacedField) { - newReplacedField.querySelectorAll('[data-toggle]').forEach(function (toggle) { - return toggle.setAttribute('data-bs-toggle', toggle.getAttribute('data-toggle')); - }); - newReplacedField.querySelectorAll('.frm-dropdown-menu').forEach(function (dropdownMenu) { - return dropdownMenu.classList.add('dropdown-menu'); - }); - } - setupSortable("#frm_field_id_".concat(key, ".edit_field_type_divider ul.frm_sorting")); - makeDraggable(document.getElementById("frm_field_id_".concat(key))); - } - $nextSet = $thisField.nextAll('.frm_field_loading:not(.frm_load_now)'); - if ($nextSet.length) { - loadFields($nextSet.attr('id')); - } else { - // go up a level - $nextSet = jQuery(document.getElementById('frm-show-fields')).find('.frm_field_loading:not(.frm_load_now)'); - if ($nextSet.length) { - loadFields($nextSet.attr('id')); - } - } - initiateMultiselect(); - renumberPageBreaks(); - maybeHideQuantityProductFieldOption(); - var loadedEvent = new Event('frm_ajax_loaded_field', { - bubbles: false - }); - loadedEvent.frmFields = field.map(function (f) { - return JSON.parse(f); - }); - document.dispatchEvent(loadedEvent); - } - function addFieldClick() { - /*jshint validthis:true */ - var $thisObj = jQuery(this); - // there is no real way to disable a (with a valid href attribute) in HTML - https://css-tricks.com/how-to-disable-links/ - if ($thisObj.hasClass('disabled')) { - return false; - } - var $button = $thisObj.closest('.frmbutton'); - var fieldType = $button.attr('id'); - if ($button.hasClass('frm_at_limit')) { - showLimitModal(); - return false; - } - if (shouldStopInsertingField(fieldType)) { - // We do not want to return false here. - // Otherwise it causes issues with trying to add a new slider field - // when clicking the button. - return; - } - var hasBreak = 0; - if ('summary' === fieldType) { - hasBreak = $newFields.children('li[data-type="break"]').length > 0 ? 1 : 0; - } - var formId = thisFormId; - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: getInsertNewFieldArgs(fieldType, 0, formId, hasBreak), - success: function success(msg) { - handleAddFieldClickResponse(msg); - var fieldId = checkMsgForFieldId(msg); - if (fieldId) { - /** - * Fires after a field is added. - * - * @since 6.23 - * - * @param {Object} fieldData The field data. - * @param {string} fieldData.field The field HTML. - * @param {string} fieldData.field_type The field type. - * @param {string} fieldData.form_id The form ID. - */ - wp.hooks.doAction('frm_after_field_added_in_form_builder', { - field: msg, - fieldId: fieldId, - fieldType: fieldType, - form_id: formId - }); - } - }, - error: handleInsertFieldError - }); - return false; - } - function showLimitModal() { - var wrapper = document.querySelector('.frm_wrap'); - if (!wrapper) { - return; - } - var temporaryAnchor = document.createElement('a'); - temporaryAnchor.setAttribute('data-frmverify', __('This field type has reached its limit.', 'formidable')); - wrapper.append(temporaryAnchor); - temporaryAnchor.click(); - temporaryAnchor.remove(); - var confirmButton = document.getElementById('frm-confirmed-click'); - if (confirmButton) { - confirmButton.style.display = 'none'; - } - } - function handleAddFieldClickResponse(msg) { - document.getElementById('frm_form_editor_container').classList.add('frm-has-fields'); - var replaceWith = wrapFieldLi(msg); - var submitField = $newFields[0].querySelector('.edit_field_type_submit'); - if (!submitField) { - $newFields.append(replaceWith); - } else { - jQuery(submitField.closest('.frm_field_box:not(.form-field)')).before(replaceWith); - } - afterAddField(msg, true); - replaceWith.each(function () { - makeDroppable(this.querySelector('ul.frm_sorting')); - makeDraggable(this.querySelector('.form-field'), '.frm-move'); - }); - } - function insertFormField(fieldType) { - var fieldOptions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - return new Promise(function (resolve) { - var formId = thisFormId; - var hasBreak = 0; - if ('summary' === fieldType) { - hasBreak = $newFields.children('li[data-type="break"]').length > 0 ? 1 : 0; - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: Object.assign(getInsertNewFieldArgs(fieldType, 0, formId, hasBreak), { - field_options: fieldOptions - }), - success: function success(msg) { - resolve(msg); - setTimeout(function () { - updateFieldOrder(); - afterAddField(msg, true); - var fieldId = checkMsgForFieldId(msg); - if (fieldId) { - /** - * Fires after a field is added. - * - * @since 6.23 - * - * @param {Object} fieldData The field data. - * @param {string} fieldData.field The field HTML. - * @param {string} fieldData.field_type The field type. - * @param {string} fieldData.form_id The form ID. - */ - wp.hooks.doAction('frm_after_field_added_in_form_builder', { - field: msg, - fieldId: fieldId, - fieldType: fieldType, - form_id: formId - }); - } - }, 10); - }, - error: handleInsertFieldError - }); - }); - } - function maybeHideQuantityProductFieldOption() { - var hide = true; - var opts = document.querySelectorAll('.frmjs_prod_field_opt_cont'); - if ($newFields.find('li.edit_field_type_product').length > 1) { - hide = false; - } - for (var i = 0; i < opts.length; i++) { - opts[i].classList.toggle('frm_hidden', hide); - } - } - - /** - * Returns true if a field can be duplicated. - * - * @since 6.19 - * - * @param {HTMLElement} field - * @param {number} maxFieldsInGroup Maximum allowed fields in a group. - * - * @return {boolean} True if the field can be added to the group. - */ - function canDuplicateField(field, maxFieldsInGroup) { - if (field.classList.contains('frm-page-collapsed')) { - return false; - } - var fieldGroup = field.closest('li.frm_field_box:not(.form-field)'); - if (!fieldGroup) { - return true; - } - var fieldsInGroup = getFieldsInRow(jQuery(fieldGroup.querySelector('ul'))).length; - return fieldsInGroup < maxFieldsInGroup; - } - function duplicateField() { - var maxFieldsInGroup = MAX_FIELD_GROUP_SIZE; - var $field = jQuery(this).closest('li.form-field'); - var newRowId = this.getAttribute('frm-target-row-id'); - if (!(newRowId !== null && newRowId !== void 0 && newRowId.startsWith('frm_field_group_')) && !canDuplicateField($field.get(0), maxFieldsInGroup)) { - /* translators: %1$d: Maximum number of fields allowed in a field group. */ - infoModal(sprintf(__('You can only have a maximum of %1$d fields in a field group. Delete or move out a field from the group and try again.', 'formidable'), maxFieldsInGroup)); - return; - } - closeOpenFieldDropdowns(); - var fieldId = $field.data('fid'); - var children = fieldsInSection(fieldId); - var fieldOrder; - if (null !== newRowId) { - fieldOrder = this.getAttribute('frm-field-order'); - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_duplicate_field', - field_id: fieldId, - form_id: thisFormId, - children: children, - nonce: frmGlobal.nonce - }, - success: function success(msg) { - var _$field$0$querySelect; - var newRow; - var replaceWith; - if (null !== newRowId) { - newRow = document.getElementById(newRowId); - if (newRow) { - replaceWith = msgAsjQueryObject(msg); - jQuery(newRow).append(replaceWith); - makeDraggable(replaceWith.get(0), '.frm-move'); - if (null !== fieldOrder) { - newRow.lastElementChild.setAttribute('frm-field-order', fieldOrder); - } - jQuery(newRow).trigger('frm_added_duplicated_field_to_row', { - duplicatedFieldHtml: msg, - originalFieldId: fieldId - }); - afterAddField(msg, false); - setLayoutClassesForDuplicatedFieldInGroup($field.get(0), replaceWith.get(0)); - return; - } - } - if ($field.siblings('li.form-field').length) { - replaceWith = msgAsjQueryObject(msg); - $field.after(replaceWith); - syncLayoutClasses($field); - makeDraggable(replaceWith.get(0), '.frm-move'); - } else { - replaceWith = wrapFieldLi(msg); - $field.parent().parent().after(replaceWith); - makeDroppable(replaceWith.get(0).querySelector('ul.frm_sorting')); - makeDraggable(replaceWith.get(0).querySelector('li.form-field'), '.frm-move'); - } - updateFieldOrder(); - afterAddField(msg, false); - maybeDuplicateUnsavedSettings(fieldId, msg); - toggleOneSectionHolder(replaceWith.find('.start_divider')); - (_$field$0$querySelect = $field[0].querySelector('.frm-dropdown-menu.dropdown-menu-right')) === null || _$field$0$querySelect === void 0 || _$field$0$querySelect.classList.remove('show'); - setLayoutClassesForDuplicatedFieldInGroup($field.get(0), replaceWith.get(0)); - } - }); - return false; - } - - /** - * Sets the layout classes for a duplicated field in a field group from the layout classes of the original field. - * - * @param {HTMLElement} field The original field. - * @param {HTMLElement} newField The duplicated field. - * - * @return {void} - */ - function setLayoutClassesForDuplicatedFieldInGroup(field, newField) { - var _document$getElementB; - var hoverTarget = field.closest('.frm-field-group-hover-target'); - if (!hoverTarget || !isFieldGroup(hoverTarget.parentElement)) { - return; - } - var fieldId = field.dataset.fid; - var fieldClasses = (_document$getElementB = document.getElementById("frm_classes_".concat(fieldId))) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.value; - if (!fieldClasses) { - return; - } - fieldClasses = fieldClasses.replace('frm_first', ''); - if (!newField.className.includes(fieldClasses)) { - newField.className += " ".concat(fieldClasses); - var classesInput = document.getElementById("frm_classes_".concat(newField.dataset.fid)); - if (classesInput) { - classesInput.value = fieldClasses; - } - } - } - function maybeDuplicateUnsavedSettings(originalFieldId, newFieldHtml) { - var originalSettings = document.getElementById("frm-single-settings-".concat(originalFieldId)); - if (!originalSettings) { - return; - } - var newFieldId = jQuery(newFieldHtml).attr('data-fid'); - if (newFieldId === undefined) { - return; - } - var copySettings = document.getElementById("frm-single-settings-".concat(newFieldId)); - if (!copySettings) { - return; - } - var fieldOptionKeys = ['name', 'required', 'unique', 'read_only', 'placeholder', 'description', 'size', 'max', 'format', 'prepend', 'append', 'separate_value']; - originalSettings.querySelectorAll('input[name^="field_options["], textarea[name^="field_options["]').forEach(function (originalSetting) { - var key = getKeyFromSettingInput(originalSetting); - if ('options' === key) { - copyOption(originalSetting, copySettings, originalFieldId, newFieldId); - return; - } - if (!fieldOptionKeys.includes(key)) { - return; - } - var tagType = originalSetting.matches('input') ? 'input' : 'textarea'; - var copySetting = copySettings.querySelector("".concat(tagType, "[name=\"field_options[").concat(key, "_").concat(newFieldId, "]\"]")); - if (null === copySetting) { - return; - } - if ('checkbox' === originalSetting.type) { - if (originalSetting.checked !== copySetting.checked) { - jQuery(copySetting).trigger('click'); - } - } else if ('text' === originalSetting.type || 'textarea' === tagType) { - if (originalSetting.value !== copySetting.value) { - copySetting.value = originalSetting.value; - jQuery(copySetting).trigger('change'); - } - } - }); - var originalDefault = originalSettings.querySelector("input[name=\"default_value_".concat(originalFieldId, "\"]")); - if (null !== originalDefault) { - var copyDefault = copySettings.querySelector("input[name=\"default_value_".concat(newFieldId, "\"]")); - if (null !== copyDefault && originalDefault.value !== copyDefault.value) { - copyDefault.value = originalDefault.value; - jQuery(copyDefault).trigger('change'); - } - } - } - function copyOption(originalSetting, copySettings, originalFieldId, newFieldId) { - var remainingKeyDetails = originalSetting.name.substr(23 + "".concat(originalFieldId).length); - var copyKey = "field_options[options_".concat(newFieldId, "]").concat(remainingKeyDetails); - var copySetting = copySettings.querySelector("input[name=\"".concat(copyKey, "\"]")); - if (null !== copySetting && copySetting.value !== originalSetting.value) { - copySetting.value = originalSetting.value; - jQuery(copySetting).trigger('change'); - } - } - function getKeyFromSettingInput(input) { - var nameWithoutPrefix = input.name.substr(14); - var nameSplit = nameWithoutPrefix.split('_'); - nameSplit.pop(); - return nameSplit.join('_'); - } - function closeOpenFieldDropdowns() { - var openSettings = document.querySelector('.frm-field-settings-open'); - if (openSettings) { - openSettings.classList.remove('frm-field-settings-open'); - jQuery(document).off('click', '#frm_builder_page', handleClickOutsideOfFieldSettings); - jQuery('.frm-field-action-icons .dropdown.open').removeClass('open'); - } - } - function handleClickOutsideOfFieldSettings(event) { - if (!jQuery(event.originalEvent.target).closest('.frm-field-action-icons').length) { - closeOpenFieldDropdowns(); - } - } - function checkForMultiselectKeysOnMouseMove(event) { - var keyIsDown = Boolean(event.ctrlKey || event.metaKey || event.shiftKey); - jQuery(builderPage).toggleClass('frm-multiselect-key-is-down', keyIsDown); - checkForActiveHoverTarget(event); - } - function checkForActiveHoverTarget(event) { - var container = postBodyContent; - if (container.classList.contains('frm-dragging-field')) { - return; - } - if (null !== document.querySelector('.frm-field-group-hover-target .frm-field-settings-open')) { - // do not set a hover target if a dropdown is open for the current hover target. - return; - } - var elementFromPoint = document.elementFromPoint(event.clientX, event.clientY); - if (null !== elementFromPoint && !elementFromPoint.classList.contains('edit_field_type_divider')) { - var list = elementFromPoint.closest('ul.frm_sorting'); - if (null !== list && !list.classList.contains('start_divider') && 'frm-show-fields' !== list.id) { - var previousHoverTarget = maybeRemoveGroupHoverTarget(); - if (false !== previousHoverTarget && !jQuery(previousHoverTarget).is(list)) { - destroyFieldGroupPopup(); - } - updateFieldGroupControls(jQuery(list), getFieldsInRow(jQuery(list)).length); - list.classList.add('frm-field-group-hover-target'); - jQuery('#wpbody-content').on('mousemove', maybeRemoveHoverTargetOnMouseMove); - } - } - } - function maybeRemoveGroupHoverTarget() { - var controls = document.getElementById('frm_field_group_controls'); - if (controls) { - controls.style.display = 'none'; - } - var previousHoverTarget = document.querySelector('.frm-field-group-hover-target'); - if (!previousHoverTarget) { - return false; - } - jQuery('#wpbody-content').off('mousemove', maybeRemoveHoverTargetOnMouseMove); - previousHoverTarget.classList.remove('frm-field-group-hover-target'); - return previousHoverTarget; - } - function maybeRemoveHoverTargetOnMouseMove(event) { - var elementFromPoint = document.elementFromPoint(event.clientX, event.clientY); - if (null !== elementFromPoint && null !== elementFromPoint.closest('#frm-show-fields')) { - return; - } - maybeRemoveGroupHoverTarget(); - deleteTooltips(); - } - function onFieldActionDropdownShow(isFieldGroup) { - unselectFieldGroups(); - - // maybe offset the dropdown if it goes off the edge of the screen or container. - setTimeout(function () { - var ul = document.querySelector('.dropdown .frm-dropdown-menu.show'); - if (!ul) { - return; - } - if (null === ul.getAttribute('aria-label')) { - ul.setAttribute('aria-label', __('More Options', 'formidable')); - } - if (0 === ul.children.length) { - fillFieldActionDropdown(ul, true === isFieldGroup); - } - var $ul = jQuery(ul); - if ($ul.offset().left > jQuery(window).width() - $ul.outerWidth()) { - ul.style.left = "".concat(-$ul.outerWidth(), "px"); - } else if (postBodyContent && $ul.offset().left < postBodyContent.getBoundingClientRect().left) { - ul.style.right = 'auto'; - ul.style.left = '0'; - } - var firstAnchor = ul.firstElementChild.querySelector('a'); - if (firstAnchor) { - firstAnchor.focus(); - } - }, 0); - } - function onFieldGroupActionDropdownShow() { - onFieldActionDropdownShow(true); - } - function changeSectionStyle(e) { - var collapsedSection = e.target.closest('.frm-section-collapsed'); - if (!collapsedSection) { - return; - } - if (e.type === 'show') { - collapsedSection.style.zIndex = 3; - } else { - collapsedSection.style.zIndex = 1; - } - } - function fillFieldActionDropdown(ul, isFieldGroup) { - var classSuffix = isFieldGroup ? '_field_group' : '_field'; - var options = [getDeleteActionOption(isFieldGroup), getDuplicateActionOption(isFieldGroup)]; - if (!isFieldGroup) { - options.push({ - class: 'frm_select', - icon: 'frm_settings_icon', - label: __('Field Settings', 'formidable') - }); - } - options.forEach(function (option) { - var li = document.createElement('div'); - li.classList.add('frm_more_options_li', 'dropdown-item'); - var anchor = document.createElement('a'); - anchor.classList.add(option.class + classSuffix); - anchor.setAttribute('href', '#'); - makeTabbable(anchor); - var span = document.createElement('span'); - span.textContent = option.label; - anchor.innerHTML = ""); - anchor.append(document.createTextNode(' ')); - anchor.append(span); - li.append(anchor); - ul.append(li); - }); - } - function getDeleteActionOption(isFieldGroup) { - var option = { - class: 'frm_delete', - icon: 'frm_delete_icon' - }; - option.label = isFieldGroup ? __('Delete Group', 'formidable') : __('Delete', 'formidable'); - return option; - } - function getDuplicateActionOption(isFieldGroup) { - var option = { - class: 'frm_clone', - icon: 'frm_clone_icon' - }; - option.label = isFieldGroup ? __('Duplicate Group', 'formidable') : __('Duplicate', 'formidable'); - return option; - } - function wrapFieldLi(field) { - var wrapper = div(); - if ('string' === typeof field) { - wrapper.innerHTML = field; - } else { - wrapper.append(field); - } - var result = jQuery(); - Array.from(wrapper.children).forEach(function (li) { - result = result.add(jQuery('
          • ').addClass('frm_field_box').html(jQuery('
              ').addClass('frm_grid_container frm_sorting').append(li))); - }); - return result; - } - function wrapFieldLiInPlace(li) { - var ul = tag('ul', { - className: 'frm_grid_container frm_sorting' - }); - var wrapper = tag('li', { - className: 'frm_field_box', - child: ul - }); - li.replaceWith(wrapper); - ul.append(li); - makeDroppable(ul); - makeDraggable(wrapper, '.frm-move'); - } - function afterAddField(msg, addFocus) { - var regex = /id="(\S+)"/; - var match = regex.exec(msg); - var field = document.getElementById(match[1]); - var section = "#".concat(match[1], ".edit_field_type_divider ul.frm_sorting.start_divider"); - var $thisSection = jQuery(section); - var type = field.getAttribute('data-type'); - checkHtmlForNewFields(msg); - var toggled = false; - fieldUpdated(); - setupSortable(section); - if ('quantity' === type) { - // try to automatically attach a product field - maybeSetProductField(field); - } - if ('product' === type || 'quantity' === type) { - // quantity too needs to be a part of the if stmt especially cos of the very - // 1st quantity field (or even if it's just one quantity field in the form). - maybeHideQuantityProductFieldOption(); - } - if ($thisSection.length) { - $thisSection.parent('.frm_field_box').children('.frm_no_section_fields').addClass('frm_block'); - } else { - var $parentSection = jQuery(field).closest('ul.frm_sorting.start_divider'); - if ($parentSection.length) { - toggleOneSectionHolder($parentSection); - toggled = true; - } - } - if (msg.includes('frm-collapse-page')) { - renumberPageBreaks(); - } - addClass(field, 'frm-newly-added'); - setTimeout(function () { - field.classList.remove('frm-newly-added'); - }, 1000); - var lastRowOrderInput = field.querySelector('#frm-last-row-fields-order'); - if (lastRowOrderInput) { - updateLastRowFieldsOrder(JSON.parse(lastRowOrderInput.value)); - } - if (addFocus) { - var bounding = field.getBoundingClientRect(); - var container = document.getElementById('post-body-content'); - var inView = bounding.top >= 0 && bounding.left >= 0 && bounding.right <= (window.innerWidth || document.documentElement.clientWidth) && bounding.bottom <= (window.innerHeight || document.documentElement.clientHeight); - if (!inView) { - container.scroll({ - top: container.scrollHeight, - left: 0, - behavior: 'smooth' - }); - } - if (toggled === false) { - toggleOneSectionHolder($thisSection); - } - } - deselectFields(); - initiateMultiselect(); - document.getElementById('frm-show-fields').classList.remove('frm-over-droppable'); - maybeDisableFieldButtonAtLimit(type); - - // Bootstrap 5 uses data-bs-toggle instead of data-toggle, and requires that elements have the dropdown-menu class. - field.querySelectorAll('[data-toggle]').forEach(function (toggle) { - return toggle.setAttribute('data-bs-toggle', toggle.getAttribute('data-toggle')); - }); - field.querySelectorAll('.frm-dropdown-menu').forEach(function (dropdownMenu) { - return dropdownMenu.classList.add('dropdown-menu'); - }); - var addedEvent = new Event('frm_added_field', { - bubbles: false - }); - addedEvent.frmField = field; - addedEvent.frmSection = section; - addedEvent.frmType = type; - addedEvent.frmToggles = toggled; - document.dispatchEvent(addedEvent); - } - - /** - * @since 6.27 - * - * @param {string} type - * @return {void} - */ - function maybeDisableFieldButtonAtLimit(type) { - var button = document.getElementById(type); - if (button !== null && button !== void 0 && button.dataset.limit && countFieldTypeInForm(type) >= button.dataset.limit) { - button.classList.add('frm_at_limit'); - } - } - function updateLastRowFieldsOrder(fieldsOrder) { - if (!fieldsOrder || 'object' !== _typeof(fieldsOrder)) { - return; - } - Object.keys(fieldsOrder).forEach(function (fieldId) { - var orderInput = document.querySelector("input[name=\"field_options[field_order_".concat(fieldId, "]\"]")); - if (orderInput) { - orderInput.value = fieldsOrder[fieldId]; - } - }); - } - - /** - * Since multiple new fields may get added when a new field is inserted, check the HTML. - * - * @param {string} html - * @return {void} - */ - function checkHtmlForNewFields(html) { - var element = div(); - element.innerHTML = html; - element.querySelectorAll('.form-field').forEach(addFieldIdToDraftFieldsInput); - } - - /** - * @param {HTMLElement} field - * @return {void} - */ - function addFieldIdToDraftFieldsInput(field) { - if (!field.dataset.fid) { - return; - } - var draftInput = document.getElementById('draft_fields'); - if (!draftInput) { - return; - } - if ('' === draftInput.value) { - draftInput.value = field.dataset.fid; - } else { - var split = draftInput.value.split(','); - if (!split.includes(field.dataset.fid)) { - draftInput.value += ",".concat(field.dataset.fid); - } - } - } - function clearSettingsBox(preventFieldGroups) { - jQuery('#new_fields .frm-single-settings').addClass('frm_hidden'); - jQuery('#frm-options-panel > .frm-single-settings').removeClass('frm_hidden'); - deselectFields(preventFieldGroups); - } - function deselectFields(preventFieldGroups) { - jQuery('li.ui-state-default.selected').removeClass('selected'); - jQuery('.frm-show-field-settings.selected').removeClass('selected'); - if (!preventFieldGroups) { - unselectFieldGroups(); - } - } - function checkCalculationCreatedByUser() { - var calculation = this.value; - var warningMessage = checkMatchingParens(calculation); - warningMessage += checkShortcodes(calculation, this); - if (warningMessage !== '') { - infoModal("".concat(calculation, "\n\n").concat(warningMessage)); - } - } - - /** - * Checks a string for parens, brackets, and curly braces and returns a message if any unmatched are found. - * - * @param {string} formula The formula string to check. - * @return {string} Warning message if unmatched delimiters found, empty string otherwise. - */ - function checkMatchingParens(formula) { - var stack = []; - var formulaArray = formula.split(''); - var length = formulaArray.length; - var opening = ['{', '[', '(']; - var closing = { - '}': '{', - ')': '(', - ']': '[' - }; - var hasUnmatchedClosing = false; - var msg = ''; - var i; - var top; - for (i = 0; i < length; i++) { - if (opening.includes(formulaArray[i])) { - stack.push(formulaArray[i]); - continue; - } - if (Object.hasOwn(closing, formulaArray[i])) { - top = stack.pop(); - if (top !== closing[formulaArray[i]]) { - hasUnmatchedClosing = true; - } - } - } - if (stack.length > 0 || hasUnmatchedClosing) { - msg = "".concat(frmAdminJs.unmatched_parens, "\n\n"); - return msg; - } - return ''; - } - - /** - * Checks a calculation for shortcodes that shouldn't be in it and returns a message if found. - * - * @param {string} calculation The calculation formula. - * @param {HTMLElement} inputElement The input element for the calculation. - * @return {string} Warning message if invalid shortcodes found, empty string otherwise. - */ - function checkShortcodes(calculation, inputElement) { - var msg = checkNonNumericShortcodes(calculation, inputElement); - msg += checkNonFormShortcodes(calculation); - return msg; - } - - /** - * Checks if a numeric calculation has shortcodes that output non-numeric strings and returns a message if found. - * - * @param {string} calculation The calculation formula. - * @param {HTMLElement} inputElement The input element for the calculation. - * @return {string} Warning message if non-numeric shortcodes found, empty string otherwise. - */ - function checkNonNumericShortcodes(calculation, inputElement) { - var msg = ''; - if (isTextCalculation(inputElement)) { - return msg; - } - var nonNumericShortcodes = getNonNumericShortcodes(); - if (nonNumericShortcodes.test(calculation)) { - msg = "".concat(frmAdminJs.text_shortcodes, "\n\n"); - } - return msg; - } - - /** - * Determines if the calculation input is from a text calculation. - * - * @param {HTMLElement} inputElement The calculation input element. - */ - function isTextCalculation(inputElement) { - return jQuery(inputElement).siblings('label[for^="calc_type"]').children('input').prop('checked'); - } - - /** - * Returns a regular expression of shortcodes that can't be used in numeric calculations. - * - * @return {RegExp} Pattern matching non-numeric shortcodes. - */ - function getNonNumericShortcodes() { - return /\[(date|time|email|ip)\]/; - } - - /** - * Checks if a string has any shortcodes that do not belong in forms and returns a message if any are found. - * - * @param {string} formula The formula string to check. - * @return {string} Warning message if non-form shortcodes found, empty string otherwise. - */ - function checkNonFormShortcodes(formula) { - var nonFormShortcodes = getNonFormShortcodes(); - var msg = ''; - if (nonFormShortcodes.test(formula)) { - msg += "".concat(frmAdminJs.view_shortcodes, "\n\n"); - } - return msg; - } - - /** - * Returns a regular expression of shortcodes that can't be used in forms but can be used in Views, Email - * Notifications, and other Formidable areas. - * - * @return {RegExp} Pattern matching shortcodes not valid in forms. - */ - function getNonFormShortcodes() { - return /\[id\]|\[key\]|\[if\s\w+\]|\[foreach\s\w+\]|\[created-at(\s*)?/g; - } - function isCalcBoxType(box, listClass) { - var list = jQuery(box).find('.frm_code_list'); - return 1 === list.length && list.hasClass(listClass); - } - function extractExcludedOptions(exclude) { - var opts = []; - if (!Array.isArray(exclude)) { - return opts; - } - for (var i = 0; i < exclude.length; i++) { - if (exclude[i].startsWith('[')) { - opts.push(exclude[i]); - // remove it - exclude.splice(i, 1); - // https://love2dev.com/blog/javascript-remove-from-array/#remove-from-array-splice-value - i--; - } - } - return opts; - } - function hasExcludedOption(field, excludedOpts) { - var hasOption = false; - for (var i = 0; i < excludedOpts.length; i++) { - var inputs = document.getElementsByName(getFieldOptionInputName(excludedOpts[i], field.fieldId)); - // 2nd condition checks that there's at least one non-empty value - if (inputs.length && jQuery(inputs[0]).val()) { - hasOption = true; - break; - } - } - return hasOption; - } - function getFieldOptionInputName(opt, fieldId) { - var at = opt.indexOf(']'); - return "field_options".concat(opt.substring(0, at), "_").concat(fieldId).concat(opt.substring(at)); - } - function popCalcFields(element, force) { - var settingsBox = jQuery(element).closest('.frm-single-settings'); - var calc = settingsBox.find('.frm-calc-field'); - if (!force && (!calc.length || calc.val() === '' || calc.is(':hidden'))) { - return; - } - var isSummary = isCalcBoxType(element, 'frm_js_summary_list'); - var fieldId = settingsBox.find('input[name="frm_fields_submitted[]"]').val(); - var box; - if (force) { - box = element; - } else { - box = document.getElementById("frm-calc-box-".concat(fieldId)); - } - var exclude = getExcludeArray(box, isSummary); - var excludedOpts = extractExcludedOptions(exclude); - var fields = getFieldList(); - var list = document.getElementById("frm-calc-list-".concat(fieldId)); - list.innerHTML = ''; - for (var i = 0; i < fields.length; i++) { - if (exclude !== null && exclude !== void 0 && exclude.includes(fields[i].fieldType) || excludedOpts.length && hasExcludedOption(fields[i], excludedOpts)) { - continue; - } - var _a = document.createElement('a'); - _a.setAttribute('href', '#'); - _a.setAttribute('data-code', fields[i].fieldId); - _a.classList.add('frm_insert_code'); - _a.append(span(fields[i].fieldName)); - _a.append(span({ - className: 'frm-text-sm frm-text-grey-500', - text: "[".concat(fields[i].fieldId, "]") - })); - var li = document.createElement('li'); - li.classList.add("frm-field-list-".concat(fieldId)); - li.classList.add("frm-field-list-".concat(fields[i].fieldType)); - li.append(_a); - list.append(li); - } - } - function getExcludeArray(calcBox, isSummary) { - var codeList = calcBox.querySelector('.frm_code_list'); - var exclude = JSON.parse(codeList.getAttribute('data-exclude')); - if (isSummary) { - // includedExtras are those that are normally excluded from the summary but the form owner can choose to include, - // when they have been chosen to be included, then they can now be manually excluded in the calc box. - var includedExtras = getIncludedExtras(); - if (includedExtras.length) { - for (var i = 0; i < exclude.length; i++) { - if (includedExtras.includes(exclude[i])) { - // remove it - exclude.splice(i, 1); - // https://love2dev.com/blog/javascript-remove-from-array/#remove-from-array-splice-value - i--; - } - } - } - } - return exclude; - } - function getIncludedExtras() { - var checked = []; - var checkboxes = document.getElementsByClassName('frm_include_extras_field'); - for (var i = 0; i < checkboxes.length; i++) { - if (checkboxes[i].checked) { - checked.push(checkboxes[i].value); - } - } - return checked; - } - function rePopCalcFieldsForSummary() { - popCalcFields(jQuery('.frm-inline-modal.postbox:has(.frm_js_summary_list)')[0], true); - } - function getFieldList(fieldType) { - var i; - var fields = []; - var allFields = document.querySelectorAll('li.frm_field_box'); - var checkType = fieldType !== undefined; - for (i = 0; i < allFields.length; i++) { - // data-ftype is better (than data-type) cos of fields loaded by AJAX - which might not be ready yet - if (checkType && allFields[i].getAttribute('data-ftype') !== fieldType) { - continue; - } - var fieldId = allFields[i].getAttribute('data-fid'); - if (fieldId) { - fields.push({ - fieldId: fieldId, - fieldName: getPossibleValue("frm_name_".concat(fieldId)), - fieldType: getPossibleValue("field_options_type_".concat(fieldId)), - fieldKey: getPossibleValue("field_options_field_key_".concat(fieldId)) - }); - } - } - return wp.hooks.applyFilters('frm_admin_get_field_list', fields, fieldType, allFields); - } - function popProductFields(field) { - var i; - var checked; - var id; - var options = []; - var current = getCurrentProductFields(field); - var fName = field.getAttribute('data-frmfname'); - var products = getFieldList('product'); - var quantities = getFieldList('quantity'); - var isSelect = field.tagName === 'SELECT'; // for reverse compatibility. - // whether we have just 1 product and 1 quantity field & should therefore attach the latter to the former - var auto = 1 === quantities.length && 1 === products.length; - if (isSelect) { - // This fallback can be removed after 4.05. - current = field.getAttribute('data-frmcurrent'); - } - for (i = 0; i < products.length; i++) { - // let's be double sure it's string, else indexOf will fail - id = products[i].fieldId.toString(); - checked = auto || current.includes(id); - if (isSelect) { - // This fallback can be removed after 4.05. - checked = checked ? ' selected' : ''; - options.push("")); - } else { - checked = checked ? ' checked' : ''; - options.push(''); - } - } - field.innerHTML = options.join(''); - } - function getCurrentProductFields(prodFieldOpt) { - var products = prodFieldOpt.querySelectorAll('[type="checkbox"]:checked'); - var idsArray = []; - for (var i = 0; i < products.length; i++) { - idsArray.push(products[i].value); - } - return idsArray; - } - function popAllProductFields() { - var opts = document.querySelectorAll('.frmjs_prod_field_opt'); - for (var i = 0; i < opts.length; i++) { - popProductFields(opts[i]); - } - } - function maybeSetProductField(field) { - var fieldId = field.getAttribute('data-fid'); - var productFieldOpt = document.getElementById("field_options[product_field_".concat(fieldId, "]")); - if (!productFieldOpt) { - return; - } - popProductFields(productFieldOpt); - // in order to move its settings to that LHS panel where - // the update form resides, else it'll lose this setting - moveFieldSettings(document.getElementById("frm-single-settings-".concat(fieldId))); - } - - /** - * If the element doesn't exist, use a blank value. - * @param {string} id The element ID to look up. - */ - function getPossibleValue(id) { - var field = document.getElementById(id); - if (field) { - return field.value; - } - return ''; - } - function liveChanges() { - /*jshint validthis:true */ - var option; - var newValue = this.value; - var changes = document.getElementById(this.getAttribute('data-changeme')); - var att = this.getAttribute('data-changeatt'); - if (!changes) { - return; - } - if (att !== null) { - if (changes.tagName === 'SELECT' && att === 'placeholder') { - option = changes.options[0]; - if (option.value === '') { - option.innerHTML = newValue; - } else { - // Create a placeholder option if there are no blank values. - addBlankSelectOption(changes, newValue); - } - } else if (att === 'class') { - changeFieldClass(changes, this); - } else if (isSliderField(changes)) { - updateSliderFieldPreview(changes, att, newValue); - } else { - changes.setAttribute(att, newValue); - } - } else if (changes.id.indexOf('setup-message') === 0) { - if (newValue !== '') { - changes.innerHTML = ''; - } - } else { - changes.innerHTML = purifyHtml(newValue); - if ('TEXTAREA' === changes.nodeName && changes.classList.contains('wp-editor-area')) { - // Trigger change events on wysiwyg textareas so we can also sync default values in the visual tab. - jQuery(changes).trigger('change'); - } - if (changes.classList.contains('frm_primary_label') && 'break' === changes.nextElementSibling.getAttribute('data-ftype')) { - changes.nextElementSibling.querySelector('.frm_button_submit').textContent = newValue; - } - } - } - function updateSliderFieldPreview(field, att, newValue) { - if (frmGlobal.proIncludesSliderJs) { - var hookName = 'frm_update_slider_field_preview'; - var hookArgs = { - field: field, - att: att, - newValue: newValue - }; - wp.hooks.doAction(hookName, hookArgs); - return; - } - - // This functionality has been moved to pro since v5.4.3. This code should be removed eventually. - if ('value' === att) { - if ('' === newValue) { - newValue = getSliderMidpoint(field); - } - field.value = newValue; - } else { - field.setAttribute(att, newValue); - } - if (!['value', 'min', 'max'].includes(att)) { - return; - } - if (('max' === att || 'min' === att) && '' === getSliderDefaultValueInput(field.id)) { - field.value = getSliderMidpoint(field); - } - field.parentNode.querySelector('.frm_range_value').textContent = field.value; - } - function getSliderDefaultValueInput(previewInputId) { - return document.querySelector("input[data-changeme=\"".concat(previewInputId, "\"][data-changeatt=\"value\"]")).value; - } - function getSliderMidpoint(sliderInput) { - var max = parseFloat(sliderInput.getAttribute('max')); - var min = parseFloat(sliderInput.getAttribute('min')); - return (max - min) / 2 + min; - } - function isSliderField(previewInput) { - return 'range' === previewInput.type && previewInput.parentNode.classList.contains('frm_range_container'); - } - function toggleInvalidMsg() { - /*jshint validthis:true */ - var fieldId = this.getAttribute('data-fid'); - var value = ''; - ['field_options_max_', 'frm_format_'].forEach(function (id) { - var input = document.getElementById(id + fieldId); - if (!input) { - return; - } - value += input.value; - }); - var typeDropdown = document.getElementsByName("field_options[type_".concat(fieldId, "]"))[0]; - var fieldType = typeDropdown.options[typeDropdown.selectedIndex].value; - if (fieldType === 'text') { - toggleValidationBox('' !== value, ".frm_invalid_msg".concat(fieldId)); - } - } - function markRequired() { - /*jshint validthis:true */ - var thisid = this.id.replace('frm_', ''); - var fieldId = thisid.replace('req_field_', ''); - var checked = this.checked; - var label = jQuery("#field_label_".concat(fieldId, " .frm_required")); - toggleValidationBox(checked, ".frm_required_details".concat(fieldId)); - if (checked) { - var $reqBox = jQuery("input[name=\"field_options[required_indicator_".concat(fieldId, "]\"]")); - if ($reqBox.val() === '') { - $reqBox.val('*'); - } - label.removeClass('frm_hidden'); - } else { - label.addClass('frm_hidden'); - } - } - function toggleValidationBox(hasValue, messageClass) { - var $msg = jQuery(messageClass); - if (hasValue) { - $msg.fadeIn('fast').closest('.frm_validation_msg').fadeIn('fast'); - } else { - // Fade out validation options - var $validationBox = $msg.fadeOut('fast').closest('.frm_validation_box'); - var visibleCount = $validationBox.css('display', 'block').children(":not(".concat(messageClass, "):visible")).length; - $validationBox.css('display', ''); - if (visibleCount === 0) { - $msg.closest('.frm_validation_msg').fadeOut('fast'); - } - } - } - function markUnique() { - /*jshint validthis:true */ - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - var $thisField = jQuery(".frm_unique_details".concat(fieldId)); - if (this.checked) { - $thisField.fadeIn('fast').closest('.frm_validation_msg').fadeIn('fast'); - var $unqDetail = jQuery(".frm_unique_details".concat(fieldId, " input")); - if ($unqDetail.val() === '') { - $unqDetail.val(frmAdminJs.default_unique); - } - } else { - var $validationBox = $thisField.fadeOut('fast').closest('.frm_validation_box'); - var visibleCount = $validationBox.css('display', 'block').children(":not(.frm_unique_details".concat(fieldId, "):visible")).length; - $validationBox.css('display', ''); - if (visibleCount === 0) { - $thisField.closest('.frm_validation_msg').fadeOut('fast'); - } - } - } - - //Fade confirmation field and validation option in or out - function addConf() { - /*jshint validthis:true */ - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - var val = jQuery(this).val(); - var $thisField = jQuery(document.getElementById("frm_field_id_".concat(fieldId))); - toggleValidationBox(val !== '', ".frm_conf_details".concat(fieldId)); - if (val !== '') { - //Add default validation message if empty - var valMsg = jQuery(".frm_validation_box .frm_conf_details".concat(fieldId, " input")); - if (valMsg.val() === '') { - valMsg.val(frmAdminJs.default_conf); - } - setConfirmationFieldDescriptions(fieldId); - - //Add or remove class for confirmation field styling - if (val === 'inline') { - $thisField.removeClass('frm_conf_below').addClass('frm_conf_inline'); - } else if (val === 'below') { - $thisField.removeClass('frm_conf_inline').addClass('frm_conf_below'); - } - jQuery(".frm-conf-box-".concat(fieldId)).removeClass('frm_hidden'); - } else { - jQuery(".frm-conf-box-".concat(fieldId)).addClass('frm_hidden'); - setTimeout(function () { - $thisField.removeClass('frm_conf_inline frm_conf_below'); - }, 200); - } - } - function setConfirmationFieldDescriptions(fieldId) { - var fieldType = document.getElementsByName("field_options[type_".concat(fieldId, "]"))[0].value; - var fieldDescription = document.getElementById("field_description_".concat(fieldId)); - var hiddenDescName = "field_options[description_".concat(fieldId, "]"); - var newValue = frmAdminJs["enter_".concat(fieldType)]; - maybeSetNewDescription(fieldDescription, hiddenDescName, newValue); - var confFieldDescription = document.getElementById("conf_field_description_".concat(fieldId)); - var hiddenConfName = "field_options[conf_desc_".concat(fieldId, "]"); - var newConfValue = frmAdminJs["confirm_".concat(fieldType)]; - maybeSetNewDescription(confFieldDescription, hiddenConfName, newConfValue); - } - function maybeSetNewDescription(descriptionDiv, hiddenName, newValue) { - if (descriptionDiv.innerHTML === frmAdminJs.desc) { - // Set the visible description value and the hidden description value - descriptionDiv.innerHTML = newValue; - document.getElementsByName(hiddenName)[0].value = newValue; - } - } - function initBulkOptionsOverlay() { - /*jshint validthis:true */ - var $info = initModal('#frm-bulk-modal', '700px'); - if ($info === false) { - return; - } - jQuery('.frm-insert-preset').on('click', insertBulkPreset); - jQuery(builderForm).on('click', 'a.frm-bulk-edit-link', function (event) { - event.preventDefault(); - var content = ''; - var fieldId = jQuery(this).closest('[data-fid]').data('fid'); - var separate = usingSeparateValues(fieldId); - var product = isProductField(fieldId); - var optList = document.getElementById("frm_field_".concat(fieldId, "_opts")); - if (!optList) { - return; - } - var opts = optList.getElementsByTagName('li'); - document.getElementById('bulk-field-id').value = fieldId; - for (var i = 0; i < opts.length; i++) { - var key = opts[i].getAttribute('data-optkey'); - if (key !== '000') { - var label = document.getElementsByName("field_options[options_".concat(fieldId, "][").concat(key, "][label]"))[0]; - if (label !== undefined) { - content += label.value; - if (separate) { - content += "|".concat(document.getElementsByName("field_options[options_".concat(fieldId, "][").concat(key, "][value]"))[0].value); - } - if (product) { - content += "|".concat(document.getElementsByName("field_options[options_".concat(fieldId, "][").concat(key, "][price]"))[0].value); - } - content += '\r\n'; - } - } - if (i >= opts.length - 1) { - document.getElementById('frm_bulk_options').value = content; - } - } - $info.dialog('open'); - return false; - }); - jQuery('#frm-update-bulk-opts').on('click', function () { - var fieldId = document.getElementById('bulk-field-id').value; - var optionType = document.getElementById('bulk-option-type').value; - if (optionType) { - // Use custom handler for custom option type. - return; - } - this.classList.add('frm_loading_button'); - frmAdminBuild.updateOpts(fieldId, document.getElementById('frm_bulk_options').value, $info); - fieldUpdated(); - }); - } - function insertBulkPreset(event) { - /*jshint validthis:true */ - var opts = JSON.parse(this.getAttribute('data-opts')); - event.preventDefault(); - document.getElementById('frm_bulk_options').value = opts.join('\n'); - return false; - } - - //Add new option or "Other" option to radio/checkbox/dropdown - function addFieldOption() { - /*jshint validthis:true */ - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - var newOption = jQuery("#frm_field_".concat(fieldId, "_opts .frm_option_template")).prop('outerHTML'); - var optType = jQuery(this).data('opttype'); - var optKey = 0; - var oldKey = '000'; - var lastKey = getHighestOptKey(fieldId); - if (lastKey !== oldKey) { - optKey = lastKey + 1; - } - - //Update hidden field - if (optType === 'other') { - document.getElementById("other_input_".concat(fieldId)).value = 1; - - //Hide "Add Other" option now if this is radio field - var ftype = jQuery(this).data('ftype'); - if (ftype === 'radio' || ftype === 'select') { - jQuery(this).fadeOut('slow'); - } - var data = { - action: 'frm_add_field_option', - field_id: fieldId, - opt_key: optKey, - opt_type: optType, - nonce: frmGlobal.nonce - }; - jQuery.post(ajaxurl, data, function (msg) { - jQuery(document.getElementById("frm_field_".concat(fieldId, "_opts"))).append(msg); - resetDisplayedOpts(fieldId); - }); - } else { - newOption = newOption.replace(new RegExp("optkey=\"".concat(oldKey, "\""), 'g'), "optkey=\"".concat(optKey, "\"")); - newOption = newOption.replace(new RegExp("-".concat(oldKey, "_"), 'g'), "-".concat(optKey, "_")); - newOption = newOption.replace(new RegExp("-".concat(oldKey, "\""), 'g'), "-".concat(optKey, "\"")); - newOption = newOption.replace(new RegExp("\\[".concat(oldKey, "\\]"), 'g'), "[".concat(optKey, "]")); - newOption = newOption.replace('frm_hidden frm_option_template', ''); - newOption = { - newOption: newOption - }; - addSaveAndDragIconsToOption(fieldId, newOption); - var $thisOption = this.closest('.frm_single_option'); - if ($thisOption) { - $thisOption.after(newOption.newOption); - } else { - // Backwards compatibility "@since 6.24" - // Note: Keep it jQuery since some events are attached to the element - jQuery("#frm_field_".concat(fieldId, "_opts")).append(newOption.newOption); - } - resetDisplayedOpts(fieldId); - } - fieldOptionEnableAllRemoveButtons(this); - fieldUpdated(); - } - - /** - * Enable all remove buttons for field options. - * - * @param {HTMLElement} element The add option button element. - */ - function fieldOptionEnableAllRemoveButtons(element) { - var _element$closest; - // Make sure all remove buttons are enabled - var parentEl = element.classList.contains('frm-add-option-legacy') // Backwards compatibility "@since 6.24" - ? (_element$closest = element.closest('.frm-collapse-me')) === null || _element$closest === void 0 ? void 0 : _element$closest.querySelector('.frm_sortable_field_opts') : element.closest('.frm_sortable_field_opts'); - parentEl === null || parentEl === void 0 || parentEl.querySelectorAll('.frm_remove_tag.frm_disabled').forEach(function (button) { - return button.classList.remove('frm_disabled'); - }); - } - function getHighestOptKey(fieldId) { - var i = 0; - var optKey = 0; - var opts = jQuery("#frm_field_".concat(fieldId, "_opts li")); - var lastKey = 0; - for (i; i < opts.length; i++) { - optKey = opts[i].getAttribute('data-optkey'); - if (opts.length === 1) { - return optKey; - } - if (optKey !== '000') { - optKey = optKey.replace('other_', ''); - optKey = parseInt(optKey, 10); - } - if (!isNaN(lastKey) && (optKey > lastKey || lastKey === '000')) { - lastKey = optKey; - } - } - return lastKey; - } - function toggleMultSel() { - /*jshint validthis:true */ - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - toggleMultiSelect(fieldId, this.value); - } - function toggleMultiSelect(fieldId, value) { - var setting = jQuery(".frm_multiple_cont_".concat(fieldId)); - if (value === 'select') { - setting.fadeIn('fast'); - } else { - setting.fadeOut('fast'); - } - } - function toggleSepValues() { - /*jshint validthis:true */ - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - toggle(jQuery(".field_".concat(fieldId, "_option_key"))); - jQuery(".field_".concat(fieldId, "_option")).toggleClass('frm_with_key'); - } - function toggleImageOptions() { - /*jshint validthis:true */ - var $field = jQuery(this).closest('.frm-single-settings'); - var fieldId = $field.data('fid'); - var displayField = document.getElementById("frm_field_id_".concat(fieldId)); - refreshOptionDisplayNow(jQuery(this)); - toggle(jQuery(".field_".concat(fieldId, "_image_id"))); - toggle(jQuery(".frm_toggle_image_options_".concat(fieldId))); - toggle(jQuery(".frm_image_size_".concat(fieldId))); - toggle(jQuery(".frm_alignment_".concat(fieldId))); - toggle(jQuery(".frm-add-other#frm_add_field_".concat(fieldId))); - var hasImageOptions = imagesAsOptions(fieldId); - if (hasImageOptions) { - setAlignment(fieldId, 'inline'); - removeImageSizeClasses(displayField); - var imageSize = getImageOptionSize(fieldId); - displayField.classList.add('frm_image_options'); - displayField.classList.add("frm_image_size_".concat(imageSize)); - $field.find('.frm-bulk-edit-link').hide(); - } else { - displayField.classList.remove('frm_image_options'); - removeImageSizeClasses(displayField); - setAlignment(fieldId, 'block'); - $field.find('.frm-bulk-edit-link').show(); - } - - /** - * Fires when image options are toggled for a field. - * - * @param {HTMLElement} field The field element. - * @param {boolean} hasImageOptions Whether the field has image options enabled. - */ - wp.hooks.doAction('frm_image_options_toggled', $field[0], hasImageOptions); - } - function removeImageSizeClasses(field) { - field.classList.remove('frm_image_size_', 'frm_image_size_small', 'frm_image_size_medium', 'frm_image_size_large', 'frm_image_size_xlarge'); - } - function setAlignment(fieldId, alignment) { - jQuery("#field_options_align_".concat(fieldId)).val(alignment).trigger('change'); - } - function setImageSize() { - var $field = jQuery(this).closest('.frm-single-settings'); - var fieldId = $field.data('fid'); - var displayField = document.getElementById("frm_field_id_".concat(fieldId)); - refreshOptionDisplay(); - if (imagesAsOptions(fieldId)) { - removeImageSizeClasses(displayField); - displayField.classList.add('frm_image_options'); - displayField.classList.add("frm_image_size_".concat(getImageOptionSize(fieldId))); - } - } - function refreshOptionDisplayNow(object) { - var $field = object.closest('.frm-single-settings'); - var fieldID = $field.data('fid'); - jQuery(".field_".concat(fieldID, "_option")).trigger('change'); - } - function refreshOptionDisplay() { - /*jshint validthis:true */ - refreshOptionDisplayNow(jQuery(this)); - } - function addImageToOption(event) { - var _wp; - var imagePreview = event.target.closest('.frm_image_preview_wrapper'); - if (!((_wp = wp) !== null && _wp !== void 0 && _wp.media) || imagePreview !== null && imagePreview !== void 0 && imagePreview.dataset.upgrade) { - return; - } - event.preventDefault(); - wp.media.model.settings.post.id = 0; - var fileFrame = wp.media.frames.file_frame = wp.media({ - multiple: false, - library: { - type: ['image'] - } - }); - fileFrame.on('select', function () { - var attachment = fileFrame.state().get('selection').first().toJSON(); - var img = imagePreview.querySelector('img'); - img.setAttribute('src', attachment.url); - img.classList.remove('frm_hidden'); - img.removeAttribute('srcset'); // Prevent the old image from sticking around. - - imagePreview.querySelector('.frm_image_preview_frame').style.display = 'block'; - imagePreview.querySelector('.frm_image_preview_title').textContent = attachment.filename; - imagePreview.querySelector('.frm_choose_image_box').style.display = 'none'; - var $imagePreview = jQuery(imagePreview); - $imagePreview.siblings('input[name*="[label]"]').data('frmimgurl', attachment.url); - $imagePreview.find('input.frm_image_id').val(attachment.id).trigger('change'); - wp.media.model.settings.post.id = 0; - }); - fileFrame.open(); - } - function removeImageFromOption(event) { - var $this = jQuery(this); - var previewWrapper = $this.closest('.frm_image_preview_wrapper'); - event.preventDefault(); - event.stopPropagation(); - previewWrapper.find('img').attr('src', ''); - previewWrapper.find('.frm_image_preview_frame').hide(); - previewWrapper.find('.frm_choose_image_box').show(); - previewWrapper.find('input.frm_image_id').val(0).trigger('change'); - } - function toggleMultiselect() { - /*jshint validthis:true */ - var dropdown = jQuery(this).closest('li').find('.frm_form_fields select'); - if (this.checked) { - dropdown.attr('multiple', 'multiple'); - } else { - dropdown.removeAttr('multiple'); - } - } - - /** - * Allow typing on form switcher click without an extra click to search. - */ - function focusSearchBox() { - var searchBox = document.getElementById('dropform-search-input'); - if (searchBox) { - setTimeout(function () { - searchBox.focus(); - }, 100); - } - } - - /** - * Dismiss a warning message and send an AJAX request to update the dismissal state. - * - * @since 6.3 - * - * @param {Event} event The event object associated with the click on the dismiss icon. - */ - function dismissWarningMessage(event) { - var target = event.target; - var warningEl = target.closest('.frm_warning_style'); - jQuery(warningEl).fadeOut(400, function () { - return warningEl.remove(); - }); - var action = target.dataset.action; - var formData = new FormData(); - doJsonPost(action, formData); - } - - /** - * If a field is clicked in the builder, prevent inputs from changing. - * @param {Event} e The event to prevent. - */ - function stopFieldFocus(e) { - e.preventDefault(); - } - - /** - * Delete a field option. - */ - function deleteFieldOption() { - var parentLi = this.parentNode; - var parentUl = parentLi.parentNode; - - // If only 2 visible options, add disabled class to the other delete button - var visibleOptions = parentUl.querySelectorAll('li:not(.frm_hidden)'); - if (visibleOptions.length === 2) { - var _Array$from$find$quer; - (_Array$from$find$quer = Array.from(visibleOptions).find(function (li) { - return li !== parentLi; - }).querySelector('.frm_remove_tag')) === null || _Array$from$find$quer === void 0 || _Array$from$find$quer.classList.add('frm_disabled'); - } - - /*jshint validthis:true */ - var otherInput; - var fieldId = this.getAttribute('data-fid'); - jQuery(parentLi).fadeOut('fast', function () { - wp.hooks.doAction('frm_before_delete_field_option', this); - jQuery(parentLi).remove(); - var hasOther = jQuery(parentUl).find('.frm_other_option'); - if (hasOther.length < 1) { - otherInput = document.getElementById("other_input_".concat(fieldId)); - if (otherInput) { - otherInput.value = 0; - } - jQuery("#other_button_".concat(fieldId)).fadeIn('fast'); - } - }); - fieldUpdated(); - } - - /** - * If a radio button is set as default, allow a click to - * deselect it. - */ - function maybeUncheckRadio() { - /*jshint validthis:true */ - var $self = jQuery(this); - if ($self.is(':checked')) { - var uncheck = function uncheck() { - setTimeout(function () { - $self.prop('checked', false); - }, 0); - }; - var up; // eslint-disable-line prefer-const - var unbind = function unbind() { - $self.off('mouseup', up); - }; - up = function up() { - uncheck(); - unbind(); - }; - $self.on('mouseup', up); - $self.one('mouseout', unbind); - } - } - - /** - * If the field option has the default text, clear it out on click. - */ - function maybeClearOptText() { - /*jshint validthis:true */ - if (this.value === frmAdminJs.new_option) { - this.setAttribute('data-value-on-focus', this.value); - this.value = ''; - } - } - function confirmFieldsDeleteMessage(numberOfFields) { - /* translators: %1$s: Number of fields that are selected to be deleted. */ - return sprintf(__('Are you sure you want to delete these %1$s selected field(s)?', 'formidable'), numberOfFields); - } - function clickDeleteField() { - /*jshint validthis:true */ - var confirmMsg = frmAdminJs.conf_delete; - var maybeDivider = this.parentNode.parentNode.parentNode.parentNode.parentNode; - var li = maybeDivider.parentNode; - var field = jQuery(this).closest('li.form-field'); - var fieldId = field.data('fid'); - if (field.data('ftype') === 'divider') { - var fieldBoxes = document.querySelectorAll('.frm-field-group-hover-target .start_divider .frm_field_box'); - var fieldIdsToDelete = 0; - fieldBoxes.forEach(function (fieldBox) { - var fieldsInsideFieldBox = fieldBox.querySelectorAll('li.form-field'); - if (fieldsInsideFieldBox) { - fieldIdsToDelete += fieldsInsideFieldBox.length; - } - }); - if (fieldIdsToDelete) { - confirmMsg = confirmFieldsDeleteMessage(++fieldIdsToDelete); - } - } - if (li.classList.contains('frm-section-collapsed') || li.classList.contains('frm-page-collapsed')) { - return false; - } - - // If deleting a section, use a special message. - if (maybeDivider.className === 'divider_section_only') { - confirmMsg = frmAdminJs.conf_delete_sec; - } - this.setAttribute('data-frmverify', confirmMsg); - this.setAttribute('data-frmverify-btn', 'frm-button-red'); - this.setAttribute('data-deletefield', fieldId); - closeOpenFieldDropdowns(); - confirmLinkClick(this); - return false; - } - function clickSelectField() { - this.closest('li.form-field').click(); - } - function clickDeleteFieldGroup() { - var hoverTarget = document.querySelector('.frm-field-group-hover-target'); - if (!hoverTarget) { - return; - } - hoverTarget.classList.add('frm-selected-field-group'); - var decoy = document.createElement('div'); - decoy.classList.add('frm-delete-field-groups', 'frm_hidden'); - document.body.append(decoy); - decoy.click(); - } - function duplicateFieldGroup() { - var hoverTarget = document.querySelector('.frm-field-group-hover-target'); - if (!hoverTarget) { - return; - } - var newRowId = "frm_field_group_".concat(getAutoId()); - var placeholderUlChild = document.createTextNode(''); - wrapFieldLiInPlace(placeholderUlChild); - var newRow = jQuery(placeholderUlChild).closest('li').get(0); - newRow.classList.add('frm_hidden'); - var newRowUl = newRow.querySelector('ul'); - newRowUl.id = newRowId; - jQuery(hoverTarget.closest('li.frm_field_box')).after(newRow); - var $fields = getFieldsInRow(jQuery(hoverTarget)); - var syncDetails = []; - var injectedCloneOptions = []; - var expectedLength = $fields.length; - var originalFieldIdByDuplicatedFieldId = {}; - var duplicatedCount = 0; - jQuery(newRow).on('frm_added_duplicated_field_to_row', function (_, args) { - originalFieldIdByDuplicatedFieldId[jQuery(args.duplicatedFieldHtml).attr('data-fid')] = args.originalFieldId; - if (expectedLength > ++duplicatedCount) { - return; - } - var $newRowUl = jQuery(newRowUl); - var $duplicatedFields = getFieldsInRow($newRowUl); - injectedCloneOptions.forEach(function (cloneOption) { - cloneOption.remove(); - }); - for (var index = 0; index < expectedLength; ++index) { - $newRowUl.append($newRowUl.children("li.form-field[frm-field-order=\"".concat(index, "\"]"))); - } - syncLayoutClasses($duplicatedFields.first(), syncDetails); - newRow.classList.remove('frm_hidden'); - updateFieldOrder(); - getFieldsInRow($newRowUl).each(function () { - maybeDuplicateUnsavedSettings(originalFieldIdByDuplicatedFieldId[this.getAttribute('data-fid')], jQuery(this).prop('outerHTML')); - }); - }); - $fields.each(function (index) { - var cloneOption = document.createElement('li'); - cloneOption.classList.add('frm_clone_field'); - cloneOption.setAttribute('frm-target-row-id', newRowId); - cloneOption.setAttribute('frm-field-order', index); - this.append(cloneOption); - cloneOption.click(); - injectedCloneOptions.push(cloneOption); - syncDetails.push(getSizeOfLayoutClass(getLayoutClassName(this.classList))); - }); - } - function clickFieldGroupLayout() { - var hoverTarget = document.querySelector('.frm-field-group-hover-target'); - if (!hoverTarget) { - return; - } - deselectFields(); - var sizeOfFieldGroup = getSizeOfFieldGroupFromChildElement(hoverTarget.querySelector('li.form-field')); - hoverTarget.classList.add('frm-has-open-field-group-popup'); - jQuery(document).on('click', '#frm_builder_page', destroyFieldGroupPopupOnOutsideClick); - var popupWrapper = div(); - popupWrapper.style.position = 'relative'; - popupWrapper.append(getFieldGroupPopup(sizeOfFieldGroup, this)); - this.parentNode.append(popupWrapper); - var firstLayoutOption = popupWrapper.querySelector('.frm-row-layout-option'); - if (firstLayoutOption) { - firstLayoutOption.focus(); - } - } - function destroyFieldGroupPopupOnOutsideClick(event) { - if (event.target.classList.contains('frm-custom-field-group-layout') || event.target.classList.contains('frm-cancel-custom-field-group-layout')) { - return; - } - if (!jQuery(event.target).closest('#frm_field_group_controls').length && !jQuery(event.target).closest('#frm_field_group_popup').length) { - destroyFieldGroupPopup(); - } - } - function getSizeOfFieldGroupFromChildElement(element) { - var $ul = jQuery(element).closest('ul'); - if ($ul.length) { - return getFieldsInRow($ul).length; - } - return getSelectedFieldCount(); - } - function getFieldGroupPopup(sizeOfFieldGroup, childElement) { - var popup = document.getElementById('frm_field_group_popup'); - if (!popup) { - popup = div(); - } else { - popup.innerHTML = ''; - } - popup.id = 'frm_field_group_popup'; - var wrapper = div(); - wrapper.style.padding = '0 24px 12px'; - wrapper.append(getRowLayoutTitle()); - var rowLayoutOptions = getRowLayoutOptions(sizeOfFieldGroup); - var ul = childElement.closest('ul.frm_sorting'); - if (ul) { - maybeMarkRowLayoutAsActive(ul, rowLayoutOptions); - } - wrapper.append(rowLayoutOptions); - popup.append(wrapper); - popup.append(separator()); - if (sizeOfFieldGroup <= 6) { - popup.append(getCustomLayoutOption()); - } - popup.append(getBreakIntoDifferentRowsOption()); - return popup; - } - function maybeMarkRowLayoutAsActive(activeRow, options) { - var length = options.children.length; - for (var index = 0; index < length; ++index) { - var currentRow = options.children[index]; - if (rowLayoutsMatch(currentRow, activeRow)) { - currentRow.classList.add('frm-active-row-layout'); - return; - } - } - } - function separator() { - return document.createElement('hr'); - } - function getCustomLayoutOption() { - var option = div(); - option.textContent = __('Custom layout', 'formidable'); - jQuery(option).prepend(getIconClone('frm_gear_svg')); - option.classList.add('frm-custom-field-group-layout'); - makeTabbable(option); - return option; - } - function makeTabbable(element, ariaLabel) { - element.setAttribute('tabindex', 0); - element.setAttribute('role', 'button'); - if (ariaLabel !== undefined) { - element.setAttribute('aria-label', ariaLabel); - } - } - function getIconClone(iconId) { - var clone = document.getElementById(iconId).cloneNode(true); - clone.id = ''; - return clone; - } - function getBreakIntoDifferentRowsOption() { - var option = div(); - option.textContent = __('Break into rows', 'formidable'); - jQuery(option).prepend(getIconClone('frm_break_field_group_svg')); - option.classList.add('frm-break-field-group'); - makeTabbable(option); - return option; - } - function getRowLayoutTitle() { - var rowLayoutTitle = div(); - rowLayoutTitle.classList.add('frm-row-layout-title'); - rowLayoutTitle.textContent = __('Row Layout', 'formidable'); - return rowLayoutTitle; - } - function getRowLayoutOptions(size) { - var wrapper = getEmptyGridContainer(); - if (size > 6) { - wrapper.append(getRowLayoutOption(size, 'even')); - return wrapper; - } - if (5 !== size) { - wrapper.append(getRowLayoutOption(size, 'even')); - } - if (size % 2 === 1) { - // only include the middle option for odd numbers because even doesn't make a lot of sense. - wrapper.append(getRowLayoutOption(size, 'middle')); - } - if (size < 6) { - wrapper.append(getRowLayoutOption(size, 'left')); - wrapper.append(getRowLayoutOption(size, 'right')); - } else { - var padding = div(); - padding.classList.add('frm_fourth'); - wrapper.prepend(padding); - } - return wrapper; - } - function getRowLayoutOption(size, type) { - var option = div(); - option.classList.add('frm-row-layout-option'); - makeTabbable(option, type); - var useClass; - switch (size) { - case 6: - useClass = 'frm_half'; - break; - case 5: - useClass = 'frm_third'; - break; - default: - if (size > 6) { - // We only show a single option at 6-12, so we use the full width. - useClass = 'frm_full'; - } else { - useClass = size % 2 === 1 ? 'frm_fourth' : 'frm_third'; - } - break; - } - option.classList.add(useClass); - option.setAttribute('layout-type', type); - option.append(getRowForSizeAndType(size, type)); - return option; - } - function rowLayoutsMatch(row1, row2) { - return getRowLayoutAsKey(row1) === getRowLayoutAsKey(row2); - } - function getRowLayoutAsKey(row) { - var $fields; - if (row.classList.contains('frm-row-layout-option')) { - $fields = jQuery(row).find('.frm_grid_container').children(); - } else { - $fields = getFieldsInRow(jQuery(row)); - } - var sizes = []; - $fields.each(function () { - sizes.push(getSizeOfLayoutClass(getLayoutClassName(this.classList))); - }); - return sizes.join('-'); - } - function getRowForSizeAndType(size, type) { - var row = getEmptyGridContainer(); - for (var index = 0; index < size; ++index) { - var block = div(); - block.classList.add(getClassForBlock(size, type, index)); - block.style.height = '16px'; - block.style.background = '#9EA9B8'; - block.style.borderRadius = '1px'; - row.append(block); - } - return row; - } - - /** - * @param {number} size 2-12. - * @param {string} type even, middle, left, or right. - * @param {number} index 0-5. - * @return {string} The class name. - */ - function getClassForBlock(size, type, index) { - if ('even' === type) { - return getEvenClassForSize(size, index); - } else if ('middle' === type) { - if (3 === size) { - return 1 === index ? 'frm6' : 'frm3'; - } - if (5 === size) { - return 2 === index ? 'frm4' : 'frm2'; - } - } else if ('left' === type) { - return 0 === index ? getLargeClassForSize(size) : getSmallClassForSize(size); - } else if ('right' === type) { - return index === size - 1 ? getLargeClassForSize(size) : getSmallClassForSize(size); - } - return 'frm12'; - } - - /** - * @param {number} size 2-12. - * @param {number|undefined} index 0-5. - * @return {string} The class name. - */ - function getEvenClassForSize(size, index) { - if (size > 6) { - return 'frm1'; - } - if ([2, 3, 4, 6].includes(size)) { - return getLayoutClassForSize(12 / size); - } - if (5 === size && index !== undefined) { - return 0 === index ? 'frm4' : 'frm2'; - } - return 'frm12'; - } - function getSmallClassForSize(size) { - switch (size) { - case 2: - case 3: - return 'frm3'; - case 4: - return 'frm2'; - case 5: - return 'frm2'; - case 6: - return 'frm1'; - default: - return 'frm12'; - } - } - function getLargeClassForSize(size) { - switch (size) { - case 2: - return 'frm9'; - case 3: - case 4: - return 'frm6'; - case 5: - return 'frm4'; - case 6: - return 'frm7'; - default: - return 'frm12'; - } - } - function getEmptyGridContainer() { - var wrapper = div(); - wrapper.classList.add('frm_grid_container'); - return wrapper; - } - - /** - * Handle when a field group layout option (that sets grid classes/column sizing) is selected in the "Row Layout" popup. - * - * @return {void} - */ - function handleFieldGroupLayoutOptionClick() { - var row = document.querySelector('.frm-field-group-hover-target'); - if (!row) { - // The field group layout options also get clicked when merging multiple rows. - // The following code isn't required for multiple rows though so just exit early. - return; - } - var type = this.getAttribute('layout-type'); - syncLayoutClasses(getFieldsInRow(jQuery(row)).first(), type); - destroyFieldGroupPopup(); - } - function handleFieldGroupLayoutOptionInsideMergeClick() { - var $ul = mergeSelectedFieldGroups(); - var type = this.getAttribute('layout-type'); - syncLayoutClasses(getFieldsInRow($ul).first(), type); - unselectFieldGroups(); - } - function mergeSelectedFieldGroups() { - var $selectedFieldGroups = jQuery('.frm-selected-field-group'); - var $firstGroupUl = $selectedFieldGroups.first(); - $selectedFieldGroups.not($firstGroupUl).each(function () { - getFieldsInRow(jQuery(this)).each(function () { - var previousParent = this.parentNode; - getFieldsInRow($firstGroupUl).last().after(this); - if (!jQuery(previousParent).children('li.form-field').length) { - // clean up the previous field group if we've removed all of its fields. - previousParent.closest('li.frm_field_box').remove(); - } - }); - }); - updateFieldOrder(); - syncLayoutClasses(getFieldsInRow($firstGroupUl).first()); - return $firstGroupUl; - } - function customFieldGroupLayoutClick() { - if (null !== this.closest('.frm-merge-fields-into-row')) { - return; - } - var $fields = getFieldsInRow(jQuery('.frm-field-group-hover-target')); - setupCustomLayoutOptions($fields); - } - function setupCustomLayoutOptions($fields) { - var size = $fields.length; - var popup = document.getElementById('frm_field_group_popup'); - popup.innerHTML = ''; - var wrapper = div(); - wrapper.style.padding = '0 24px'; - var layoutClass = getEvenClassForSize(5 === size ? 6 : size); - var inputRow = div(); - inputRow.style.padding = '20px 0'; - inputRow.classList.add('frm_grid_container'); - if (5 === size) { - // add a span to pad the inputs by 1 column, to account for the missing 2 columns. - var paddingElement = document.createElement('span'); - paddingElement.classList.add('frm1'); - inputRow.append(paddingElement); - } - var inputValueOverride = getSelectedFieldCount() > 0 ? getSizeOfLayoutClass(getEvenClassForSize(size)) : false; - if (false !== inputValueOverride && inputValueOverride >= 12) { - inputValueOverride = Math.floor(12 / size); - } - for (var index = 0; index < size; ++index) { - var inputField = document.createElement('input'); - inputField.type = 'text'; - inputField.classList.add(layoutClass); - inputField.classList.add('frm-custom-grid-size-input'); - inputField.value = false !== inputValueOverride ? inputValueOverride : getSizeOfLayoutClass(getLayoutClassName($fields.get(index).classList)); - inputRow.append(inputField); - } - var heading = div(); - heading.classList.add('frm-builder-popup-heading'); - heading.textContent = __('Enter number of columns for each field', 'formidable'); - var label = div(); - label.classList.add('frm-builder-popup-subheading'); - label.textContent = __('Layouts are based on a 12-column grid system', 'formidable'); - wrapper.append(heading); - wrapper.append(label); - wrapper.append(inputRow); - var buttonsWrapper = div(); - buttonsWrapper.style.textAlign = 'right'; - var cancelButton = getSecondaryButton(); - cancelButton.textContent = __('Cancel', 'formidable'); - cancelButton.classList.add('frm-cancel-custom-field-group-layout'); - cancelButton.style.marginRight = '10px'; - var saveButton = getPrimaryButton(); - saveButton.textContent = __('Save', 'formidable'); - saveButton.classList.add('frm-save-custom-field-group-layout'); - buttonsWrapper.append(cancelButton); - buttonsWrapper.append(saveButton); - wrapper.append(buttonsWrapper); - popup.append(wrapper); - setTimeout(function () { - var firstInput = popup.querySelector('input.frm-custom-grid-size-input').focus(); - if (firstInput) { - firstInput.focus(); - } - }, 0); - } - function customFieldGroupLayoutInsideMergeClick() { - var $fields = jQuery('.frm-selected-field-group li.form-field'); - setupCustomLayoutOptions($fields); - } - function getPrimaryButton() { - var button = getButton(); - button.classList.add('button-primary', 'frm-button-primary'); - return button; - } - function getSecondaryButton() { - var button = getButton(); - button.classList.add('button-secondary', 'frm-button-secondary'); - return button; - } - function getButton() { - var button = document.createElement('a'); - button.setAttribute('href', '#'); - button.classList.add('button'); - button.style.textDecoration = 'none'; - return button; - } - function getSizeOfLayoutClass(className) { - switch (className) { - case 'frm_half': - return 6; - case 'frm_third': - return 4; - case 'frm_two_thirds': - return 8; - case 'frm_fourth': - return 3; - case 'frm_three_fourths': - return 9; - case 'frm_sixth': - return 2; - default: - if (0 === className.indexOf('frm')) { - return parseInt(className.substr(3)); - } - - // Anything missing a layout class should be a full width row. - return 12; - } - } - function getLayoutClassName(classList) { - var classes = getLayoutClasses(); - for (var index = 0; index < classes.length; ++index) { - var currentClass = classes[index]; - if (classList.contains(currentClass)) { - return currentClass; - } - } - return ''; - } - function getLayoutClassForSize(size) { - return "frm".concat(size); - } - function breakFieldGroupClick() { - var row = document.querySelector('.frm-field-group-hover-target'); - breakRow(row); - destroyFieldGroupPopup(); - } - function breakRow(row) { - var $row = jQuery(row); - getFieldsInRow($row).each(function (index) { - var field = this; - if (0 !== index) { - $row.parent().after(wrapFieldLi(field)); - } - stripLayoutFromFields(jQuery(field)); - }); - } - function stripLayoutFromFields(field) { - syncLayoutClasses(field, 'clear'); - } - function focusFieldGroupInputOnClick() { - this.select(); - } - function cancelCustomFieldGroupClick() { - revertToFieldGroupPopupFirstPage(this); - } - function revertToFieldGroupPopupFirstPage(triggerElement) { - jQuery(document.getElementById('frm_field_group_popup')).replaceWith(getFieldGroupPopup(getSizeOfFieldGroupFromChildElement(triggerElement), triggerElement)); - } - function destroyFieldGroupPopup() { - var popup = document.getElementById('frm_field_group_popup'); - if (!popup) { - return; - } - var wrapper = document.querySelector('.frm-has-open-field-group-popup'); - if (wrapper) { - wrapper.classList.remove('frm-has-open-field-group-popup'); - popup.parentNode.remove(); - } - jQuery(document).off('click', '#frm_builder_page', destroyFieldGroupPopupOnOutsideClick); - } - function saveCustomFieldGroupClick() { - var syncDetails = []; - jQuery(document.getElementById('frm_field_group_popup').querySelectorAll('.frm_grid_container input')).each(function () { - syncDetails.push(parseInt(this.value)); - }); - var $controls = jQuery(document.getElementById('frm_field_group_controls')); - if ($controls.length && 'none' !== $controls.get(0).style.display) { - syncLayoutClasses(getFieldsInRow(jQuery(document.querySelector('.frm-field-group-hover-target'))).first(), syncDetails); - } else { - var $ul = mergeSelectedFieldGroups(); - syncLayoutClasses(getFieldsInRow($ul).first(), syncDetails); - unselectFieldGroups(); - } - destroyFieldGroupPopup(); - } - function fieldGroupClick(e) { - maybeShowFieldGroupMessage(); - if ('ul' !== e.originalEvent.target.nodeName.toLowerCase()) { - // only continue if the group itself was clicked / ignore when a field is clicked. - return; - } - var hoverTarget = document.querySelector('.frm-field-group-hover-target'); - if (!hoverTarget) { - return; - } - var ctrlOrCmdKeyIsDown = e.ctrlKey || e.metaKey; - var shiftKeyIsDown = e.shiftKey; - var groupIsActive = hoverTarget.classList.contains('frm-selected-field-group'); - var $selectedFieldGroups = getSelectedFieldGroups(); - var numberOfSelectedGroups = $selectedFieldGroups.length; - if (ctrlOrCmdKeyIsDown || shiftKeyIsDown) { - // multi-selecting - - var selectedField = getSelectedField(); - if (null !== selectedField && !jQuery(selectedField).siblings('li.form-field').length) { - // count a selected field on its own as a selected field group when multiselecting. - selectedField.parentNode.classList.add('frm-selected-field-group'); - ++numberOfSelectedGroups; - } - if (ctrlOrCmdKeyIsDown) { - if (groupIsActive) { - // unselect if holding ctrl or cmd and the group was already active. - --numberOfSelectedGroups; - hoverTarget.classList.remove('frm-selected-field-group'); - syncAfterMultiSelect(numberOfSelectedGroups); - return; // exit early to avoid adding back frm-selected-field-group - } - ++numberOfSelectedGroups; - } else if (shiftKeyIsDown && !groupIsActive) { - ++numberOfSelectedGroups; // include the one we're selecting right now. - var $firstGroup = $selectedFieldGroups.first(); - var $range; - if ($firstGroup.parent().index() < jQuery(hoverTarget.parentNode).index()) { - $range = $firstGroup.parent().nextUntil(hoverTarget.parentNode); - } else { - $range = $firstGroup.parent().prevUntil(hoverTarget.parentNode); - } - $range.each(function () { - var $fieldGroup = jQuery(this).closest('li').find('ul.frm_sorting'); - if (!$fieldGroup.hasClass('frm-selected-field-group')) { - ++numberOfSelectedGroups; - $fieldGroup.addClass('frm-selected-field-group'); - } - }); - } - } else { - // not multi-selecting - unselectFieldGroups(); - numberOfSelectedGroups = 1; - } - hoverTarget.classList.add('frm-selected-field-group'); - syncAfterMultiSelect(numberOfSelectedGroups); - maybeHideFieldGroupMessage(); - jQuery(document).off('click', unselectFieldGroups); - jQuery(document).on('click', unselectFieldGroups); - } - - /** - * Hide the field group message by manipulating classes. - * - * @param {Element} fieldGroupMessage The field group message element. - * @return {void} - */ - function hideFieldGroupMessage(fieldGroupMessage) { - if (!fieldGroupMessage) { - return; - } - fieldGroupMessage.classList.add('frm_hidden'); - fieldGroupMessage.classList.remove('frm-fadein-up-back'); - } - - /** - * Show the field group message by manipulating classes. - * - * @param {Element} fieldGroupMessage The field group message element. - * @return {void} - */ - function showFieldGroupMessage(fieldGroupMessage) { - if (!fieldGroupMessage) { - return; - } - fieldGroupMessage.classList.remove('frm_hidden'); - fieldGroupMessage.classList.add('frm-fadein-up-back'); - } - - /** - * Maybe show a message if there are at least two rows. - * - * @return {void} - */ - function maybeShowFieldGroupMessage() { - var fieldGroupMessage = document.getElementById('frm-field-group-message'); - var rows = document.querySelectorAll('.edit_form_item:not(.edit_field_type_end_divider)'); - if (rows.length < 2) { - hideFieldGroupMessage(fieldGroupMessage); - return; - } - if (fieldGroupMessage) { - showFieldGroupMessage(fieldGroupMessage); - return; - } - fieldGroupMessage = div({ - id: 'frm-field-group-message', - className: 'frm-flex-center frm-fadein-up-back', - children: [span({ - id: 'frm-field-group-message-dismiss', - className: 'frm-flex-center', - child: svg({ - href: '#frm_close_icon' - }) - })] - }); - - // Insert the field group into the DOM - document.getElementById('post-body-content').append(fieldGroupMessage); - - // Get and add the field group message text - var messageText = getFieldGroupMessageText(); - fieldGroupMessage.prepend(messageText); - - // Set up a click event listener - document.getElementById('frm-field-group-message-dismiss').addEventListener('click', function () { - hideFieldGroupMessage(document.getElementById('frm-field-group-message')); - }); - } - - /** - * Get a span element with text about selecting multiple fields. - * - * @return {HTMLElement} A span element with the message and style classes. - */ - function getFieldGroupMessageText() { - var text = document.createElement('span'); - text.classList.add('frm-field-group-message-text', 'frm-flex-center'); - text.innerHTML = sprintf( - // eslint-disable-line @wordpress/valid-sprintf -- Format string is a localized variable - /* translators: %1$s: Start span HTML, %2$s: end span HTML */ - frm_admin_js.holdShiftMsg, '', ''); - return text; - } - - /** - * Maybe hide the field group message based on the number of selected rows. - * - * @return {void} - */ - function maybeHideFieldGroupMessage() { - var selectedRowCount = document.querySelectorAll('.frm-selected-field-group').length; - if (selectedRowCount < 2) { - return; - } - var fieldGroupMessage = document.getElementById('frm-field-group-message'); - hideFieldGroupMessage(fieldGroupMessage); - } - function getSelectedField() { - return document.getElementById('frm-show-fields').querySelector('li.form-field.selected'); - } - function getSelectedFieldGroups() { - var $fieldGroups = jQuery('.frm-selected-field-group'); - if ($fieldGroups.length) { - return $fieldGroups; - } - var selectedField = getSelectedField(); - if (selectedField) { - // If there is only one field in a group and the field is selected, consider the field's group as selected for multi-select. - var selectedFieldGroup = selectedField.closest('ul'); - if (selectedFieldGroup && 1 === getFieldsInRow(jQuery(selectedFieldGroup)).length) { - selectedFieldGroup.classList.add('frm-selected-field-group'); - return jQuery(selectedFieldGroup); - } - } - return jQuery(); - } - function syncAfterMultiSelect(numberOfSelectedGroups) { - clearSettingsBox(true); // unselect any fields if one is selected. - if (numberOfSelectedGroups >= 2 || 1 === numberOfSelectedGroups && selectedGroupHasMultipleFields()) { - addFieldMultiselectPopup(); - } else { - maybeRemoveMultiselectPopup(); - } - maybeRemoveGroupHoverTarget(); - } - function selectedGroupHasMultipleFields() { - return getFieldsInRow(jQuery(document.querySelector('.frm-selected-field-group'))).length > 1; - } - function unselectFieldGroups(event) { - if (event !== undefined) { - if (null !== event.originalEvent.target.closest('#frm-show-fields')) { - return; - } - if (event.originalEvent.target.classList.contains('frm-merge-fields-into-row')) { - return; - } - if (null !== event.originalEvent.target.closest('.frm-merge-fields-into-row')) { - return; - } - if (event.originalEvent.target.classList.contains('frm-custom-field-group-layout')) { - return; - } - if (event.originalEvent.target.classList.contains('frm-cancel-custom-field-group-layout')) { - return; - } - } - jQuery('.frm-selected-field-group').removeClass('frm-selected-field-group'); - jQuery(document).off('click', unselectFieldGroups); - maybeRemoveMultiselectPopup(); - } - function maybeRemoveMultiselectPopup() { - var popup = document.getElementById('frm_field_multiselect_popup'); - if (popup) { - popup.remove(); - } - } - function addFieldMultiselectPopup() { - getFieldMultiselectPopup(); - } - function getFieldMultiselectPopup() { - var popup = document.getElementById('frm_field_multiselect_popup'); - if (popup) { - popup.classList.toggle('frm-unmergable', !selectedFieldsAreMergeable()); - return popup; - } - popup = div(); - popup.id = 'frm_field_multiselect_popup'; - if (!selectedFieldsAreMergeable()) { - popup.classList.add('frm-unmergable'); - } - var mergeOption = div(); - mergeOption.classList.add('frm-merge-fields-into-row'); - mergeOption.textContent = __('Merge into row', 'formidable'); - var caret = document.createElement('a'); - caret.style.marginLeft = '5px'; - caret.classList.add('frm_icon_font', 'frm_arrowdown6_icon'); - caret.setAttribute('href', '#'); - mergeOption.append(caret); - popup.append(mergeOption); - var verticalSeparator = div(); - verticalSeparator.classList.add('frm-multiselect-popup-separator'); - popup.append(verticalSeparator); - var deleteOption = div(); - deleteOption.classList.add('frm-delete-field-groups'); - deleteOption.append(getIconClone('frm_trash_svg')); - popup.append(deleteOption); - document.getElementById('post-body-content').append(popup); - jQuery(popup).hide().fadeIn(); - return popup; - } - function selectedFieldsAreMergeable() { - var selectedFieldGroups = document.querySelectorAll('.frm-selected-field-group'); - var length = selectedFieldGroups.length; - if (1 === length) { - return false; - } - var totalFieldCount = 0; - for (var index = 0; index < length; ++index) { - var fieldGroup = selectedFieldGroups[index]; - if (null !== fieldGroup.querySelector('.edit_field_type_break, .edit_field_type_hidden')) { - return false; - } - totalFieldCount += getFieldsInRow(jQuery(fieldGroup)).length; - if (totalFieldCount > MAX_FIELD_GROUP_SIZE) { - return false; - } - } - return true; - } - function mergeFieldsIntoRowClick(event) { - if (null !== event.originalEvent.target.closest('#frm_field_group_popup')) { - // prevent clicks within the popup from triggering the button again. - return; - } - if (event.originalEvent.target.classList.contains('frm-custom-field-group-layout')) { - // avoid switching back to the first page when clicking the custom option nested inside of the merge option. - return; - } - var size = getSelectedFieldCount(); - var popup = getFieldGroupPopup(size, document.querySelector('.frm-selected-field-group').firstChild); - this.append(popup); - } - function getSelectedFieldCount() { - var count = 0; - jQuery(document.querySelectorAll('.frm-selected-field-group')).each(function () { - count += getFieldsInRow(jQuery(this)).length; - }); - return count; - } - function deleteFieldGroupsClick() { - var fieldIdsToDelete = getSelectedFieldIds(); - var deleteOnConfirm = getDeleteSelectedFieldGroupsOnConfirmFunction(fieldIdsToDelete); - var multiselectPopup = document.getElementById('frm_field_multiselect_popup'); - if (multiselectPopup) { - multiselectPopup.remove(); - } - this.setAttribute('data-frmverify', confirmFieldsDeleteMessage(fieldIdsToDelete.length)); - confirmLinkClick(this); - var confirmedClick = document.getElementById('frm-confirmed-click'); - - // Remove any previous delete field data so delete confirmation does not attempt - // to delete a field that was already deleted or previously attempted and cancelled. - confirmedClick === null || confirmedClick === void 0 || confirmedClick.removeAttribute('data-deletefield'); - jQuery(confirmedClick).on('click', deleteOnConfirm); - jQuery('#frm_confirm_modal').one('dialogclose', function () { - jQuery(confirmedClick).off('click', deleteOnConfirm); - }); - } - function getSelectedFieldIds() { - var deleteFieldIds = []; - jQuery('.frm-selected-field-group > li.form-field').each(function () { - deleteFieldIds.push(this.dataset.fid); - }); - return deleteFieldIds; - } - function getDeleteSelectedFieldGroupsOnConfirmFunction(deleteFieldIds) { - return function (event) { - event.preventDefault(); - deleteAllSelectedFieldGroups(deleteFieldIds); - }; - } - function deleteAllSelectedFieldGroups(deleteFieldIds) { - deleteFieldIds.forEach(function (fieldId) { - deleteFields(fieldId); - }); - } - function deleteFieldConfirmed() { - /*jshint validthis:true */ - deleteFields(this.getAttribute('data-deletefield')); - } - function deleteFields(fieldId) { - var field = jQuery("#frm_field_id_".concat(fieldId)); - deleteField(fieldId); - if (field.hasClass('edit_field_type_divider')) { - field.find('li.frm_field_box[data-fid]').each(function () { - deleteField(this.getAttribute('data-fid')); - }); - } - toggleSectionHolder(); - } - - /** - * Checks if there is only submit field in the form builder. - * - * @return {boolean} True if only the submit field exists. - */ - function hasOnlySubmitField() { - // If there are at least 2 rows, return false. - if ($newFields.get(0).childElementCount > 1) { - return false; - } - var childUl = $newFields.get(0).firstElementChild.firstElementChild; - - // Use query instead of children because there might be a div inside this ul. - var childLi = childUl.querySelectorAll('li.frm_field_box'); - - // If there are at least 2 items in the row, return false. - if (childLi.length > 1) { - return false; - } - return childLi[0].classList.contains('edit_field_type_submit'); - } - - /** - * Moves open modals out of the field options form. - * - * When a modal is open, it is moved in the DOM and appended to the parent element of the modal trigger input. That - * creates a problem since deleting the field also deletes the modal and this function fixes that problem. - * - * @since 6.22 - * - * @param {Object} settings - * @return {void} - */ - function moveOpenModalsOutOfFieldOptions(settings) { - var openModals = settings[0].querySelectorAll('.frm-inline-modal[data-fills]'); - if (!openModals.length) { - return; - } - openModals.forEach(function (modal) { - modal.classList.add('frm_hidden'); - modal.removeAttribute('data-fills'); - modal.closest('form').append(modal); - }); - } - function deleteField(fieldId) { - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_delete_field', - field_id: fieldId, - nonce: frmGlobal.nonce - }, - success: function success() { - var $thisField = jQuery(document.getElementById("frm_field_id_".concat(fieldId))); - var settings = jQuery("#frm-single-settings-".concat(fieldId)); - - // Remove settings from sidebar. - if (settings.is(':visible')) { - var _document$querySelect2; - (_document$querySelect2 = document.querySelector('.frm-settings-panel .frm-tabs-navs ul > li:first-child')) === null || _document$querySelect2 === void 0 || _document$querySelect2.click(); - document.querySelector('#frm-options-panel .frm-single-settings').classList.remove('frm_hidden'); - } - moveOpenModalsOutOfFieldOptions(settings); - settings.remove(); - $thisField.fadeOut('slow', function () { - var $section = $thisField.closest('.start_divider'); - var type = $thisField.data('type'); - var $adjacentFields = $thisField.siblings('li.form-field'); - var $liWrapper; - if (!$adjacentFields.length) { - if ($thisField.is('.edit_field_type_end_divider')) { - $adjacentFields.length = $thisField.closest('li.form-field').siblings(); - } else { - $liWrapper = $thisField.closest('ul.frm_sorting').parent(); - } - } - $thisField.remove(); - if (type === 'break') { - renumberPageBreaks(); - } else if (type === 'product') { - maybeHideQuantityProductFieldOption(); - // a product field attached to a quantity field earlier might be the one deleted, so re-populate - popAllProductFields(); - } - if ($adjacentFields.length) { - syncLayoutClasses($adjacentFields.first()); - } else { - $liWrapper.remove(); - } - if (jQuery('#frm-show-fields li').length === 0 || hasOnlySubmitField()) { - var formEditorContainer = document.getElementById('frm_form_editor_container'); - formEditorContainer.classList.remove('frm-has-fields'); - formEditorContainer.classList.add('frm-empty-fields'); - } else if ($section.length) { - toggleOneSectionHolder($section); - } - - // prevent "More Options" tooltips from staying around after their target field is deleted. - deleteTooltips(); - }); - if ($thisField.length) { - maybeEnableFieldButtonAtLimit($thisField.data('type')); - wp.hooks.doAction('frm_after_delete_field', $thisField[0]); - } - } - }); - } - - /** - * @since 6.27 - * - * @param {string} type - * @return {void} - */ - function maybeEnableFieldButtonAtLimit(type) { - var button = document.getElementById(type); - if (!button || !button.dataset.limit) { - return; - } - - // Subtract one because the field has not really been removed from the page yet. - var fieldTypeCount = countFieldTypeInForm(type) - 1; - if (fieldTypeCount < button.dataset.limit) { - button.classList.remove('frm_at_limit'); - } - } - function countFieldTypeInForm(type) { - return document.getElementById('frm-show-fields').querySelectorAll("li.form-field[data-ftype=\"".concat(type, "\"]")).length; - } - function addFieldLogicRow() { - /*jshint validthis:true */ - var id = jQuery(this).closest('.frm-single-settings').data('fid'); - var formId = thisFormId; - var logicRows = document.getElementById("frm_logic_row_".concat(id)).querySelectorAll('.frm_logic_row'); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_add_logic_row', - form_id: formId, - field_id: id, - nonce: frmGlobal.nonce, - meta_name: getNewRowId(logicRows, "frm_logic_".concat(id, "_")), - fields: getFieldList() - }, - success: function success(html) { - jQuery(document.getElementById("logic_".concat(id))).fadeOut('fast', function () { - var logicRow = document.getElementById("frm_logic_row_".concat(id)); - logicRow.insertAdjacentHTML('beforeend', html); - var logicRowText = logicRow.querySelector('.frm_logic_row:last-child .frm-logic-rule-text'); - if (logicRowText) { - logicRowText.textContent = logicRow.dataset.ruleText; - } - var logicRows = logicRow.closest('.frm_logic_rows'); - logicRows.style.height = 'auto'; - jQuery(logicRows).fadeIn('fast'); - }); - } - }); - return false; - } - function getNewRowId(rows, replace, defaultValue) { - if (!rows.length) { - return defaultValue !== undefined ? defaultValue : 0; - } - return parseInt(rows[rows.length - 1].id.replace(replace, ''), 10) + 1; - } - function addWatchLookupRow() { - /*jshint validthis:true */ - var id = jQuery(this).closest('.frm-single-settings').data('fid'); - var formId = thisFormId; - var lookupBlockRows = document.getElementById("frm_watch_lookup_block_".concat(id)).children; - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_add_watch_lookup_row', - form_id: formId, - field_id: id, - row_key: getNewRowId(lookupBlockRows, "frm_watch_lookup_".concat(id, "_")), - nonce: frmGlobal.nonce - }, - success: function success(newRow) { - var _document$getElementB2; - var watchRowBlock = jQuery(document.getElementById("frm_watch_lookup_block_".concat(id))); - watchRowBlock.append(newRow); - watchRowBlock.fadeIn('slow'); - - // Show the "Watch Lookup Fields" label if it was hidden - (_document$getElementB2 = document.getElementById("frm_watch_lookup_label_".concat(id))) === null || _document$getElementB2 === void 0 || _document$getElementB2.classList.remove('frm-force-hidden'); - } - }); - return false; - } - function resetOptionTextDetails() { - jQuery('.frm-single-settings ul input[type="text"][name^="field_options[options_"]').filter('[data-value-on-load]').removeAttr('data-value-on-load'); - jQuery('input[type="hidden"][name^=optionmap]').remove(); - } - function optionTextAlreadyExists(input) { - var fieldId = jQuery(input).closest('.frm-single-settings').attr('data-fid'); - var optionInputs = jQuery(input).closest('ul').get(0).querySelectorAll(".field_".concat(fieldId, "_option")); - var index; - var optionInput; - for (index in optionInputs) { - if (Object.hasOwn(optionInputs, index)) { - optionInput = optionInputs[index]; - if (optionInput.id !== input.id && optionInput.value === input.value && optionInput.getAttribute('data-duplicate') !== 'true') { - return true; - } - } - } - return false; - } - function onOptionTextFocus() { - var input; - var fieldId; - if (this.getAttribute('data-value-on-load') === null) { - this.setAttribute('data-value-on-load', this.value); - fieldId = jQuery(this).closest('.frm-single-settings').attr('data-fid'); - input = document.createElement('input'); - input.value = this.value; - input.setAttribute('type', 'hidden'); - input.setAttribute('name', "optionmap[".concat(fieldId, "][").concat(this.value, "]")); - this.parentNode.append(input); - if (optionMap[fieldId] === undefined) { - optionMap[fieldId] = {}; - } - optionMap[fieldId][this.value] = input; - } - if (this.getAttribute('data-duplicate') === 'true') { - this.removeAttribute('data-duplicate'); - - // we want to use original value if actually still a duplicate - if (optionTextAlreadyExists(this)) { - this.setAttribute('data-value-on-focus', this.getAttribute('data-value-on-load')); - return; - } - } - if ('' !== this.value || frmAdminJs.new_option !== this.getAttribute('data-value-on-focus')) { - this.setAttribute('data-value-on-focus', this.value); - } - } - - /** - * Returns an object that has the old and new values and labels, when a field choice is changed. - * - * @param {HTMLElement} input The changed input element. - * @return {Object} Object with oldValue, oldLabel, newValue, newLabel properties. - */ - function getChoiceOldAndNewValues(input) { - var _getChoiceOldValueAnd = getChoiceOldValueAndLabel(input), - oldValue = _getChoiceOldValueAnd.oldValue, - oldLabel = _getChoiceOldValueAnd.oldLabel; - var _getChoiceNewValueAnd = getChoiceNewValueAndLabel(input), - newValue = _getChoiceNewValueAnd.newValue, - newLabel = _getChoiceNewValueAnd.newLabel; - return { - oldValue: oldValue, - oldLabel: oldLabel, - newValue: newValue, - newLabel: newLabel - }; - } - - /** - * Returns an object that has the new value and label, when a field choice is changed. - * - * @param {HTMLElement} choiceElement The changed choice element. - * @return {Object} Object with newValue and newLabel properties. - */ - function getChoiceNewValueAndLabel(choiceElement) { - var singleOptionContainer = choiceElement.closest('.frm_single_option'); - var newValue; - var newLabel; - if (choiceElement.parentElement.classList.contains('frm_single_option')) { - // label changed - newValue = singleOptionContainer.querySelector('.frm_option_key input[type="text"]').value; - newLabel = choiceElement.value; - return { - newValue: newValue, - newLabel: newLabel - }; - } - - // saved value changed - newLabel = singleOptionContainer.querySelector('input[type="text"]').value; - newValue = choiceElement.value; - return { - newValue: newValue, - newLabel: newLabel - }; - } - - /** - * Returns an object that has the old value and label, when a field choice is changed. - * - * @param {HTMLElement} choiceElement The changed choice element. - * @return {Object} Object with oldValue and oldLabel properties. - */ - function getChoiceOldValueAndLabel(choiceElement) { - var _choiceElement$closes, _choiceElement$closes2; - var usingSeparateValues = (_choiceElement$closes = (_choiceElement$closes2 = choiceElement.closest('.frm-single-settings').querySelector('.frm_toggle_sep_values')) === null || _choiceElement$closes2 === void 0 ? void 0 : _choiceElement$closes2.checked) !== null && _choiceElement$closes !== void 0 ? _choiceElement$closes : false; - var singleOptionContainer = choiceElement.closest('.frm_single_option'); - var oldValue; - var oldLabel; - if (usingSeparateValues) { - if (choiceElement.parentElement.classList.contains('frm_single_option')) { - // label changed - oldValue = singleOptionContainer.querySelector('.frm_option_key input[type="text"]').getAttribute('data-value-on-focus'); - oldLabel = choiceElement.getAttribute('data-value-on-focus'); - return { - oldValue: oldValue, - oldLabel: oldLabel - }; - } - } - oldValue = choiceElement.getAttribute('data-value-on-focus'); - oldLabel = singleOptionContainer.querySelector('input[type="text"]').getAttribute('data-value-on-focus'); - return { - oldValue: oldValue, - oldLabel: oldLabel - }; - } - function onOptionTextBlur() { - var fieldIndex; - var settingId; - var setting; - var _getChoiceOldAndNewVa = getChoiceOldAndNewValues(this), - oldValue = _getChoiceOldAndNewVa.oldValue, - oldLabel = _getChoiceOldAndNewVa.oldLabel, - newValue = _getChoiceOldAndNewVa.newValue, - newLabel = _getChoiceOldAndNewVa.newLabel; - if (oldValue === newValue && oldLabel === newLabel) { - return; - } - var singleSettingsContainer = this.closest('.frm-single-settings'); - var fieldId = singleSettingsContainer.getAttribute('data-fid'); - var originalValue = this.getAttribute('data-value-on-load'); - - // check if the newValue is already mapped to another option - // if it is, mark as duplicate and return - if (optionTextAlreadyExists(this)) { - this.setAttribute('data-duplicate', 'true'); - if (optionMap[fieldId] !== undefined && optionMap[fieldId][originalValue] !== undefined) { - // unmap any other change that may have happened before instead of changing it to something unused - optionMap[fieldId][originalValue].value = originalValue; - } - return; - } - if (optionMap[fieldId] !== undefined && optionMap[fieldId][originalValue] !== undefined) { - optionMap[fieldId][originalValue].value = newValue; - } - var fieldIds = []; - var rows = builderPage.querySelectorAll('.frm_logic_row'); - var rowLength = rows.length; - for (var rowIndex = 0; rowIndex < rowLength; rowIndex++) { - var row = rows[rowIndex]; - var opts = row.querySelector('.frm_logic_field_opts'); - if (opts.value !== fieldId) { - continue; - } - var logicId = row.id.split('_')[2]; - var valueSelect = row.querySelector("select[name=\"field_options[hide_opt_".concat(logicId, "][]\"]")); - var optionMatches = void 0; - if ('' === oldValue) { - optionMatches = []; - } else { - optionMatches = valueSelect.querySelectorAll("option[value=\"".concat(oldValue, "\"]")); - } - var option = void 0; - if (!optionMatches.length) { - optionMatches = valueSelect.querySelectorAll("option[value=\"".concat(newValue, "\"]")); - if (!optionMatches.length) { - var _singleSettingsContai; - if (!((_singleSettingsContai = singleSettingsContainer.querySelector('.frm_toggle_sep_values')) !== null && _singleSettingsContai !== void 0 && _singleSettingsContai.checked)) { - option = searchSelectByText(valueSelect, oldValue); // Find conditional logic option with oldValue - } - if (!option) { - option = document.createElement('option'); - valueSelect.append(option); - } - } - } - if (optionMatches.length) { - option = optionMatches[optionMatches.length - 1]; - } - option.setAttribute('value', newValue); - option.textContent = newLabel; - if (!fieldIds.includes(logicId)) { - fieldIds.push(logicId); - } - } - for (fieldIndex in fieldIds) { - if (Object.hasOwn(fieldIds, fieldIndex)) { - settingId = fieldIds[fieldIndex]; - setting = document.getElementById("frm-single-settings-".concat(settingId)); - moveFieldSettings(setting); - } - } - } - - /** - * Returns an option element that matches a string with its text content. - * - * @param {HTMLElement} selectElement The select element to search. - * @param {string} searchText The text to search for. - * @return {HTMLElement|null} Matching option element or null. - */ - function searchSelectByText(selectElement, searchText) { - var options = selectElement.options; - for (var i = 0; i < options.length; i++) { - var option = options[i]; - if (searchText === option.textContent) { - return option; - } - } - return null; - } - function updateGetValueFieldSelection() { - /*jshint validthis:true */ - var fieldID = this.id.replace('get_values_form_', ''); - var fieldSelect = document.getElementById("get_values_field_".concat(fieldID)); - var fieldType = this.getAttribute('data-fieldtype'); - if (this.value === '') { - fieldSelect.options.length = 1; - } else { - var formID = this.value; - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_get_options_for_get_values_field', - form_id: formID, - field_type: fieldType, - nonce: frmGlobal.nonce - }, - success: function success(fields) { - fieldSelect.innerHTML = fields; - } - }); - } - } - - // Clear the Watch Fields option when Lookup field switches to "Text" option - function maybeClearWatchFields() { - /*jshint validthis:true */ - var link; - var lookupBlock; - var fieldID = this.name.replace('field_options[data_type_', '').replace(']', ''); - link = document.getElementById("frm_add_watch_lookup_link_".concat(fieldID)); - if (!link) { - return; - } - link = link.parentNode; - if (this.value === 'text') { - lookupBlock = document.getElementById("frm_watch_lookup_block_".concat(fieldID)); - if (lookupBlock) { - // Clear and hide the Watch Fields option - lookupBlock.innerHTML = ''; - link.classList.add('frm_hidden'); - - // Hide the Watch Fields row - link.previousElementSibling.style.display = 'none'; - link.previousElementSibling.previousElementSibling.style.display = 'none'; - link.previousElementSibling.previousElementSibling.previousElementSibling.style.display = 'none'; - } - } else { - // Show the Watch Fields option - link.classList.remove('frm_hidden'); - } - toggleMultiSelect(fieldID, this.value); - } - - // Number the pages and hide/show the first page as needed. - function renumberPageBreaks() { - var i; - var containerClass; - var pages = document.getElementsByClassName('frm-page-num'); - if (pages.length > 1) { - document.getElementById('frm-fake-page').style.display = 'block'; - for (i = 0; i < pages.length; i++) { - containerClass = pages[i].parentNode.parentNode.parentNode.classList; - if (i === 1) { - // Hide previous button on page 1 - containerClass.add('frm-first-page'); - } else { - containerClass.remove('frm-first-page'); - } - pages[i].textContent = i + 1; - } - } else { - document.getElementById('frm-fake-page').style.display = 'none'; - } - wp.hooks.doAction('frm_renumber_page_breaks', pages); - } - - // The fake field works differently than real fields. - function maybeCollapsePage() { - /*jshint validthis:true */ - var field = jQuery(this).closest('.frm_field_box[data-ftype=break]'); - if (field.length) { - toggleCollapsePage(field); - } else { - toggleCollapseFakePage(); - } - } - - // Find all fields in a page and hide/show them - function toggleCollapsePage(field) { - var toCollapse = getAllFieldsForPage(field.get(0).parentNode.closest('li.frm_field_box').nextElementSibling); - togglePage(field, toCollapse); - } - function toggleCollapseFakePage() { - var topLevel = document.getElementById('frm-fake-page'); - var firstField = document.getElementById('frm-show-fields').firstElementChild; - var toCollapse = getAllFieldsForPage(firstField); - if (firstField.getAttribute('data-ftype') === 'break') { - // Don't collapse if the first field is a page break. - return; - } - togglePage(jQuery(topLevel), toCollapse); - } - function getAllFieldsForPage(firstWrapper) { - var $fieldsForPage; - var currentWrapper; - $fieldsForPage = jQuery(); - if (null === firstWrapper) { - return $fieldsForPage; - } - currentWrapper = firstWrapper; - do { - if (null !== currentWrapper.querySelector('.edit_field_type_break')) { - break; - } - $fieldsForPage = $fieldsForPage.add(jQuery(currentWrapper)); - currentWrapper = currentWrapper.nextElementSibling; - } while (null !== currentWrapper); - return $fieldsForPage; - } - function togglePage(field, toCollapse) { - var i; - var fieldCount = toCollapse.length; - var slide = Math.min(fieldCount, 3); - if (field.hasClass('frm-page-collapsed')) { - field.removeClass('frm-page-collapsed'); - toCollapse.removeClass('frm-is-collapsed'); - for (i = 0; i < slide; i++) { - if (i === slide - 1) { - jQuery(toCollapse[i]).slideDown(150, function () { - toCollapse.show(); - }); - } else { - jQuery(toCollapse[i]).slideDown(150); - } - } - } else { - field.addClass('frm-page-collapsed'); - toCollapse.addClass('frm-is-collapsed'); - for (i = 0; i < slide; i++) { - if (i === slide - 1) { - jQuery(toCollapse[i]).slideUp(150, function () { - toCollapse.css('cssText', 'display:none !important;'); - }); - } else { - jQuery(toCollapse[i]).slideUp(150); - } - } - } - } - function maybeCollapseSection() { - /*jshint validthis:true */ - var parentCont = this.parentNode.parentNode.parentNode.parentNode; - parentCont.classList.toggle('frm-section-collapsed'); - } - function maybeCollapseSettings() { - /*jshint validthis:true */ - - // Restore animation that may have been disabled by showFieldOptions. - if (this.nextElementSibling) { - this.nextElementSibling.style.animation = ''; - } - this.classList.toggle('frm-collapsed'); - - // Toggles the "aria-expanded" attribute - var expanded = this.getAttribute('aria-expanded') === 'true' || false; - this.setAttribute('aria-expanded', !expanded); - addSlideAnimationCssVars(this.nextElementSibling); - } - - /** - * Add slide animation CSS variables to the element - * - * @param {HTMLElement} element The element to add CSS variables to - * @return {void} - */ - function addSlideAnimationCssVars(element) { - if (!element) { - return; - } - var height = element.scrollHeight; - if (height <= 0) { - return; - } - height += 250; - element.style.setProperty('--slide-height', "".concat(height, "px")); - element.style.setProperty('--slide-time', "".concat(Math.ceil(height * 0.8), "ms")); - } - function clickLabel() { - if (!this.id) { - return; - } - - /*jshint validthis:true */ - var setting = document.querySelectorAll("[data-changeme=\"".concat(this.id, "\"]"))[0]; - var fieldId = this.id.replace('field_label_', ''); - var fieldType = document.getElementById("field_options_type_".concat(fieldId)); - var fieldTypeName = fieldType.value; - if (setting !== undefined) { - if (fieldType.tagName === 'SELECT') { - fieldTypeName = fieldType.options[fieldType.selectedIndex].text.toLowerCase(); - } else { - fieldTypeName = fieldTypeName.replace('_', ' '); - } - fieldTypeName = normalizeFieldName(fieldTypeName); - setTimeout(function () { - if (setting.value.toLowerCase() === fieldTypeName) { - setting.select(); - } else { - setting.focus(); - } - }, 50); - } - } - function clickDescription() { - /*jshint validthis:true */ - var setting = document.querySelectorAll("[data-changeme=\"".concat(this.id, "\"]"))[0]; - if (setting !== undefined) { - setTimeout(function () { - setting.focus(); - autoExpandSettings(setting); - }, 50); - } - } - function autoExpandSettings(setting) { - var inSection = setting.closest('.frm-collapse-me'); - if (inSection !== null) { - inSection.previousElementSibling.classList.remove('frm-collapsed'); - } - } - function normalizeFieldName(fieldTypeName) { - if (fieldTypeName === 'divider') { - fieldTypeName = 'section'; - } else if (fieldTypeName === 'range') { - fieldTypeName = 'slider'; - } else if (fieldTypeName === 'data') { - fieldTypeName = 'dynamic'; - } else if (fieldTypeName === 'form') { - fieldTypeName = 'embed form'; - } - return fieldTypeName; - } - function clickVis(e) { - /*jshint validthis:true */ - var currentClass = e.target.classList; - if (currentClass.contains('frm-collapse-page') || currentClass.contains('frm-sub-label') || e.target.closest('.dropdown') !== null) { - return; - } - if (this.closest('.start_divider') !== null) { - e.stopPropagation(); - } - if (this.classList.contains('edit_field_type_divider')) { - var originalList = e.originalEvent.target.closest('ul.frm_sorting'); - if (null !== originalList) { - // prevent section click if clicking a field group within a section. - if (originalList.classList.contains('edit_field_type_divider') || originalList.parentNode.parentNode.classList.contains('start_divider')) { - return; - } - } - } - clickAction(this); - } - - /** - * Update the format input based on the selected format type. - * - * @since 6.9 - * - * @param {Event} event The event object from the format type selection. - * @return {void} - */ - function maybeUpdateFormatInput(event) { - var formatElement = event.target; - var type = formatElement.value; - if ('custom' === type) { - var fieldId = formatElement.dataset.fieldId; - var formatInput = document.getElementById("frm-field-format-custom-".concat(fieldId)).querySelector('.frm_format_opt'); - if ('international' === formatInput.value || 'currency' === formatInput.value || 'number' === formatInput.value) { - formatInput.setAttribute('value', ''); - } - } - setTimeout(function () { - formatElement.querySelectorAll('option').forEach(function (option) { - if (option.selected && option.classList.contains('frm_show_upgrade')) { - formatElement.value = 'none'; - } - }); - }, 0); - } - - /** - * Open Advanced settings on double click. - */ - function openAdvanced() { - var fieldId = this.getAttribute('data-fid'); - autoExpandSettings(document.getElementById("field_options_field_key_".concat(fieldId))); - } - function toggleRepeatButtons() { - /*jshint validthis:true */ - var $thisField = jQuery(this).closest('.frm_field_box'); - $thisField.find('.repeat_icon_links').removeClass('repeat_format repeat_formatboth repeat_formattext').addClass("repeat_format".concat(this.value)); - if (this.value === 'text' || this.value === 'both') { - $thisField.find('.frm_repeat_text').show(); - $thisField.find('.repeat_icon_links a').addClass('frm_button'); - } else { - $thisField.find('.frm_repeat_text').hide(); - $thisField.find('.repeat_icon_links a').removeClass('frm_button'); - } - } - function checkRepeatLimit() { - /*jshint validthis:true */ - var val = this.value; - if (val !== '' && (val < 2 || val > 200)) { - infoModal(frmAdminJs.repeat_limit_min); - this.value = ''; - } - } - function checkCheckboxSelectionsLimit() { - /*jshint validthis:true */ - var val = this.value; - if (val !== '' && (val < 1 || val > 200)) { - infoModal(frmAdminJs.checkbox_limit); - this.value = ''; - } - } - function updateRepeatText(obj, addRemove) { - var $thisField = jQuery(obj).closest('.frm_field_box'); - $thisField.find(".frm_".concat(addRemove, "_form_row .frm_repeat_label")).text(obj.value); - } - function fieldsInSection(id) { - var children = []; - jQuery(document.getElementById("frm_field_id_".concat(id))).find('li.frm_field_box:not(.no_repeat_section .edit_field_type_end_divider)').each(function () { - children.push(jQuery(this).data('fid')); - }); - return children; - } - function toggleFormTax() { - /*jshint validthis:true */ - var id = jQuery(this).closest('.frm-single-settings').data('fid'); - var val = this.value; - var $showFields = document.getElementById("frm_show_selected_fields_".concat(id)); - var $showForms = document.getElementById("frm_show_selected_forms_".concat(id)); - jQuery($showForms).find('select').val(''); - if (val === 'form') { - $showForms.style.display = 'inline'; - empty($showFields); - } else { - $showFields.style.display = 'none'; - $showForms.style.display = 'none'; - getTaxOrFieldSelection(val, id); - } - } - function resetOptOnChange() { - /*jshint validthis:true */ - var field = getFieldKeyFromOpt(this); - if (!field) { - return; - } - var thisOpt = jQuery(this).closest('.frm_single_option'); - resetSingleOpt(field.fieldId, field.fieldKey, thisOpt); - } - function getFieldKeyFromOpt(object) { - var allOpts = jQuery(object).closest('.frm_sortable_field_opts'); - if (!allOpts.length) { - return false; - } - var fieldId = allOpts.attr('id').replace('frm_field_', '').replace('_opts', ''); - var fieldKey = allOpts.data('key'); - return { - fieldId: fieldId, - fieldKey: fieldKey - }; - } - function resetSingleOpt(fieldId, fieldKey, thisOpt) { - var optKey = thisOpt.data('optkey'); - var separateValues = usingSeparateValues(fieldId); - var single = jQuery("label[for=\"field_".concat(fieldKey, "-").concat(optKey, "\"]")); - var baseName = "field_options[options_".concat(fieldId, "][").concat(optKey, "]"); - var label = jQuery("input[name=\"".concat(baseName, "[label]\"]")); - if (single.length < 1) { - resetDisplayedOpts(fieldId); - - // Set the default value. - var _defaultVal = thisOpt.find('input[name^="default_value_"]'); - if (_defaultVal.is(':checked') && label.length > 0) { - jQuery("select[name^=\"item_meta[".concat(fieldId, "]\"]")).val(label.val()); - } - return; - } - var previewInput = single.children('input'); - var saved; - if (label.length < 1) { - // Check for other label. - label = jQuery("input[name=\"".concat(baseName, "\"]")); - saved = label.val(); - } else if (separateValues) { - saved = jQuery("input[name=\"".concat(baseName, "[value]\"]")).val(); - } else { - saved = label.val(); - } - if (label.length < 1) { - return; - } - - // Set the displayed value. - var text = single[0].childNodes; - if (imagesAsOptions(fieldId)) { - var labelForDisplay = getImageDisplayValue(thisOpt, fieldId, label); - var optContainer = single.find('.frm_image_option_container'); - if (optContainer.length > 0) { - optContainer.replaceWith(labelForDisplay); - } else { - text[text.length - 1].nodeValue = ''; - single.append(labelForDisplay); - } - } else { - var firstInputIndex = false; - text.forEach(function (node, index) { - if (firstInputIndex === false) { - if (node.tagName === 'INPUT') { - firstInputIndex = index; - } - } else if (index === firstInputIndex + 1) { - var nodeValue = ''; - if (buttonsAsOptions(fieldId)) { - nodeValue = div({ - className: 'frm_label_button_container', - text: " ".concat(label.val()) - }); - single[0].replaceChild(nodeValue, node); - } else { - node.nodeValue = " ".concat(label.val()); - } - } else { - node.remove(); - } - }); - } - - // Set saved value. - previewInput.val(saved); - - // Set the default value. - defaultVal = thisOpt.find('input[name^="default_value_"]'); - previewInput.prop('checked', defaultVal.is(':checked') ? true : false); - } - function buttonsAsOptions(fieldId) { - var fields = document.getElementsByName("field_options[image_options_".concat(fieldId, "]")); - var result = Array.from(fields).find(function (field) { - return field.checked && 'buttons' === field.value; - }); - return result !== undefined; - } - - /** - * Set the displayed value for an image option. - * @param {HTMLElement} thisOpt The option element. - * @param {number} fieldId The field ID. - * @param {string} label The option label. - */ - function getImageDisplayValue(thisOpt, fieldId, label) { - var image = thisOpt.find('img'); - var imageUrl; - if (image) { - imageUrl = image.attr('src'); - } - var showLabelWithImage = showingLabelWithImage(fieldId); - return getImageLabel(label.val(), showLabelWithImage, imageUrl); - } - function getImageOptionSize(fieldId) { - var val; - var field = document.getElementById("field_options_image_size_".concat(fieldId)); - var size = ''; - if (field) { - val = field.value; - if (val !== '') { - size = val; - } - } - return size; - } - function resetDisplayedOpts(fieldId) { - var input = jQuery("[name^=\"item_meta[".concat(fieldId, "]\"]")); - if (input.length < 1) { - return; - } - if (input.is('select')) { - var placeholder = document.getElementById("frm_placeholder_".concat(fieldId)); - if (!placeholder || placeholder.value === '') { - fillDropdownOpts(input[0], { - sourceID: fieldId - }); - } else { - fillDropdownOpts(input[0], { - sourceID: fieldId, - placeholder: placeholder.value - }); - } - } else { - var opts = getMultipleOpts(fieldId); - jQuery("#field_".concat(fieldId, "_inner_container > .frm_form_fields")).html(''); - var fieldInfo = getFieldKeyFromOpt(jQuery("#frm_delete_field_".concat(fieldId, "-000_container"))); - var container = jQuery("#field_".concat(fieldId, "_inner_container > .frm_form_fields")); - var hasImageOptions = imagesAsOptions(fieldId); - var imageSize = hasImageOptions ? getImageOptionSize(fieldId) : ''; - var imageOptionClass = hasImageOptions ? "frm_image_option frm_image_".concat(imageSize, " ") : ''; - var isProduct = isProductField(fieldId); - var type = 'hidden' === input.attr('type') ? input.data('field-type') : input.attr('type'); - for (var i = 0; i < opts.length; i++) { - container.append(addRadioCheckboxOpt(type, opts[i], fieldId, fieldInfo.fieldKey, isProduct, imageOptionClass)); - } - } - adjustConditionalLogicOptionOrders(fieldId); - } - - /** - * Returns an object that has a value and label for new conditional logic option, for a given option value. - * - * @param {number} fieldId - * @param {string} expectedOption The expected option value. - * @return {Object} Object with value and label for the new option. - */ - function getNewConditionalLogicOption(fieldId, expectedOption) { - var optionsContainer = document.getElementById("frm_field_".concat(fieldId, "_opts")); - var expectedOptionInput = optionsContainer.querySelector("input[value=\"".concat(expectedOption, "\"]")); - if (expectedOptionInput) { - return getChoiceNewValueAndLabel(expectedOptionInput); - } - return { - newValue: expectedOption, - newLabel: expectedOption - }; - } - function adjustConditionalLogicOptionOrders(fieldId, type) { - var rows = builderPage.querySelectorAll('.frm_logic_row'); - var rowLength = rows.length; - var fieldOptions = wp.hooks.applyFilters('frm_conditional_logic_field_options', getFieldOptions(fieldId), { - type: type, - fieldId: fieldId - }); - var optionLength = fieldOptions.length; - for (var rowIndex = 0; rowIndex < rowLength; rowIndex++) { - var row = rows[rowIndex]; - var opts = row.querySelector('.frm_logic_field_opts'); - if (opts.value != fieldId) { - continue; - } - var logicId = row.id.split('_')[2]; - var valueSelect = row.querySelector("select[name=\"field_options[hide_opt_".concat(logicId, "][]\"]")); - var _loop = function _loop() { - var _document$getElementB3; - var expectedOption = fieldOptions[optionIndex]; - var expectedOptionValue = (_document$getElementB3 = document.getElementById("frm_field_".concat(fieldId, "_opts")).querySelector('.frm_option_key input[type="text"]')) === null || _document$getElementB3 === void 0 ? void 0 : _document$getElementB3.value; - if (!expectedOptionValue) { - expectedOptionValue = expectedOption; - } - var optionMatch = valueSelect.querySelector("option[value=\"".concat(expectedOptionValue, "\"]")); - var _getNewConditionalLog = getNewConditionalLogicOption(fieldId, expectedOption), - newValue = _getNewConditionalLog.newValue, - newLabel = _getNewConditionalLog.newLabel; - var fieldChoices = document.querySelectorAll("#frm_field_".concat(fieldId, "_opts input[data-value-on-focus]")); - var expectedChoiceEl = Array.from(fieldChoices).find(function (element) { - return element.value === expectedOption; - }); - if (expectedChoiceEl) { - var oldValue = expectedChoiceEl.dataset.valueOnFocus; - var hasMatch = oldValue && valueSelect.querySelector("option[value=\"".concat(oldValue, "\"]")); - if (hasMatch) { - return 1; // continue - } - } - prependValueSelectWithOptionMatch(valueSelect, optionMatch, newValue, newLabel); - }; - for (var optionIndex = optionLength - 1; optionIndex >= 0; optionIndex--) { - if (_loop()) continue; - } - var optionMatch = valueSelect.querySelector('option[value=""]'); - if (optionMatch !== null) { - valueSelect.prepend(optionMatch); - } - } - } - function prependValueSelectWithOptionMatch(valueSelect, optionMatch, newValue, newLabel) { - if (optionMatch === null && !valueSelect.querySelector("option[value=\"".concat(newValue, "\"]"))) { - optionMatch = frmDom.tag('option', { - text: newLabel - }); - optionMatch.value = newValue; - } - valueSelect.prepend(optionMatch); - } - function getFieldOptions(fieldId) { - var options = []; - var optsContainer = document.getElementById("frm_field_".concat(fieldId, "_opts")); - if (!optsContainer) { - return options; - } - var listItems = optsContainer.querySelectorAll('.frm_single_option'); - var length = listItems.length; - for (var index = 0; index < length; index++) { - var li = listItems[index]; - if (li.classList.contains('frm_hidden')) { - continue; - } - var input = li.querySelector(".field_".concat(fieldId, "_option")); - options.push(input.value); - } - return options; - } - function addRadioCheckboxOpt(type, opt, fieldId, fieldKey, isProduct, classes) { - var single = ''; - var isOther = opt.key.includes('other'); - var id = "field_".concat(fieldKey, "-").concat(opt.key); - var inputType = type === 'scale' ? 'radio' : type; - var other = ""); - this.getSingle = function () { - /** - * Get single option template. - * - * @param {Object} option Object containing the option data. - * @param {string} type The field type. - * @param {string} fieldId The field id. - * @param {string} classes The option clasnames. - * @param {string} id The input id attribute. - */ - single = wp.hooks.applyFilters('frm_admin.build_single_option_template', single, { - opt: opt, - type: type, - fieldId: fieldId, - classes: classes, - id: id - }); - if ('' !== single) { - return single; - } - return "
              \n\t\t\t\t\t\n\t\t\t\t\t").concat(isOther ? other : '', "\n\t\t\t\t
              "); - }; - return this.getSingle(); - } - function fillDropdownOpts(field, atts) { - if (!field) { - return; - } - var sourceID = atts.sourceID; - var placeholder = atts.placeholder; - var isProduct = isProductField(sourceID); - var showOther = atts.other; - removeDropdownOpts(field); - var opts = getMultipleOpts(sourceID, field.id.includes('frm_field_logic_opt')); - var hasPlaceholder = placeholder !== undefined; - for (var i = 0; i < opts.length; i++) { - var label = opts[i].label; - var isOther = opts[i].key.includes('other'); - if (hasPlaceholder && label !== '') { - addBlankSelectOption(field, placeholder); - } else if (hasPlaceholder) { - label = placeholder; - } - hasPlaceholder = false; - if (!isOther || showOther) { - var opt = document.createElement('option'); - opt.value = opts[i].saved; - opt.innerHTML = purifyHtml(label); - if (isProduct) { - opt.setAttribute('data-price', opts[i].price); - } - field.append(opt); - } - } - } - function addBlankSelectOption(field, placeholder) { - var opt = document.createElement('option'); - var firstChild = field.firstChild; - opt.value = ''; - opt.innerHTML = placeholder; - if (firstChild !== null) { - firstChild.before(opt); - field.selectedIndex = 0; - } else { - field.append(opt); - } - } - - /** - * Get multiple options for a field. - * - * @param {string} fieldId The field id. - * @param {boolean} showValueAsLabel Whether to show the value as label for empty labels. - */ - function getMultipleOpts(fieldId) { - var showValueAsLabel = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; - var i; - var saved; - var labelName; - var label; - var key; - var optObj; - var checked = false; - var opts = []; - var imageUrl = ''; - var optVals = jQuery("input[name^=\"field_options[options_".concat(fieldId, "]\"]")).filter('[name$="[label]"], [name*="[other_"]'); - var isProduct = isProductField(fieldId); - var showLabelWithImage = showingLabelWithImage(fieldId); - var hasImageOptions = imagesAsOptions(fieldId); - var separateValues = usingSeparateValues(fieldId); - for (i = 0; i < optVals.length; i++) { - if (optVals[i].name.indexOf('[000]') > 0) { - continue; - } - saved = optVals[i].value; - label = saved; - key = optVals[i].name.replace("field_options[options_".concat(fieldId, "]["), '').replace('[label]', '').replace(']', ''); - if (separateValues) { - labelName = optVals[i].name.replace('[label]', '[value]'); - saved = jQuery("input[name=\"".concat(labelName, "\"]")).val(); - if (showValueAsLabel && '' === label) { - label = '' !== saved ? saved : frm_admin_js.no_label; - } - } - if (hasImageOptions) { - imageUrl = getImageUrlFromInput(optVals[i]); - label = getImageLabel(label, showLabelWithImage, imageUrl); - } - - /** - * @since 5.0.04 - */ - label = frmAdminBuild.hooks.applyFilters('frm_choice_field_label', label, fieldId, optVals[i], hasImageOptions); - checked = getChecked(optVals[i].id); - optObj = { - saved: saved, - label: label, - checked: checked, - key: key - }; - if (isProduct) { - labelName = optVals[i].name.replace('[label]', '[price]'); - optObj.price = jQuery("input[name=\"".concat(labelName, "\"]")).val(); - } - opts.push(optObj); - } - return opts; - } - function getImageUrlFromInput(optVal) { - var wrapper = jQuery(optVal).siblings('.frm_image_preview_wrapper'); - if (!wrapper.length) { - return ''; - } - var img = wrapper.find('img'); - if (!img.length) { - return ''; - } - return img.attr('src'); - } - function purifyHtml(html) { - if (html instanceof Element || html instanceof Document) { - html = html.outerHTML; - } - var clean = jQuery.parseHTML(html).reduce(function (total, currentNode) { - var cleanNode = frmDom.cleanNode(currentNode); - if ('#text' === cleanNode.nodeName) { - return total + cleanNode.textContent; - } - return total + cleanNode.outerHTML; - }, ''); - if (clean !== html) { - // Clean it until nothing changes, in case the stripped result is now unsafe. - return purifyHtml(clean); - } - return clean; - } - function getImageLabel(label, showLabelWithImage, imageUrl) { - var originalLabel = label; - originalLabel = purifyHtml(originalLabel); - var labelImage; - if (imageUrl) { - labelImage = img({ - src: imageUrl, - alt: originalLabel - }); - } else { - labelImage = div({ - className: 'frm_empty_url' - }); - labelImage.innerHTML = frmAdminJs.image_placeholder_icon; - } - var imageLabelClass = showLabelWithImage ? ' frm_label_with_image' : ''; - var imageLabel = tag('span', { - className: 'frm_text_label_for_image_inner' - }); - imageLabel.innerHTML = originalLabel; - var labelNode = tag('span', { - className: "frm_image_option_container".concat(imageLabelClass), - children: [labelImage, tag('span', { - className: 'frm_text_label_for_image', - child: imageLabel - })] - }); - return labelNode; - } - function getChecked(id) { - var field = jQuery("#".concat(id)); - if (field.length === 0) { - return false; - } - var checkbox = field.siblings('input[type=checkbox]'); - return checkbox.length && checkbox.prop('checked'); - } - function removeDropdownOpts(field) { - var i; - if (field.options === undefined) { - return; - } - for (i = field.options.length - 1; i >= 0; i--) { - field.remove(i); - } - } - - /** - * Is the box checked to use separate values? - * @param {number} fieldId The field ID. - */ - function usingSeparateValues(fieldId) { - return isChecked("separate_value_".concat(fieldId)); - } - - /** - * Is the box checked to use images as options? - * @param {number} fieldId The field ID. - */ - function imagesAsOptions(fieldId) { - var checked = false; - var field = document.getElementsByName("field_options[image_options_".concat(fieldId, "]")); - for (var i = 0; i < field.length; i++) { - if (field[i].checked) { - checked = '0' !== field[i].value; - } - } - - /** - * @since 5.0.04 - */ - return frmAdminBuild.hooks.applyFilters('frm_choice_field_images_as_options', checked, fieldId); - } - function showingLabelWithImage(fieldId) { - var isShowing = !isChecked("hide_image_text_".concat(fieldId)); - - /** - * @since 5.0.04 - */ - return frmAdminBuild.hooks.applyFilters('frm_choice_field_showing_label_with_image', isShowing, fieldId); - } - function isChecked(id) { - var field = document.getElementById(id); - if (!field) { - return false; - } - return field.checked; - } - function checkUniqueOpt(targetInput) { - var settingsContainer = targetInput.closest('.frm-single-settings'); - var fieldId = settingsContainer.getAttribute('data-fid'); - var areValuesSeparate = settingsContainer.querySelector("[name=\"field_options[separate_value_".concat(fieldId, "]\"]")).checked; - if (areValuesSeparate && !targetInput.name.endsWith('[value]')) { - return; - } - var container = document.getElementById("frm_field_".concat(fieldId, "_opts")); - var conflicts = Array.from(container.querySelectorAll('input[type="text"]')).filter(function (input) { - return input.id !== targetInput.id && areValuesSeparate === input.name.endsWith('[value]') && input.value === targetInput.value; - }); - if (conflicts.length) { - /* translators: %s: The detected option value. */ - infoModal(sprintf(__('Duplicate option value "%s" detected', 'formidable'), purifyHtml(targetInput.value))); - } - } - function getFieldValues() { - /*jshint validthis:true */ - var isTaxonomy; - var val = this.value; - if (val) { - var parentIDs = this.parentNode.id.replace('frm_logic_', '').split('_'); - var fieldID = parentIDs[0]; - var metaKey = parentIDs[1]; - var valueField = document.getElementById("frm_field_id_".concat(val)); - var valueFieldType = valueField.getAttribute('data-ftype'); - var fill = document.getElementById("frm_show_selected_values_".concat(fieldID, "_").concat(metaKey)); - var optionName = "field_options[hide_opt_".concat(fieldID, "][]"); - var optionID = "frm_field_logic_opt_".concat(fieldID); - var input = false; - var showSelect = valueFieldType === 'select' || valueFieldType === 'checkbox' || valueFieldType === 'radio'; - var showText = valueFieldType === 'text' || valueFieldType === 'email' || valueFieldType === 'phone' || valueFieldType === 'url' || valueFieldType === 'number'; - if (showSelect) { - isTaxonomy = document.getElementById("frm_has_hidden_options_".concat(val)); - if (isTaxonomy) { - // get the category options with ajax - showSelect = false; - } - } - if (showSelect || showText) { - var comparison = document.querySelector("#frm_logic_".concat(fieldID, "_").concat(metaKey, " [name=\"field_options[hide_field_cond_").concat(fieldID, "][]\"]")).value; - fill.innerHTML = ''; - var creatingValuesDropdown = showSelect && !['LIKE', 'not LIKE', 'LIKE%', '%LIKE'].includes(comparison); - if (creatingValuesDropdown) { - input = document.createElement('select'); - } else { - input = document.createElement('input'); - input.type = 'text'; - } - input.name = optionName; - input.id = "".concat(optionID, "_").concat(metaKey); - fill.append(input); - if (creatingValuesDropdown) { - var fillField = document.getElementById(input.id); - fillDropdownOpts(fillField, { - sourceID: val, - placeholder: '', - other: true - }); - } - } else { - var thisType = this.getAttribute('data-type'); - var callback = function callback() { - var event = new CustomEvent('frm_logic_options_loaded'); - event.frmData = { - valueFieldType: valueFieldType, - fieldID: fieldID, - metaKey: metaKey - }; - document.dispatchEvent(event); - }; - frmGetFieldValues(val, fieldID, metaKey, thisType, undefined, callback); - } - } - } - function getFieldSelection() { - /*jshint validthis:true */ - var formId = this.value; - if (formId) { - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - getTaxOrFieldSelection(formId, fieldId); - } - } - function getTaxOrFieldSelection(formId, fieldId) { - if (formId) { - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_get_field_selection', - field_id: fieldId, - form_id: formId, - nonce: frmGlobal.nonce - }, - success: function success(msg) { - var $selectedFields = jQuery("#frm_show_selected_fields_".concat(fieldId)); - $selectedFields.toggleClass('frm6', !msg.includes('frm-inline-message')); - $selectedFields.html(msg).show(); - } - }); - } - } - function updateFieldOrder() { - var self = this; - this.initOnceInAllInstances = function () { - if (updateFieldOrder.prototype.orderFieldsObject !== undefined) { - return; - } - - // It will store the order input fields ( input[name="field_options[field_order_{fieldId}]"] ). - // It will help to reduce the DOM searches based on fieldId. - // The same object data is used across all "updateFieldOrder" instances. - updateFieldOrder.prototype.orderFieldsObject = {}; - - // Get the Form group that will handle the fields settings. - // Perform a single DOM search and use it across all "updateFieldOrder" instances. - updateFieldOrder.prototype.fieldSettingsForm = document.getElementById('frm-end-form-marker').closest('form'); - }; - this.getFieldOrderInputById = function (fieldId, parent) { - var field; - var orderFieldsObject = updateFieldOrder.prototype.orderFieldsObject; - var fieldSettingsForm = updateFieldOrder.prototype.fieldSettingsForm; - if (orderFieldsObject[fieldId] === undefined) { - field = fieldSettingsForm.querySelector("input[name=\"field_options[field_order_".concat(fieldId, "]\"]")); - if (!field) { - field = parent.querySelector("input[name=\"field_options[field_order_".concat(fieldId, "]\"]")); - } - orderFieldsObject[fieldId] = field; - return field; - } - return orderFieldsObject[fieldId]; - }; - this.initOnceInAllInstances(); - renumberPageBreaks(); - return function () { - var fieldId; - var field; - var currentOrder; - var newOrder; - var i; - var singleField; - var moveFieldsClass = new moveFieldSettings(); - var fields = jQuery('li.frm_field_box', jQuery('#frm-show-fields')); - for (i = 0; i < fields.length; i++) { - fieldId = fields[i].getAttribute('data-fid'); - field = self.getFieldOrderInputById(fieldId, fields[i]); - - // get current field order, make sure we don't get the "field" reference as the "field" value will get updated later. - currentOrder = field ? Object.assign({}, field.value)[0] : null; - newOrder = i + 1; - if (currentOrder != newOrder && null !== currentOrder) { - field.value = newOrder; - singleField = fields[i].querySelector("#frm-single-settings-".concat(fieldId)); - - // add field that needs to be moved to "updateFieldOrder.prototype.fieldSettingsForm" - moveFieldsClass.append(singleField); - fieldUpdated(); - } - } - // move all appended fields - moveFieldsClass.moveFields(); - }(); - } - function toggleSectionHolder() { - document.querySelectorAll('.start_divider').forEach(function (divider) { - toggleOneSectionHolder(jQuery(divider)); - }); - } - function toggleOneSectionHolder($section) { - if (!$section.length) { - return; - } - var $rows = $section.find('ul.frm_sorting'); - var sectionHasFields = false; - var length = $rows.length; - for (var index = 0; index < length; ++index) { - if (0 !== getFieldsInRow(jQuery($rows.get(index))).length) { - sectionHasFields = true; - break; - } - } - var noSectionFields = $section.parent().children('.frm_no_section_fields').get(0); - noSectionFields.classList.toggle('frm_block', !sectionHasFields); - } - function handleShowPasswordLiveUpdate() { - frmDom.util.documentOn('change', '.frm_show_password_setting_input', function (event) { - var fieldId = event.target.getAttribute('data-fid'); - var fieldEl = document.getElementById("frm_field_id_".concat(fieldId)); - if (!fieldEl) { - return; - } - fieldEl.classList.toggle('frm_disabled_show_password', !event.target.checked); - }); - } - function slideDown() { - /*jshint validthis:true */ - var id = jQuery(this).data('slidedown'); - var $thisId = jQuery(document.getElementById(id)); - if ($thisId.is(':hidden')) { - $thisId.slideDown('fast'); - this.style.display = 'none'; - } - return false; - } - function slideUp() { - /*jshint validthis:true */ - var id = jQuery(this).data('slideup'); - var $thisId = jQuery(document.getElementById(id)); - $thisId.slideUp('fast'); - $thisId.siblings('a').show(); - return false; - } - function adjustVisibilityValuesForEveryoneValues(element, option) { - if ('' === option.getAttribute('value')) { - onEveryoneOptionSelected(jQuery(this)); - } else { - unselectEveryoneOptionIfSelected(jQuery(this)); - } - } - function onEveryoneOptionSelected($select) { - $select.val(''); - $select.next('.btn-group').find('.multiselect-container input[value!=""]').prop('checked', false); - } - function unselectEveryoneOptionIfSelected($select) { - var selectedValues = $select.val(); - if (selectedValues === null) { - $select.next('.btn-group').find('.multiselect-container input[value=""]').prop('checked', true); - onEveryoneOptionSelected($select); - return; - } - var index = selectedValues.indexOf(''); - if (index >= 0) { - selectedValues.splice(index, 1); - $select.val(selectedValues); - $select.next('.btn-group').find('.multiselect-container input[value=""]').prop('checked', false); - } - } - - /** - * Get rid of empty container that inserts extra space. - */ - function hideEmptyEle() { - jQuery('.frm-hide-empty').each(function () { - if (jQuery(this).text().trim().length === 0) { - jQuery(this).remove(); - } - }); - } - - /* Change the classes in the builder */ - function changeFieldClass(field, setting) { - var classes; - var replace; - var alignField; - var replaceWith = " ".concat(setting.value); - var fieldId = field.getAttribute('data-fid'); - - // Include classes from multiple settings. - if (fieldId !== undefined) { - if (setting.classList.contains('field_options_align')) { - replaceWith += " ".concat(document.getElementById("frm_classes_".concat(fieldId)).value); - } else if (setting.classList.contains('frm_classes')) { - alignField = document.getElementById("field_options_align_".concat(fieldId)); - if (alignField) { - replaceWith += " ".concat(alignField.value); - } - } - } - replaceWith += ' '; - - // Allow for the column number dropdown. - replaceWith = replaceWith.replace(' block ', ' vertical_radio ').replace(' inline ', ' horizontal_radio '); - classes = field.className.split(' frmstart ')[1]; - classes = 0 === classes.indexOf('frmend ') ? '' : classes.split(' frmend ')[0]; - if (classes.trim() === '') { - replace = ' frmstart frmend '; - if (!field.className.includes(replace)) { - replace = ' frmstart frmend '; - } - replaceWith = " frmstart ".concat(replaceWith.trim(), " frmend "); - } else { - replace = classes.trim(); - replaceWith = replaceWith.trim(); - } - field.className = field.className.replace(replace, replaceWith); - } - function maybeShowInlineModal(e) { - /*jshint validthis:true */ - e.preventDefault(); - showInlineModal(this, undefined, e); - } - function showInlineModal(icon, input, event) { - var box = document.getElementById(icon.getAttribute('data-open')); - var container = jQuery(icon).closest('p,ul'); - var inputTrigger = input !== undefined; - if (container.hasClass('frm-open')) { - container.removeClass('frm-open'); - box.classList.add('frm_hidden'); - } else { - if (!inputTrigger) { - input = getInputForIcon(icon); - } - if (input) { - if (!inputTrigger) { - var key = event.key; - if (key !== 'Enter' && key !== ' ') { - input.focus(); - } - } - container.after(box); - box.setAttribute('data-fills', input.id.replace('-proxy-input', '')); - if (box.id.indexOf('frm-calc-box') === 0) { - popCalcFields(box, true); - } - } - container.addClass('frm-open'); - box.classList.remove('frm_hidden'); - - /** - * @since 6.4.1 - */ - wp.hooks.doAction('frm_show_inline_modal', box, icon); - } - } - function dismissInlineModal(e) { - /*jshint validthis:true */ - e.preventDefault(); - this.parentNode.classList.add('frm_hidden'); - jQuery(".frm-open [data-open=\"".concat(this.parentNode.id, "\"]")).closest('.frm-open').removeClass('frm-open'); - } - - /** - * Close frm-modal-no-dismiss element when clicking outside of it - * - * @param {Event} event The click event - */ - function closeModalOnOutsideClick(_ref3) { - var target = _ref3.target; - if (target.closest('.frm-inline-modal.frm-modal-no-dismiss') || target.closest('.frm-show-inline-modal') || target.closest('#frm_adv_info') || target.closest('.frm-token-proxy-input')) { - return; - } - - // Close all inline modals (without close button) that are not hidden - document.querySelectorAll('.frm-inline-modal.frm-modal-no-dismiss:not(.frm_hidden)').forEach(function (modal) { - modal.classList.add('frm_hidden'); - modal.previousElementSibling.classList.remove('frm-open'); - }); - } - function changeInputtedValue() { - /*jshint validthis:true */ - var i; - var action = this.getAttribute('data-frmchange').split(','); - for (i = 0; i < action.length; i++) { - if (action[i] === 'updateOption') { - changeHiddenSeparateValue(this); - } else if (action[i] === 'updateDefault') { - changeDefaultRadioValue(this); - } else if (action[i] === 'checkUniqueOpt') { - checkUniqueOpt(this); - } else { - this.value = this.value[action[i]](); - } - } - } - - /** - * When the saved value is changed, update the default value radio. - * @param {HTMLElement} input The changed input element. - */ - function changeDefaultRadioValue(input) { - var parentLi = getOptionParent(input); - var key = parentLi.getAttribute('data-optkey'); - var fieldId = getOptionFieldId(parentLi, key); - var defaultRadio = parentLi.querySelector("input[name=\"default_value_".concat(fieldId, "\"]")); - if (defaultRadio !== null) { - defaultRadio.value = input.value; - } - } - - /** - * If separate values are not enabled, change the saved value when - * the displayed value is changed. - * @param {HTMLElement} input The changed input element. - */ - function changeHiddenSeparateValue(input) { - var savedVal; - var parentLi = getOptionParent(input); - var key = parentLi.getAttribute('data-optkey'); - var fieldId = getOptionFieldId(parentLi, key); - var sep = document.getElementById("separate_value_".concat(fieldId)); - if (sep && sep.checked === false) { - // If separate values are not turned on. - savedVal = document.getElementById("field_key_".concat(fieldId, "-").concat(key)); - savedVal.value = input.value; - changeDefaultRadioValue(savedVal); - } - } - function getOptionParent(input) { - var parentLi = input.parentNode; - if (parentLi.tagName !== 'LI') { - parentLi = parentLi.parentNode; - } - return parentLi; - } - function getOptionFieldId(li, key) { - var liId = li.id; - return liId.replace('frm_delete_field_', '').replace("-".concat(key, "_container"), ''); - } - function submitBuild() { - /*jshint validthis:true */ - var $thisEle = this; - if (showNameYourFormModal()) { - return; - } - preFormSave(this); - var $form = jQuery(builderForm); - var v = JSON.stringify($form.serializeArray()); - jQuery(document.getElementById('frm_compact_fields')).val(v); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_save_form', - frm_compact_fields: v, - nonce: frmGlobal.nonce - }, - success: function success(msg) { - afterFormSave($thisEle); - var $postStuff = document.getElementById('post-body-content'); - var $html = document.createElement('div'); - $html.setAttribute('class', 'frm_updated_message'); - $html.innerHTML = msg; - $postStuff.insertBefore($html, $postStuff.firstChild); - reloadIfAddonActivatedAjaxSubmitOnly(); - }, - error: function error() { - triggerSubmit(document.getElementById('frm_js_build_form')); - } - }); - } - function triggerSubmit(form) { - var button = form.ownerDocument.createElement('input'); - button.style.display = 'none'; - button.type = 'submit'; - form.append(button); - button.click(); - button.remove(); - } - function triggerChange(element) { - jQuery(element).trigger('change'); - } - function submitNoAjax() { - /*jshint validthis:true */ - if (showNameYourFormModal()) { - return; - } - preFormSave(this); - var form = jQuery(builderForm); - jQuery(document.getElementById('frm_compact_fields')).val(JSON.stringify(form.serializeArray())); - triggerSubmit(document.getElementById('frm_js_build_form')); - } - - /** - * Display a modal dialog for naming a new form template, if applicable. - * - * @return {boolean} True if the modal is successfully initialized and displayed; false otherwise. - */ - function showNameYourFormModal() { - // Exit early if the 'new_template' URL parameter is not set to 'true' - if (!shouldShowNameYourFormNameModal()) { - return false; - } - var modalWidget = initModal('#frm-form-templates-modal', '440px'); - if (!modalWidget) { - return false; - } - - // Set the vertical offset for the modal and open it - offsetModalY(modalWidget, '72px'); - modalWidget.dialog('open'); - return true; - } - - /** - * Returns true if 'Name Your Form' modal should be displayed. - * - * @return {boolean} True if the modal should be displayed. - */ - function shouldShowNameYourFormNameModal() { - var _document$querySelect3; - var formNameInput = document.getElementById('frm_form_name'); - if (formNameInput && formNameInput.value.trim() !== '') { - return false; - } - return 'true' === urlParams.get('new_template') && ((_document$querySelect3 = document.querySelector('#frm_top_bar #frm_bs_dropdown .frm_bstooltip')) === null || _document$querySelect3 === void 0 ? void 0 : _document$querySelect3.textContent.trim()) === frm_admin_js.noTitleText; - } - - /** - * Manages event handling for the 'Name your form' modal. - * - * Attaches click and keydown event listeners to the save button and input field. - * - * @return {void} - */ - function addFormNameModalEvents() { - var saveFormNameButton = document.getElementById('frm-save-form-name-button'); - var newFormNameInput = document.getElementById('frm_new_form_name_input'); - - // Attach click event listener - onClickPreventDefault(saveFormNameButton, onSaveFormNameButton); - - // Attach keydown event listener - newFormNameInput.addEventListener('keydown', function (event) { - if (event.key === 'Enter') { - onSaveFormNameButton(event); - } - }); - } - - /** - * Handles the click event on the save form name button. - * - * @param {Event} event The click event object. - * @return {void} - */ - var onSaveFormNameButton = function onSaveFormNameButton(event) { - var newFormName = document.getElementById('frm_new_form_name_input').value.trim(); - - // Prepare FormData for the POST request - var formData = new FormData(); - formData.append('form_id', urlParams.get('id')); - formData.append('form_name', newFormName); - - // Perform the POST request - doJsonPost('rename_form', formData).then(function (data) { - // Remove the 'new_template' parameter from the URL and update the browser history - urlParams.delete('new_template'); - currentURL.search = urlParams.toString(); - history.replaceState({}, '', currentURL.toString()); - if (null !== document.getElementById('frm_notification_settings')) { - document.getElementById('frm_form_name').value = newFormName; - document.getElementById('frm_form_key').value = data.form_key; - } - - // Trigger the 'Save' button click using jQuery - jQuery('#frm-publishing').find('.frm_button_submit').trigger('click'); - }); - }; - function preFormSave(b) { - removeWPUnload(); - if (jQuery('form.inplace_form').length) { - jQuery('.inplace_save, .postbox').trigger('click'); - } - if (b.classList.contains('frm_button_submit')) { - b.classList.add('frm_loading_form'); - } else { - b.classList.add('frm_loading_button'); - } - b.setAttribute('aria-busy', 'true'); - adjustFormatInputBeforeSave(); - } - - /** - * Updates the format input based on the selected format type from dropdowns during the form save process. - * - * @since 6.9 - * - * @return {void} - */ - function adjustFormatInputBeforeSave() { - var formatTypes = document.querySelectorAll('.frm_format_dropdown, .frm_phone_type_dropdown'); - var valueMap = { - none: '', - international: 'international', - currency: 'currency', - number: 'number' - }; - formatTypes.forEach(function (formatType) { - var value = formatType.value; - if (value in valueMap) { - var formatInput = document.getElementById("frm_format_".concat(formatType.dataset.fieldId)); - formatInput.value = valueMap[value]; - } - }); - } - function afterFormSave(button) { - button.classList.remove('frm_loading_form'); - button.classList.remove('frm_loading_button'); - resetOptionTextDetails(); - fieldsUpdated = 0; - button.setAttribute('aria-busy', 'false'); - setTimeout(function () { - jQuery('.frm_updated_message').fadeOut('slow', function () { - this.remove(); - }); - }, 5000); - } - function initUpgradeModal() { - var upgradePopup = __webpack_require__(/*! ./upgrade-popup */ "./js/src/admin/upgrade-popup.js"); - upgradePopup.initUpgradeModal(); - } - function addOneClick(element, type, upgradeLabel) { - var upgradePopup = __webpack_require__(/*! ./upgrade-popup */ "./js/src/admin/upgrade-popup.js"); - upgradePopup.addOneClick(element, type, upgradeLabel); - } - - /** - * Opens a basic modal with the given title and content. - * - * @param {Event} event The event object. - * @return {void} - */ - function showBasicModal(event) { - var _event$target$dataset; - var button = (_event$target$dataset = event.target.dataset) !== null && _event$target$dataset !== void 0 && _event$target$dataset.modalTitle ? event.target : event.target.closest('[data-modal-title]'); - if (!button) { - return; - } - var _button$dataset = button.dataset, - modalTitle = _button$dataset.modalTitle, - modalContent = _button$dataset.modalContent; - if (!modalTitle || !modalContent) { - return; - } - event.preventDefault(); - frmDom.modal.maybeCreateModal('frmBasicModal', { - title: modalTitle, - content: div({ - className: 'inside', - child: span(modalContent) - }) - }); - } - function getRequiredLicenseFromTrigger(element) { - if (element.dataset.requires) { - return element.dataset.requires; - } - return 'Pro'; - } - function populateUpgradeTab(element) { - var title = element.dataset.upgrade; - var tab = element.getAttribute('href').replace('#', ''); - var container = document.querySelector(".frm_".concat(tab)) || document.querySelector(".".concat(tab)); - if (!container) { - return; - } - if (container.querySelector('.frm-upgrade-message')) { - // Tab has already been populated. - return; - } - var h2 = container.querySelector('h2'); - h2.style.borderBottom = 'none'; - - /* translators: %s: Form Setting section name (ie Form Permissions, Form Scheduling). */ - h2.textContent = sprintf(__('%s are not installed', 'formidable'), title); - container.classList.add('frmcenter'); - var upgradeModal = document.getElementById('frm_upgrade_modal'); - appendClonedModalElementToContainer('frm-oneclick'); - appendClonedModalElementToContainer('frm-addon-status'); - - // Borrow the call to action from the Upgrade upgradeModal which should exist on the settings page (it is still used for other upgrades including Actions). - var upgradeModalLink = upgradeModal.querySelector('.frm-upgrade-link'); - if (upgradeModalLink) { - var _upgradeModalLink$nex; - var upgradeButton; - var upgradeActions = upgradeModalLink.closest('.frm-upgrade-modal-actions'); - if (upgradeActions) { - upgradeActions = upgradeActions.cloneNode(true); - upgradeButton = upgradeActions.querySelector('.frm-upgrade-link'); - } else { - upgradeButton = upgradeModalLink.cloneNode(true); - } - var level = upgradeButton.querySelector('.license-level'); - if (level) { - level.textContent = getRequiredLicenseFromTrigger(element); - } - container.append(upgradeActions || upgradeButton); - - // Maybe append the secondary "Already purchased?" link from the upgradeModal as well. - if ((_upgradeModalLink$nex = upgradeModalLink.nextElementSibling) !== null && _upgradeModalLink$nex !== void 0 && _upgradeModalLink$nex.querySelector('.frm-link-secondary')) { - container.append(upgradeModalLink.nextElementSibling.cloneNode(true)); - } - appendClonedModalElementToContainer('frm-oneclick-button'); - } - appendClonedModalElementToContainer('frm-upgrade-message'); - var upgradeLabel = element.dataset.message; - if (upgradeLabel === undefined) { - upgradeLabel = element.dataset.upgrade; - } - addOneClick(element, 'tab', upgradeLabel); - if (element.dataset.screenshot) { - container.append(getScreenshotWrapper(element.dataset.screenshot)); - } - function appendClonedModalElementToContainer(className) { - container.append(upgradeModal.querySelector(".".concat(className)).cloneNode(true)); - } - } - function getScreenshotWrapper(screenshot) { - var folderUrl = "".concat(frmGlobal.url, "/images/screenshots/"); - var wrapper = div({ - className: 'frm-settings-screenshot-wrapper', - children: [getToolbar(), div({ - child: img({ - src: folderUrl + screenshot - }) - })] - }); - function getToolbar() { - var children = getColorIcons(); - children.push(img({ - src: "".concat(frmGlobal.url, "/images/tab.svg") - })); - return div({ - className: 'frm-settings-screenshot-toolbar', - children: children - }); - } - function getColorIcons() { - return ['#ED8181', '#EDE06A', '#80BE30'].map(function (color) { - var circle = div({ - className: 'frm-minmax-icon' - }); - circle.style.backgroundColor = color; - return circle; - }); - } - return wrapper; - } - - /* Form settings */ - - function showInputIcon(parentClass) { - if (parentClass === undefined) { - parentClass = ''; - } - maybeAddFieldSelection(parentClass); - jQuery("".concat(parentClass, " .frm_has_shortcodes:not(.frm-with-right-icon) input,").concat(parentClass, " .frm_has_shortcodes:not(.frm-with-right-icon) textarea")).wrap('').before(''); - } - - /** - * For reverse compatibility. Check for fields that were - * using the old sidebar. - * @param {string} parentClass The parent CSS class selector. - */ - function maybeAddFieldSelection(parentClass) { - var i; - var missingClass = jQuery("".concat(parentClass, " :not(.frm_has_shortcodes) .frm_not_email_message, ").concat(parentClass, " :not(.frm_has_shortcodes) .frm_not_email_to, ").concat(parentClass, " :not(.frm_has_shortcodes) .frm_not_email_subject")); - for (i = 0; i < missingClass.length; i++) { - missingClass[i].parentNode.classList.add('frm_has_shortcodes'); - } - } - function showSuccessOpt() { - /*jshint validthis:true */ - var c = 'success'; - if (this.name === 'options[edit_action]') { - c = 'edit'; - } - var v = jQuery(this).val(); - jQuery(".".concat(c, "_action_box")).hide(); - if (v === 'redirect') { - jQuery(".".concat(c, "_action_redirect_box.").concat(c, "_action_box")).fadeIn('slow'); - } else if (v === 'page') { - jQuery(".".concat(c, "_action_page_box.").concat(c, "_action_box")).fadeIn('slow'); - } else { - jQuery(".".concat(c, "_action_message_box.").concat(c, "_action_box")).fadeIn('slow'); - } - } - function copyFormAction(event) { - if (waitForActionToLoadBeforeCopy(event.target)) { - return; - } - var targetSettings = event.target.closest('.frm_form_action_settings'); - var wysiwygs = targetSettings.querySelectorAll('.wp-editor-area'); - if (wysiwygs.length) { - // Temporary remove TinyMCE before cloning to avoid TinyMCE conflicts. - wysiwygs.forEach(function (wysiwyg) { - tinymce.EditorManager.execCommand('mceRemoveEditor', true, wysiwyg.id); - }); - } - var $action = jQuery(targetSettings).clone(); - var currentID = $action.attr('id').replace('frm_form_action_', ''); - var newID = newActionId(currentID); - $action.find('.frm_action_id, .frm-btn-group').remove(); - $action.find("input[name$=\"[".concat(currentID, "][ID]\"]")).val(''); - $action.find('.widget-inside').hide(); - - // the .html() gets original values, so they need to be set - $action.find('input[type=text], textarea, input[type=number]').prop('defaultValue', function () { - return this.value; - }); - $action.find('input[type=checkbox], input[type=radio]').prop('defaultChecked', function () { - return this.checked; - }); - var rename = new RegExp("\\[".concat(currentID, "\\]"), 'g'); - var reid = new RegExp("_".concat(currentID, "\""), 'g'); - var reclass = new RegExp("-".concat(currentID, "\""), 'g'); - var revalue = new RegExp("\"".concat(currentID, "\""), 'g'); // if a field id matches, this could cause trouble - - var html = $action.html().replace(rename, "[".concat(newID, "]")).replace(reid, "_".concat(newID, "\"")); - html = html.replace(reclass, "-".concat(newID, "\"")).replace(revalue, "\"".concat(newID, "\"")); - var newAction = div({ - id: "frm_form_action_".concat(newID), - className: $action.get(0).className - }); - newAction.setAttribute('data-actionkey', newID); - newAction.innerHTML = html; - newAction.querySelectorAll('.wp-editor-wrap, .wp-editor-wrap *').forEach(function (element) { - if ('string' === typeof element.className) { - element.className = element.className.replace(currentID, newID); - } - element.id = element.id.replace(currentID, newID); - }); - newAction.classList.remove('open'); - document.getElementById('frm_notification_settings').append(newAction); - if (wysiwygs.length) { - // Re-initialize the original wysiwyg which was removed before cloning. - wysiwygs.forEach(function (wysiwyg) { - frmDom.wysiwyg.init(wysiwyg); - }); - newAction.querySelectorAll('.wp-editor-area').forEach(function (wysiwyg) { - frmDom.wysiwyg.init(wysiwyg); - }); - } - if (newAction.classList.contains('frm_single_on_submit_settings')) { - var autocompleteInput = newAction.querySelector('input.frm-page-search'); - if (autocompleteInput) { - initAutocomplete(newAction); - } - } - initiateMultiselect(); - var hookName = 'frm_after_duplicate_action'; - wp.hooks.doAction(hookName, newAction); - } - function waitForActionToLoadBeforeCopy(element) { - var $trigger = jQuery(element); - var $original = $trigger.closest('.frm_form_action_settings'); - var $inside = $original.find('.widget-inside'); - if ($inside.find('p, div, table').length) { - return false; - } - var $top = $original.find('.widget-top'); - $top.on('frm-action-loaded', function () { - $trigger.trigger('click'); - $original.removeClass('open'); - $inside.hide(); - }); - $top.trigger('click'); - return true; - } - function newActionId(currentID) { - var newID = parseInt(currentID, 10) + 11; - var exists = document.getElementById("frm_form_action_".concat(newID)); - if (exists) { - newID++; - newID = newActionId(newID); - } - return newID; - } - function addFormAction() { - /*jshint validthis:true */ - var type = jQuery(this).data('actiontype'); - if (isAtLimitForActionType(type)) { - return; - } - var actionId = getNewActionId(); - var formId = thisFormId; - var placeholderSetting = document.createElement('div'); - placeholderSetting.classList.add("frm_single_".concat(type, "_settings")); - var actionsList = document.getElementById('frm_notification_settings'); - actionsList.append(placeholderSetting); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_add_form_action', - type: type, - list_id: actionId, - form_id: formId, - nonce: frmGlobal.nonce - }, - success: handleAddFormActionSuccess - }); - function handleAddFormActionSuccess(html) { - fieldUpdated(); - placeholderSetting.remove(); - closeOpenActions(); - var newActionContainer = div(); - newActionContainer.innerHTML = html; - var widgetTop = newActionContainer.querySelector('.widget-top'); - Array.from(newActionContainer.children).forEach(function (child) { - return actionsList.append(child); - }); - jQuery('.frm_form_action_settings').fadeIn('slow'); - var newAction = document.getElementById("frm_form_action_".concat(actionId)); - newAction.classList.add('open'); - document.getElementById('post-body-content').scroll({ - top: newAction.offsetTop + 10, - left: 0, - behavior: 'smooth' - }); - - // Check if icon should be active - checkActiveAction(type); - showInputIcon("#frm_form_action_".concat(actionId)); - initiateMultiselect(); - initAutocomplete(newAction); - if (widgetTop) { - jQuery(widgetTop).trigger('frm-action-loaded'); - } - - /** - * Fires after added a new form action. - * - * @since 5.5.4 - * - * @param {HTMLElement} formAction Form action element. - */ - frmAdminBuild.hooks.doAction('frm_added_form_action', newAction); - } - } - function closeOpenActions() { - document.querySelectorAll('.frm_form_action_settings.open').forEach(function (setting) { - return setting.classList.remove('open'); - }); - } - function toggleActionGroups() { - /*jshint validthis:true */ - var actions = document.getElementById('frm_email_addon_menu').classList; - var search = document.getElementById('actions-search-input'); - if (actions.contains('frm-all-actions')) { - actions.remove('frm-all-actions'); - actions.add('frm-limited-actions'); - } else { - actions.add('frm-all-actions'); - actions.remove('frm-limited-actions'); - } - - // Reset search. - search.value = ''; - triggerEvent(search, 'input'); - } - function getNewActionId() { - var actionSettings = document.querySelectorAll('.frm_form_action_settings'); - var len = getNewRowId(actionSettings, 'frm_form_action_'); - if (document.getElementById("frm_form_action_".concat(len)) !== undefined) { - len = len + 100; - } - if (lastNewActionIdReturned >= len) { - len = lastNewActionIdReturned + 1; - } - lastNewActionIdReturned = len; - return len; - } - function clickAction(obj) { - var $thisobj = jQuery(obj); - if (obj.className.includes('selected')) { - return; - } - if (obj.className.includes('edit_field_type_end_divider') && $thisobj.closest('.edit_field_type_divider').hasClass('no_repeat_section')) { - return; - } - deselectFields(); - $thisobj.addClass('selected'); - showFieldOptions(obj); - } - - /** - * When a field is selected, show the field settings in the sidebar. - * @param {HTMLElement} obj The selected field element. - */ - function showFieldOptions(obj) { - var _document$querySelect4; - var i; - var fieldId = obj.getAttribute('data-fid'); - var fieldType = obj.getAttribute('data-type'); - var allFieldSettings = document.querySelectorAll('.frm-single-settings:not(.frm_hidden)'); - for (i = 0; i < allFieldSettings.length; i++) { - allFieldSettings[i].classList.add('frm_hidden'); - } - var singleField = document.getElementById("frm-single-settings-".concat(fieldId)); - moveFieldSettings(singleField); - if (fieldType && 'quantity' === fieldType) { - popProductFields(jQuery(singleField).find('.frmjs_prod_field_opt')[0]); - } - - // Scroll settings panel to top - (_document$querySelect4 = document.querySelector('.frm-settings-panel.frm-scrollbar-wrapper')) === null || _document$querySelect4 === void 0 || _document$querySelect4.scrollTo({ - top: 0, - behavior: 'instant' - }); - singleField.classList.remove('frm_hidden'); - - // Cancel slide animation on expanded sections so screen readers - // can immediately access inputs after DOM re-insertion. - singleField.querySelectorAll('h3:not(.frm-collapsed) + .frm-collapse-me').forEach(function (section) { - return section.style.animation = 'none'; - }); - document.getElementById('frm-options-panel-tab').click(); - var editor = singleField.querySelector('.wp-editor-area'); - if (editor) { - frmDom.wysiwyg.init(editor, { - setupCallback: setupTinyMceEventHandlers - }); - } - wp.hooks.doAction('frmShowedFieldSettings', obj, singleField); - maybeAddShortcodesModalTriggerIcon(fieldType, fieldId, singleField); - } - function maybeAddShortcodesModalTriggerIcon(fieldType, fieldId, singleField) { - var _singleField$querySel; - if (!shouldAddShortcodesModalTriggerIcon(fieldType)) { - return; - } - var fieldSettingsSelector = "#frm-single-settings-".concat(fieldId); - if (document.querySelector("".concat(fieldSettingsSelector, " .frm-show-box"))) { - return; - } - (_singleField$querySel = singleField.querySelector('.wp-editor-container')) === null || _singleField$querySel === void 0 || _singleField$querySel.classList.add('frm_has_shortcodes'); - var wrapTextareaWithIconContainer = function wrapTextareaWithIconContainer() { - var textareas = document.querySelectorAll("".concat(fieldSettingsSelector, " .frm_has_shortcodes textarea")); - textareas.forEach(function (textarea) { - var wrapperSpan = span({ - className: 'frm-with-right-icon' - }); - textarea.parentNode.insertBefore(wrapperSpan, textarea); - wrapperSpan.append(createModalTriggerIcon()); - wrapperSpan.append(textarea); - }); - }; - var createModalTriggerIcon = function createModalTriggerIcon() { - return frmDom.svg({ - href: '#frm_more_horiz_solid_icon', - classList: ['frm-show-box'] - }); - }; - wrapTextareaWithIconContainer(); - } - function shouldAddShortcodesModalTriggerIcon(fieldType) { - var fieldsWithShortcodesBox = wp.hooks.applyFilters('frm_fields_with_shortcode_popup', ['html']); - return fieldsWithShortcodesBox.includes(fieldType); - } - function setupTinyMceEventHandlers(editor) { - editor.on('Change', function () { - handleTinyMceChange(editor); - }); - } - function handleTinyMceChange(editor) { - if (!isTinyMceActive() || tinyMCE.activeEditor.isHidden()) { - return; - } - editor.targetElm.value = editor.getContent(); - jQuery(editor.targetElm).trigger('change'); - } - function isTinyMceActive() { - var activeSettings = document.querySelector('.frm-single-settings:not(.frm_hidden)'); - if (!activeSettings) { - return false; - } - var wrapper = activeSettings.querySelector('.wp-editor-wrap'); - return wrapper && wrapper.classList.contains('tmce-active'); - } - - /** - * Move the settings to the sidebar the first time they are changed or selected. - * Keep the end marker at the end of the form. - * @param {HTMLElement} singleField The field settings element to move. - */ - function moveFieldSettings(singleField) { - var self = this; - if (!singleField) { - // The field may have not been loaded yet via ajax. - return; - } - this.fragment = document.createDocumentFragment(); - this.initOnceInAllInstances = function () { - if (moveFieldSettings.prototype.endMarker !== undefined) { - return; - } - // perform a single search in the DOM and use it across all moveFieldSettings instances - moveFieldSettings.prototype.endMarker = document.getElementById('frm-end-form-marker'); - }; - this.append = function (field) { - var classname = field ? field.parentElement.classList : ''; - if (!field || !classname.contains('frm_field_box') && !classname.contains('divider_section_only')) { - return; - } - self.fragment.append(field); - }; - this.moveFields = function () { - builderForm.insertBefore(self.fragment, moveFieldSettings.prototype.endMarker); - }; - this.initOnceInAllInstances(); - - // Move the field if function is called as function with a singleField passed as arg. - // In this particular case only 1 field is needed to be moved so the field will get instantly moved. - // "singleField" may be undefined when it's called as a constructor instead of a function. Use the constructor to add multiple fields which are passed through "append" and move these all at once via "moveFields". - if (singleField !== undefined) { - this.append(singleField); - this.moveFields(); - return; - } - return { - append: this.append, - moveFields: this.moveFields - }; - } - function showEmailRow() { - /*jshint validthis:true */ - var actionKey = jQuery(this).closest('.frm_form_action_settings').data('actionkey'); - var rowType = this.getAttribute('data-emailrow'); - jQuery("#frm_form_action_".concat(actionKey, " .frm_").concat(rowType, "_row")).fadeIn('slow'); - jQuery(this).fadeOut('slow'); - } - function hideEmailRow() { - /*jshint validthis:true */ - var actionBox = jQuery(this).closest('.frm_form_action_settings'); - var rowType = this.getAttribute('data-emailrow'); - var emailRowSelector = ".frm_".concat(rowType, "_row"); - var emailButtonSelector = ".frm_".concat(rowType, "_button"); - jQuery(actionBox).find(emailButtonSelector).fadeIn('slow'); - jQuery(actionBox).find(emailRowSelector).fadeOut('slow', function () { - jQuery(actionBox).find("".concat(emailRowSelector, " input")).val(''); - }); - } - function showEmailWarning() { - /*jshint validthis:true */ - var actionBox = jQuery(this).closest('.frm_form_action_settings'); - var emailRowSelector = '.frm_from_to_match_row'; - var fromVal = actionBox.find('input[name$="[post_content][from]"]').val(); - var toVal = actionBox.find('input[name$="[post_content][email_to]"]').val(); - if (fromVal === toVal) { - jQuery(actionBox).find(emailRowSelector).fadeIn('slow'); - } else { - jQuery(actionBox).find(emailRowSelector).fadeOut('slow'); - } - } - function checkActiveAction(type) { - var actionTriggers = document.querySelectorAll(".frm_".concat(type, "_action")); - if (isAtLimitForActionType(type)) { - var addAlreadyUsedClass = getLimitForActionType(type) > 0; - markActionTriggersInactive(actionTriggers, addAlreadyUsedClass); - return; - } - markActionTriggersActive(actionTriggers); - } - function markActionTriggersActive(triggers) { - triggers.forEach(function (trigger) { - if (trigger.querySelector('.frm_show_upgrade')) { - // Prevent disabled action becoming active. - return; - } - trigger.classList.remove('frm_inactive_action', 'frm_already_used'); - trigger.classList.add('frm_active_action'); - }); - } - function markActionTriggersInactive(triggers, addAlreadyUsedClass) { - triggers.forEach(function (trigger) { - trigger.classList.remove('frm_active_action'); - trigger.classList.add('frm_inactive_action'); - if (addAlreadyUsedClass) { - trigger.classList.add('frm_already_used'); - } - }); - } - function isAtLimitForActionType(type) { - var atLimit = getNumberOfActionsForType(type) >= getLimitForActionType(type); - var hookName = 'frm_action_at_limit'; - var hookArgs = { - type: type - }; - atLimit = wp.hooks.applyFilters(hookName, atLimit, hookArgs); - return atLimit; - } - function getLimitForActionType(type) { - return parseInt(jQuery(".frm_".concat(type, "_action")).data('limit'), 10); - } - function getNumberOfActionsForType(type) { - return jQuery(".frm_single_".concat(type, "_settings")).length; - } - function actionLimitMessage() { - var message = frmAdminJs.only_one_action; - var limit = this.dataset.limit; - if (limit !== undefined) { - limit = parseInt(limit); - if (limit > 1) { - message = message.replace(1, limit).trim(); - } else { - message += " ".concat(frmAdminJs.edit_action_text); - } - } - infoModal(message); - } - function addFormLogicRow() { - /*jshint validthis:true */ - var id = jQuery(this).data('emailkey'); - var type = jQuery(this).closest('.frm_form_action_settings').find('.frm_action_name').val(); - var formId = document.getElementById('form_id').value; - var logicRowsContainer = document.getElementById("frm_logic_row_".concat(id)); - var logicRows = logicRowsContainer.querySelectorAll('.frm_logic_row'); - var newRowID = getNewRowId(logicRows, "frm_logic_".concat(id, "_")); - var placeholder = div({ - id: "frm_logic_".concat(id, "_").concat(newRowID), - className: 'frm_logic_row frm_hidden' - }); - logicRowsContainer.append(placeholder); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_add_form_logic_row', - email_id: id, - form_id: formId, - meta_name: newRowID, - type: type, - nonce: frmGlobal.nonce - }, - success: function success(html) { - jQuery(document.getElementById("logic_link_".concat(id))).fadeOut('slow', function () { - placeholder.insertAdjacentHTML('beforebegin', html); - placeholder.remove(); - - // Show conditional logic options after "Add Conditional Logic" is clicked. - jQuery(logicRowsContainer).parent('.frm_logic_rows').fadeIn('slow'); - }); - } - }); - return false; - } - function checkDupPost() { - /*jshint validthis:true */ - var postField = jQuery('select.frm_single_post_field'); - postField.css('border-color', ''); - var $t = this; - var v = jQuery($t).val(); - if (v === '' || v === 'checkbox') { - return false; - } - postField.each(function () { - if (jQuery(this).val() === v && this.name !== $t.name) { - this.style.borderColor = 'red'; - jQuery($t).val(''); - infoModal(frmAdminJs.field_already_used); - return false; - } - }); - } - function togglePostContent() { - /*jshint validthis:true */ - var v = jQuery(this).val(); - if ('' === v) { - jQuery('.frm_post_content_opt, select.frm_dyncontent_opt').hide().val(''); - jQuery('.frm_dyncontent_opt').hide(); - } else if ('post_content' === v) { - jQuery('.frm_post_content_opt').show(); - jQuery('.frm_dyncontent_opt').hide(); - jQuery('select.frm_dyncontent_opt').val(''); - } else { - jQuery('.frm_post_content_opt').hide().val(''); - jQuery('select.frm_dyncontent_opt, .frm_form_field.frm_dyncontent_opt').show(); - } - } - function fillDyncontent() { - /*jshint validthis:true */ - var v = jQuery(this).val(); - var $dyn = jQuery(document.getElementById('frm_dyncontent')); - if ('' === v || 'new' === v) { - $dyn.val(''); - jQuery('.frm_dyncontent_opt').show(); - } else { - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_display_get_content', - id: v, - nonce: frmGlobal.nonce - }, - success: function success(val) { - $dyn.val(val); - jQuery('.frm_dyncontent_opt').show(); - } - }); - } - } - function switchPostType() { - /*jshint validthis:true */ - // update all rows of categories/taxonomies - var curSelect; - var newSelect; - var catRows = document.getElementById('frm_posttax_rows').childNodes; - var postParentField = document.querySelector('.frm_post_parent_field'); - var postMenuOrderField = document.querySelector('.frm_post_menu_order_field'); - var postType = this.value; - - // Get new category/taxonomy options - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_replace_posttax_options', - post_type: postType, - nonce: frmGlobal.nonce - }, - success: function success(html) { - // Loop through each category row, and replace the first dropdown - for (var i = 0; i < catRows.length; i++) { - // Check if current element is a div - if (catRows[i].tagName !== 'DIV') { - continue; - } - - // Get current category select - curSelect = catRows[i].getElementsByTagName('select')[0]; - - // Set up new select - newSelect = document.createElement('select'); - newSelect.innerHTML = html; - newSelect.className = curSelect.className; - newSelect.name = curSelect.name; - - // Replace the old select with the new select - catRows[i].replaceChild(newSelect, curSelect); - } - } - }); - - // Get new post parent option. - if (postParentField) { - getActionOption(postParentField, postType, 'frm_get_post_parent_option', function (response, optName) { - // The replaced string is declared in FrmProFormActionController::ajax_get_post_menu_order_option() in the pro version. - postParentField.querySelector('.frm_post_parent_opt_wrapper').innerHTML = response.replaceAll('REPLACETHISNAME', optName); - initAutocomplete(postParentField); - }); - } - if (postMenuOrderField) { - getActionOption(postMenuOrderField, postType, 'frm_should_use_post_menu_order_option'); - } - } - function getActionOption(field, postType, action, successHandler) { - var opt = field.querySelector('.frm_autocomplete_value_input') || field.querySelector('select'); - var optName = opt.getAttribute('name'); - jQuery.ajax({ - url: ajaxurl, - method: 'POST', - data: { - action: action, - post_type: postType, - _wpnonce: frmGlobal.nonce - }, - success: function success(response) { - if ('string' !== typeof response) { - console.error(response); - return; - } - if ('0' === response) { - // This post type does not support this field. - field.classList.add('frm_hidden'); - field.value = ''; - return; - } - field.classList.remove('frm_hidden'); - if ('function' === typeof successHandler) { - successHandler(response, optName); - } - }, - error: function error(response) { - return console.error(response); - } - }); - } - function addPosttaxRow() { - /*jshint validthis:true */ - addPostRow('tax', this); - } - function addPostmetaRow() { - /*jshint validthis:true */ - addPostRow('meta', this); - } - function addPostRow(type, button) { - var name; - var id = jQuery('input[name="id"]').val(); - var settings = jQuery(button).closest('.frm_form_action_settings'); - var key = settings.data('actionkey'); - var postType = settings.find('.frm_post_type').val(); - var metaName = 0; - var postTypeRows = document.querySelectorAll(".frm_post".concat(type, "_row")); - if (postTypeRows.length) { - name = postTypeRows[postTypeRows.length - 1].id.replace("frm_post".concat(type, "_"), ''); - if (isNumeric(name)) { - metaName = 1 + parseInt(name, 10); - } else { - metaName = 1; - } - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: "frm_add_post".concat(type, "_row"), - form_id: id, - meta_name: metaName, - tax_key: metaName, - post_type: postType, - action_key: key, - nonce: frmGlobal.nonce - }, - success: function success(html) { - var cfOpts; - var optIndex; - jQuery(document.getElementById("frm_post".concat(type, "_rows"))).append(html); - jQuery(".frm_add_post".concat(type, "_row.button")).hide(); - if (type === 'meta') { - jQuery('.frm_name_value').show(); - cfOpts = document.querySelectorAll('.frm_toggle_cf_opts'); - for (optIndex = 0; optIndex < cfOpts.length - 1; ++optIndex) { - cfOpts[optIndex].style.display = 'none'; - } - } else if (type === 'tax') { - jQuery('.frm_posttax_labels').show(); - } - } - }); - } - function isNumeric(value) { - return !isNaN(parseFloat(value)) && isFinite(value); - } - function changePosttaxRow() { - /*jshint validthis:true */ - if (!jQuery(this).closest('.frm_posttax_row').find('.frm_posttax_opt_list').length) { - return; - } - jQuery(this).closest('.frm_posttax_row').find('.frm_posttax_opt_list').html('
              '); - var postType = jQuery(this).closest('.frm_form_action_settings').find('select[name$="[post_content][post_type]"]').val(); - var actionKey = jQuery(this).closest('.frm_form_action_settings').data('actionkey'); - var taxKey = jQuery(this).closest('.frm_posttax_row').attr('id').replace('frm_posttax_', ''); - var metaName = jQuery(this).val(); - var showExclude = jQuery(document.getElementById("".concat(taxKey, "_show_exclude"))).is(':checked') ? 1 : 0; - var fieldId = jQuery("select[name$=\"[post_category][".concat(taxKey, "][field_id]\"]")).val(); - var id = jQuery('input[name="id"]').val(); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_add_posttax_row', - form_id: id, - post_type: postType, - tax_key: taxKey, - action_key: actionKey, - meta_name: metaName, - field_id: fieldId, - show_exclude: showExclude, - nonce: frmGlobal.nonce - }, - success: function success(html) { - var $tax = jQuery(document.getElementById("frm_posttax_".concat(taxKey))); - $tax.replaceWith(html); - } - }); - } - function toggleCfOpts() { - /*jshint validthis:true */ - var row = jQuery(this).closest('.frm_postmeta_row'); - var cancel = row.find('.frm_cancelnew'); - var select = row.find('.frm_enternew'); - if (row.find('select.frm_cancelnew').is(':visible')) { - cancel.hide(); - select.show(); - } else { - cancel.show(); - select.hide(); - } - row.find('input.frm_enternew, select.frm_cancelnew').val(''); - return false; - } - function toggleFormOpts() { - /*jshint validthis:true */ - var changedOpt = jQuery(this); - var val = changedOpt.val(); - if (changedOpt.attr('type') === 'checkbox') { - if (this.checked === false) { - val = ''; - } - } - var toggleClass = changedOpt.data('toggleclass'); - if (val === '') { - jQuery(".".concat(toggleClass)).hide(); - } else { - jQuery(".".concat(toggleClass)).show(); - jQuery(".hide_".concat(toggleClass, "_").concat(val)).hide(); - } - } - function submitSettings() { - if (showNameYourFormModal()) { - return; - } - - /*jshint validthis:true */ - preFormSave(this); - triggerSubmit(document.querySelector('.frm_form_settings')); - } - - /* Customization Panel */ - function insertCode(e) { - /*jshint validthis:true */ - e.preventDefault(); - insertFieldCode(jQuery(this), this.getAttribute('data-code')); - return false; - } - function insertFieldCode(element, variable) { - var rich = false; - var elementId = element; - if (_typeof(element) === 'object') { - if (element.hasClass('frm_noallow')) { - return; - } - elementId = jQuery(element).closest('[data-fills]').attr('data-fills'); - if (elementId === undefined) { - elementId = element.closest('div').attr('class'); - if (elementId !== undefined) { - elementId = elementId.split(' ')[1]; - } - } - } - if (elementId === undefined) { - var active = document.activeElement; - if (active.type === 'search') { - // If the search field has focus, find the correct field. - elementId = active.id.replace('-search-input', ''); - if (elementId.match(/\d/gi) === null) { - active = jQuery(".frm-single-settings:visible .".concat(elementId)); - elementId = active.attr('id'); - } - } else { - elementId = active.id; - } - } - if (elementId) { - rich = jQuery("#wp-".concat(elementId, "-wrap.wp-editor-wrap")).length > 0; - } - var contentBox = jQuery(document.getElementById(elementId)); - if (element.attr('data-shortcode') === undefined && (!contentBox.length || contentBox.attr('data-shortcode') === undefined)) { - // this helps to exclude those that don't want shortcode-like inserted content e.g. frm-pro's summary field - var doShortcode = element.parents('ul.frm_code_list').attr('data-shortcode'); - if (doShortcode === 'undefined' || doShortcode !== 'no') { - variable = "[".concat(variable, "]"); - } - } - if (rich) { - wpActiveEditor = elementId; - } - if (!contentBox.length) { - return false; - } - if (variable === '[default-html]' || variable === '[default-plain]') { - var p = 0; - if (variable === '[default-plain]') { - p = 1; - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_get_default_html', - form_id: jQuery('input[name="id"]').val(), - plain_text: p, - nonce: frmGlobal.nonce - }, - elementId: elementId, - success: function success(msg) { - if (rich) { - var _p = document.createElement('p'); - _p.innerText = msg; - send_to_editor(_p.innerHTML); - } else { - insertContent(contentBox, msg); - } - } - }); - } else { - variable = maybeAddSanitizeUrlToShortcodeVariable(variable, element, contentBox); - if (rich) { - send_to_editor(variable); - } else { - insertContent(contentBox, variable); - } - } - return false; - } - function maybeAddSanitizeUrlToShortcodeVariable(variable, element, contentBox) { - if ('object' !== _typeof(element) || !(element instanceof jQuery) || 0 !== contentBox[0].id.indexOf('success_url_')) { - return variable; - } - element = element[0]; - if (!element.closest('#frm-insert-fields-box')) { - // Only add sanitize_url=1 to field shortcodes. - return variable; - } - if (!element.parentNode.classList.contains('frm_insert_url')) { - variable = variable.replace(']', ' sanitize_url=1]'); - } - return variable; - } - function insertContent(contentBox, variable) { - if (document.selection) { - contentBox[0].focus(); - document.selection.createRange().text = variable; - } else { - var obj = contentBox[0]; - var e = obj.selectionEnd; - variable = maybeFormatInsertedContent(contentBox, variable, obj.selectionStart, e); - obj.value = obj.value.substr(0, obj.selectionStart) + variable + obj.value.substr(obj.selectionEnd, obj.value.length); - var _s = e + variable.length; - maybeRemoveLayoutClasses(obj, variable); - obj.focus(); - obj.setSelectionRange(_s, _s); - } - triggerChange(contentBox); - } - - /** - * When a layout class is added, remove any previous layout classes to avoid conflicts. - * We only expect one layout class to exist for a given field. - * For example, if a field has frm_half and we set it to frm_third, frm_half will be removed. - * - * @since 6.11 - * - * @param {HTMLElement} obj - * @param {string} variable - * @return {void} - */ - function maybeRemoveLayoutClasses(obj, variable) { - if (!obj.classList.contains('frm_classes') || !isALayoutClass(variable)) { - return; - } - var removeClasses = obj.value.split(' ').filter(isALayoutClass); - if (removeClasses.length) { - obj.value = maybeRemoveClasses(obj.value, removeClasses, variable.trim()); - } - } - - /** - * Check if a given class is a layout class. - * - * @since 6.11 - * - * @param {string} className The class name to check. - * @return {boolean} True if the class is a layout class. - */ - function isALayoutClass(className) { - var layoutClasses = ['frm_half', 'frm_third', 'frm_two_thirds', 'frm_fourth', 'frm_three_fourths', 'frm_fifth', 'frm_sixth', 'frm2', 'frm3', 'frm4', 'frm6', 'frm8', 'frm9', 'frm10', 'frm12']; - return layoutClasses.includes(className.trim()); - } - - /** - * @since 6.11 - * - * @param {string} beforeValue The original value string. - * @param {Array} removeClasses Classes to remove. - * @param {string} variable The CSS variable name. - * @return {string} The value with specified classes removed. - */ - function maybeRemoveClasses(beforeValue, removeClasses, variable) { - var currentClasses = beforeValue.split(' ').filter(function (currentClass) { - currentClass = currentClass.trim(); - return currentClass.length && !removeClasses.includes(currentClass); - }); - if (!currentClasses.includes(variable)) { - currentClasses.push(variable); - } - return currentClasses.join(' '); - } - function maybeFormatInsertedContent(input, textToInsert, selectionStart, selectionEnd) { - var separator = input.data('sep'); - if (undefined === separator) { - return textToInsert; - } - var value = input.val(); - if (!value.trim().length) { - return textToInsert; - } - var startPattern = new RegExp("".concat(separator, "\\s*$")); - var endPattern = new RegExp("^\\s*".concat(separator)); - if (value.substr(0, selectionStart).trim().length && false === startPattern.test(value.substr(0, selectionStart))) { - textToInsert = separator + textToInsert; - } - if (value.substr(selectionEnd, value.length).trim().length && false === endPattern.test(value.substr(selectionEnd, value.length))) { - textToInsert += separator; - } - return textToInsert; - } - function resetLogicBuilder() { - /*jshint validthis:true */ - var id = document.getElementById('frm-id-condition'); - var key = document.getElementById('frm-key-condition'); - if (this.value === 'id') { - id.classList.remove('frm_hidden'); - key.classList.add('frm_hidden'); - triggerEvent(key, 'change'); - } else { - id.classList.add('frm_hidden'); - key.classList.remove('frm_hidden'); - triggerEvent(id, 'change'); - } - } - function setLogicExample() { - var idKey = document.getElementById('frm-id-key-condition-id').checked ? 'frm-id-condition' : 'frm-key-condition'; - var is = document.getElementById('frm-is-condition').value; - var text = document.getElementById('frm-text-condition').value; - var result = document.getElementById('frm-insert-condition'); - idKey = document.getElementById(idKey); - var field = idKey.options[idKey.selectedIndex].value; - var code = "if ".concat(field, " ").concat(is, "=\"").concat(text, "\"]"); - result.setAttribute('data-code', "".concat(code + frmAdminJs.conditional_text, "[/if ").concat(field)); - result.innerHTML = "[".concat(code, "[/if ").concat(field, "]"); - } - - /** - * Gets data from href or xlink:href of the given element. - * - * @param {HTMLElement} element HTML element. - * - * @return {string} The href attribute value. - */ - function getSVGHref(element) { - return element.getAttribute('href') || element.getAttributeNS('http://www.w3.org/1999/xlink', 'href'); - } - function maybeShowModal(input) { - var moreIcon; - if (input.parentNode.parentNode.classList.contains('frm_has_shortcodes')) { - hideShortcodes(); - moreIcon = getIconForInput(input); - if (moreIcon.tagName === 'use') { - moreIcon = moreIcon.firstElementChild; - if (!getSVGHref(moreIcon).includes('frm_close_icon')) { - showShortcodeBox(moreIcon, 'nofocus'); - } - } else if (!moreIcon.classList.contains('frm_close_icon')) { - showShortcodeBox(moreIcon, 'nofocus'); - } - } - } - function showShortcodes(e) { - /*jshint validthis:true */ - e.preventDefault(); - e.stopPropagation(); - showShortcodeBox(this); - } - - /** - * Handles 'change' event on the document. - * - * @since 6.16.3 - * - * @param {Event} event - * @return {void} - */ - function handleBuilderChangeEvent(event) { - maybeShowSaveAndReloadModal(event.target); - } - - /** - * Shows 'Save and Reload' modal if the target field's type is changed. - * - * @since 6.16.3 - * - * @param {HTMLElement} target - * @return {void} - */ - function maybeShowSaveAndReloadModal(target) { - var _document$querySelect5; - if (!target.id.startsWith('field_options_type_')) { - return; - } - var idParts = target.id.split('_'); - var fieldId = idParts.length && idParts[idParts.length - 1]; - if ((_document$querySelect5 = document.querySelector("#frm-single-settings-".concat(fieldId))) !== null && _document$querySelect5 !== void 0 && _document$querySelect5.classList.contains("frm-type-".concat(target.value))) { - // Do not show modal if the field type is reverted back to the original type when builder is loaded. - return; - } - showSaveAndReloadModal(); - } - - /** - * Shows 'Save and Reload' modal with the given message. - * - * @since 6.16.3 - * - * @param {string} message - * @return {void} - */ - function showSaveAndReloadModal(message) { - if (message === undefined) { - message = __('You are changing the field type. Not all field settings will appear as expected until you reload the page. Would you like to reload the page now?', 'formidable'); - } - frmDom.modal.maybeCreateModal('frmSaveAndReloadModal', { - title: __('Save and Reload?', 'formidable'), - content: getModalContent(), - footer: getModalFooter() - }); - function getModalContent() { - var modalContent = div(message); - modalContent.style.padding = 'var(--gap-md)'; - return modalContent; - } - function getModalFooter() { - var continueButton = frmDom.modal.footerButton({ - text: __('Save and Reload', 'formidable'), - buttonType: 'primary' - }); - onClickPreventDefault(continueButton, function () { - saveAndReloadFormBuilder(); - }); - var cancelButton = frmDom.modal.footerButton({ - text: __('Cancel', 'formidable'), - buttonType: 'cancel' - }); - cancelButton.classList.add('dismiss'); - return frmDom.div({ - children: [cancelButton, continueButton] - }); - } - } - function updateShortcodesPopupPosition(target) { - var moreIcon; - if (target instanceof Event) { - var useElements = document.querySelectorAll('.frm-single-settings .frm-show-box.frmsvg use'); - var openTrigger = Array.from(useElements).find(function (use) { - return use.getAttribute('href') === '#frm_close_icon'; - }); - if (openTrigger === undefined) { - return; - } - moreIcon = openTrigger.parentElement; - } else { - moreIcon = target; - } - var moreIconPosition = moreIcon.getBoundingClientRect(); - var shortCodesPopup = document.getElementById('frm_adv_info'); - var parentPos = shortCodesPopup.parentElement.getBoundingClientRect(); - shortCodesPopup.style.top = "".concat(moreIconPosition.top - parentPos.top + 32, "px"); - shortCodesPopup.style.left = "".concat(moreIconPosition.left - parentPos.left - 280, "px"); - } - function showShortcodeBox(moreIcon, shouldFocus) { - var input = getInputForIcon(moreIcon); - var box = document.getElementById('frm_adv_info'); - var classes = moreIcon.className; - if (moreIcon.tagName === 'svg') { - moreIcon = moreIcon.firstElementChild; - } - if (moreIcon.tagName === 'use') { - classes = getSVGHref(moreIcon); - } - if (classes.includes('frm_close_icon')) { - hideShortcodes(box); - } else { - updateShortcodesPopupPosition(moreIcon); - jQuery('.frm_code_list a').removeClass('frm_noallow'); - if (input.classList.contains('frm_not_email_to')) { - jQuery('#frm-insert-fields-box .frm_code_list li:not(.show_frm_not_email_to) a').addClass('frm_noallow'); - } else if (input.classList.contains('frm_not_email_subject')) { - jQuery('.frm_code_list li.hide_frm_not_email_subject a').addClass('frm_noallow'); - } - box.setAttribute('data-fills', input.id); - box.style.display = 'block'; - if (moreIcon.tagName === 'use') { - if (moreIcon.hasAttributeNS('http://www.w3.org/1999/xlink', 'href')) { - moreIcon.setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_close_icon'); - } else { - var newMoreIcon = document.createElementNS('http://www.w3.org/2000/svg', 'use'); - newMoreIcon.setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_close_icon'); - moreIcon.parentNode.replaceChild(newMoreIcon, moreIcon); - } - } else { - moreIcon.className = classes.replace('frm_more_horiz_solid_icon', 'frm_close_icon'); - } - if (shouldFocus !== 'nofocus') { - if ('none' !== input.style.display) { - input.focus(); - } else { - jQuery(tinymce.get(input.id)).trigger('focus'); - } - } - showOrHideContextualShortcodes(input); - } - } - - /** - * Returns true if a shortcode could be shown in the search result. - * - * @since 6.16.3 - * - * @param {HTMLElement} item - * @return {boolean} True if the shortcode can be shown. - */ - function checkContextualShortcode(item) { - if (frmAdminJs.contextualShortcodes.length === 0) { - return true; - } - return !isContextualShortcode(item) || canShowContextualShortcode(item); - } - - /** - * Returns true if a shortcode is contextual to fields. - * - * @since 6.16.3 - * - * @param {HTMLElement} item - * @return {boolean} True if the shortcode is contextual. - */ - function isContextualShortcode(item) { - var anchor = item.querySelector('a'); - if (!anchor) { - return false; - } - var shortcode = anchor.dataset.code; - return frmAdminJs.contextualShortcodes.address.includes(shortcode) || frmAdminJs.contextualShortcodes.body.includes(shortcode); - } - - /** - * @since 6.16.3 - * - * @param {HTMLElement} item The shortcode list item. - * @return {boolean} True if the contextual shortcode can be shown. - */ - function canShowContextualShortcode(item) { - var shortcode = item.querySelector('a').dataset.code; - var inputId = document.getElementById('frm_adv_info').dataset.fills; - var input = document.getElementById(inputId); - var contextualShortcodes = frmAdminJs.contextualShortcodes; - if (contextualShortcodes.address.includes(shortcode)) { - return input.matches(contextualShortcodes.addressSelector); - } - return input.matches(contextualShortcodes.bodySelector); - } - - /** - * @since 6.16.3 - * - * @param {HTMLElement} input - * @return {void} - */ - function showOrHideContextualShortcodes(input) { - ['address', 'body'].forEach(function (type) { - toggleContextualShortcodes(input, type); - }); - } - - /** - * @since 6.16.3 - * - * @param {HTMLElement} input - * @param {string} type - * - * @return {void} - */ - function toggleContextualShortcodes(input, type) { - var selector = frmAdminJs.contextualShortcodes["".concat(type, "Selector")]; - var contextualShortcodes = frmAdminJs.contextualShortcodes[type]; - var shouldShowShortcodes = input.matches(selector); - var _iterator = _createForOfIteratorHelper(contextualShortcodes), - _step; - try { - for (_iterator.s(); !(_step = _iterator.n()).done;) { - var _document$querySelect6; - var shortcode = _step.value; - var shortcodeLi = (_document$querySelect6 = document.querySelector("#frm-adv-info-tab .frm_code_list [data-code=\"".concat(shortcode, "\"]"))) === null || _document$querySelect6 === void 0 ? void 0 : _document$querySelect6.closest('li'); - shortcodeLi === null || shortcodeLi === void 0 || shortcodeLi.classList.toggle('frm_hidden', !shouldShowShortcodes); - } - } catch (err) { - _iterator.e(err); - } finally { - _iterator.f(); - } - } - - /** - * Returns shortcodes that are contextual to the current input field. - * - * @since 6.16.3 - * - * @return {Array} Array of contextual shortcode data. - */ - function getContextualShortcodes() { - var _document$getElementB4; - var contextualShortcodes = (_document$getElementB4 = document.getElementById('frm_adv_info')) === null || _document$getElementB4 === void 0 ? void 0 : _document$getElementB4.dataset.contextualShortcodes; - if (!contextualShortcodes) { - return []; - } - contextualShortcodes = JSON.parse(contextualShortcodes); - contextualShortcodes.addressSelector = '[id^=email_to], [id^=from_], [id^=cc], [id^=bcc]'; - contextualShortcodes.bodySelector = '[id^=email_message_]'; - return contextualShortcodes; - } - function fieldUpdated() { - if (!fieldsUpdated) { - fieldsUpdated = 1; - window.addEventListener('beforeunload', confirmExit); - } - } - function buildSubmittedNoAjax() { - // set fieldsUpdated to 0 to avoid the unsaved changes pop up - fieldsUpdated = 0; - } - function settingsSubmitted() { - // set fieldsUpdated to 0 to avoid the unsaved changes pop up - fieldsUpdated = 0; - } - function resetFieldsUpdated() { - fieldsUpdated = 0; - } - function reloadIfAddonActivatedAjaxSubmitOnly() { - var submitButton = document.getElementById('frm_submit_side_top'); - if (submitButton.hasAttribute('data-new-addon-installed') && 'true' === submitButton.getAttribute('data-new-addon-installed')) { - submitButton.removeAttribute('data-new-addon-installed'); - window.location.reload(); - } - } - function saveAndReloadFormBuilder() { - var submitButton = document.getElementById('frm_submit_side_top'); - if (submitButton.classList.contains('frm_submit_ajax')) { - submitButton.setAttribute('data-new-addon-installed', true); - } - submitButton.click(); - } - function confirmExit(event) { - if (fieldsUpdated) { - event.preventDefault(); - event.returnValue = ''; - } - } - function offsetModalY($modal, amount) { - var position = { - my: 'top', - at: "top+".concat(amount), - of: window - }; - $modal.dialog('option', 'position', position); - } - - /** - * Get the input box for the selected icon or calculation field. - * - * @param {Element} moreIcon The icon element - * @return {Element} The associated input or textarea - */ - function getInputForIcon(moreIcon) { - if (moreIcon.classList.contains('frm-input-icon')) { - return moreIcon.previousElementSibling; - } - - // For regular fields - var input = moreIcon.nextElementSibling; - while (input && (input.tagName !== 'INPUT' && input.tagName !== 'TEXTAREA' || input.classList.contains('frm-token-input-field'))) { - input = getInputForIcon(input); - } - - // For calculation fields - if (!input) { - var _moreIcon$closest; - input = (_moreIcon$closest = moreIcon.closest('.frm-field-formula')) === null || _moreIcon$closest === void 0 ? void 0 : _moreIcon$closest.querySelector('.frm-calc-field'); - } - return input; - } - - /** - * Get the ... icon for the selected input box. - * @param {HTMLElement} input The input element. - */ - function getIconForInput(input) { - var _input$nextElementSib; - if ((_input$nextElementSib = input.nextElementSibling) !== null && _input$nextElementSib !== void 0 && _input$nextElementSib.classList.contains('frm-input-icon')) { - return input.nextElementSibling; - } - var moreIcon = input.previousElementSibling; - while (moreIcon !== null && moreIcon.tagName !== 'I' && moreIcon.tagName !== 'svg') { - moreIcon = getIconForInput(moreIcon); - } - return moreIcon; - } - function hideShortcodes(box) { - if (box === undefined) { - box = document.getElementById('frm_adv_info'); - if (!box) { - return; - } - } - if (document.getElementById('frm_dyncontent') !== null) { - // Don't run when in the sidebar. - return; - } - box.style.display = 'none'; - var closeIcons = document.querySelectorAll('.frm-show-box.frm_close_icon'); - for (var iconIndex = 0; iconIndex < closeIcons.length; iconIndex++) { - closeIcons[iconIndex].classList.remove('frm_close_icon'); - closeIcons[iconIndex].classList.add('frm_more_horiz_solid_icon'); - } - var closeSvg = document.querySelectorAll('.frm_has_shortcodes use'); - for (var svgIndex = 0; svgIndex < closeSvg.length; svgIndex++) { - if (getSVGHref(closeSvg[svgIndex]) === '#frm_close_icon') { - if (closeSvg[svgIndex].closest('.frm_remove_field')) { - // Don't change the icon for the email fields remove button. - continue; - } - closeSvg[svgIndex].setAttributeNS('http://www.w3.org/1999/xlink', 'href', '#frm_more_horiz_solid_icon'); - } - } - } - function toggleAllowedHTML(input) { - var id = input.id; - if (id === undefined || id.includes('-search-input')) { - return; - } - jQuery('#frm-adv-info-tab').attr('data-fills', id.trim()); - if (input.classList.contains('field_custom_html')) { - id = 'field_custom_html'; - } - var htmlFieldIds = ['after_html', 'before_html', 'submit_html', 'field_custom_html']; - if (jQuery.inArray(id, htmlFieldIds) >= 0) { - jQuery(".frm_code_list li:not(.show_".concat(id, ")")).addClass('frm_hidden'); - jQuery(".frm_code_list li.show_".concat(id)).removeClass('frm_hidden'); - } - } - function toggleKeyID(switchTo, e) { - e.stopPropagation(); - jQuery('.frm_code_list .frmids, .frm_code_list .frmkeys').addClass('frm_hidden'); - jQuery(".frm_code_list .".concat(switchTo)).removeClass('frm_hidden'); - jQuery('.frmids, .frmkeys').removeClass('current'); - jQuery(".".concat(switchTo)).addClass('current'); - } - function onActionLoaded(event) { - var settings = event.target.closest('.frm_form_action_settings'); - if (settings && (settings.classList.contains('frm_single_email_settings') || settings.classList.contains('frm_single_on_submit_settings'))) { - initWysiwygOnActionLoaded(settings); - } - } - function initWysiwygOnActionLoaded(settings) { - settings.querySelectorAll('.wp-editor-area').forEach(function (wysiwyg) { - frmDom.wysiwyg.init(wysiwyg, { - height: 160, - addFocusEvents: true - }); - }); - } - - /* Global settings page */ - function loadSettingsTab(anchor) { - var holder = anchor.replace('#', ''); - var holderContainer = jQuery(".frm_".concat(holder, "_ajax")); - if (holderContainer.length) { - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: 'frm_settings_tab', - tab: holder.replace('_settings', ''), - nonce: frmGlobal.nonce - }, - success: function success(html) { - holderContainer.replaceWith(html); - } - }); - } - } - function uninstallNow() { - /*jshint validthis:true */ - if (confirmLinkClick(this) === true) { - jQuery('.frm_uninstall .frm-wait').css('visibility', 'visible'); - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: "action=frm_uninstall&nonce=".concat(frmGlobal.nonce), - success: function success(msg) { - jQuery('.frm_uninstall').fadeOut('slow'); - window.location = msg; - } - }); - } - return false; - } - function saveAddonLicense() { - /*jshint validthis:true */ - var button = jQuery(this); - var buttonName = this.name; - var pluginSlug = this.getAttribute('data-plugin'); - var action = buttonName.replace("edd_".concat(pluginSlug, "_license_"), ''); - var license = document.getElementById("edd_".concat(pluginSlug, "_license_key")).value; - button.get(0).disabled = true; - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - dataType: 'json', - data: { - action: "frm_addon_".concat(action), - license: license, - plugin: pluginSlug, - nonce: frmGlobal.nonce - }, - success: function success(msg) { - button.get(0).disabled = false; - var thisRow = button.closest('.edd_frm_license_row'); - if (action === 'deactivate') { - license = ''; - document.getElementById("edd_".concat(pluginSlug, "_license_key")).value = ''; - } - thisRow.find('.edd_frm_license').html(license); - var eddWrapper = button.get(0).closest('.frm_form_field'); - var actionIsSuccess = msg.success === true; - eddWrapper.querySelector('.frm_icon_font.frm_action_success').classList.toggle('frm_hidden', !actionIsSuccess || action === 'deactivate'); - eddWrapper.querySelector('.frm_icon_font.frm_action_error').classList.toggle('frm_hidden', actionIsSuccess); - var messageBox = thisRow.find('.frm_license_msg'); - messageBox.html(msg.message); - if (msg.message !== '') { - setTimeout(function () { - messageBox.html(''); - thisRow.find('.frm_icon_font').addClass('frm_hidden'); - if (actionIsSuccess) { - var actionIsActivate = action === 'activate'; - thisRow.get(0).querySelector('.edd_frm_unauthorized').classList.toggle('frm_hidden', actionIsActivate); - thisRow.get(0).querySelector('.edd_frm_authorized').classList.toggle('frm_hidden', !actionIsActivate); - } - }, 2000); - } - } - }); - } - - /* Import/Export page */ - - function startFormMigration(event) { - event.preventDefault(); - var checkedBoxes = jQuery(event.target).find('input:checked'); - if (!checkedBoxes.length) { - return; - } - var ids = []; - checkedBoxes.each(function (i) { - ids[i] = this.value; - }); - - // Begin the import process. - importForms(ids, event.target); - } - - /** - * Begins the process of importing the forms. - * @param {Array} forms The form IDs to import. - * @param {HTMLElement} targetForm The form element that triggered the import. - */ - function importForms(forms, targetForm) { - // Hide the form select section. - var $form = jQuery(targetForm); - var $processSettings = $form.next('.frm-importer-process'); - - // Display total number of forms we have to import. - $processSettings.find('.form-total').text(forms.length); - $processSettings.find('.form-current').text('1'); - $form.hide(); - - // Show processing status. - // '.process-completed' might have been shown earlier during a previous import, so hide now. - $processSettings.find('.process-completed').hide(); - $processSettings.show(); - - // Create global import queue. - s.importQueue = forms; - s.imported = 0; - - // Import the first form in the queue. - importForm($processSettings); - } - - /** - * Imports a single form from the import queue. - * @param {jQuery} $processSettings The jQuery wrapped process settings element. - */ - function importForm($processSettings) { - var formID = s.importQueue[0]; - var provider = jQuery('#welcome-panel').find('input[name="slug"]').val(); - var data = { - action: "frm_import_".concat(provider), - form_id: formID, - nonce: frmGlobal.nonce - }; - - // Trigger AJAX import for this form. - jQuery.post(ajaxurl, data, function (res) { - if (res.success) { - var statusUpdate; - if (res.data.error) { - statusUpdate = "

              ".concat(res.data.name, ": ").concat(res.data.msg, "

              "); - } else { - statusUpdate = "

              Imported ").concat(res.data.name, "

              "); - } - $processSettings.find('.status').prepend(statusUpdate); - $processSettings.find('.status').show(); - - // Remove this form ID from the queue. - s.importQueue = jQuery.grep(s.importQueue, function (value) { - return value != formID; - }); - s.imported++; - if (s.importQueue.length === 0) { - $processSettings.find('.process-count').hide(); - $processSettings.find('.forms-completed').text(s.imported); - $processSettings.find('.process-completed').show(); - } else { - // Import next form in the queue. - $processSettings.find('.form-current').text(s.imported + 1); - importForm($processSettings); - } - } - }); - } - function validateExport(e) { - /*jshint validthis:true */ - e.preventDefault(); - var s = false; - var $exportForms = jQuery('input[name="frm_export_forms[]"]'); - if (!jQuery('input[name="frm_export_forms[]"]:checked').val()) { - $exportForms.closest('.frm-table-box').addClass('frm_blank_field'); - s = 'stop'; - } - var $exportType = jQuery('input[name="type[]"]'); - if (!jQuery('input[name="type[]"]:checked').val() && $exportType.attr('type') === 'checkbox') { - $exportType.closest('p').addClass('frm_blank_field'); - s = 'stop'; - } - if (s === 'stop') { - return false; - } - e.stopPropagation(); - this.submit(); - } - function removeExportError() { - /*jshint validthis:true */ - var t = jQuery(this).closest('.frm_blank_field'); - if (t === undefined) { - return; - } - var $thisName = this.name; - if ($thisName === 'type[]' && jQuery('input[name="type[]"]:checked').val()) { - t.removeClass('frm_blank_field'); - } else if ($thisName === 'frm_export_forms[]' && jQuery(this).val()) { - t.removeClass('frm_blank_field'); - } - } - function checkCSVExtension() { - /*jshint validthis:true */ - var f = jQuery(this).val(); - var re = /\.csv$/i; - if (f.match(re) !== null) { - jQuery('.show_csv').fadeIn(); - } else { - jQuery('.show_csv').fadeOut(); - } - } - function getExportOption() { - var exportFormatSelect = document.querySelector('select[name="format"]'); - if (exportFormatSelect) { - return exportFormatSelect.value; - } - return ''; - } - function exportTypeChanged(event) { - var value = event.target.value; - showOrHideRepeaters(value); - checkExportTypes.call(event.target); - checkSelectedAllFormsCheckbox(value); - } - function checkSelectedAllFormsCheckbox(exportType) { - var selectAllCheckbox = document.getElementById('frm-export-select-all'); - if (exportType === 'csv') { - selectAllCheckbox.checked = false; - selectAllCheckbox.disabled = true; - } else { - selectAllCheckbox.disabled = false; - } - } - function checkExportTypes() { - /*jshint validthis:true */ - var $dropdown = jQuery(this); - var $selected = $dropdown.find(':selected'); - var s = $selected.data('support'); - var multiple = s.indexOf('|'); - jQuery('input[name="type[]"]').each(function () { - this.checked = false; - if (s.includes(this.value)) { - this.disabled = false; - if (multiple === -1) { - this.checked = true; - } - } else { - this.disabled = true; - } - }); - if ($dropdown.val() === 'csv') { - jQuery('.csv_opts').show(); - jQuery('.xml_opts').hide(); - } else { - jQuery('.csv_opts').hide(); - jQuery('.xml_opts').show(); - } - var c = $selected.data('count'); - var exportField = jQuery('input[name="frm_export_forms[]"]'); - if (c === 'single') { - exportField.prop('multiple', false); - exportField.prop('checked', false); - } else { - exportField.prop('multiple', true); - exportField.prop('disabled', false); - } - $dropdown.trigger('change'); - } - function showOrHideRepeaters(exportOption) { - if (exportOption === '') { - return; - } - var repeaters = document.querySelectorAll('.frm-is-repeater'); - if (!repeaters.length) { - return; - } - if (exportOption === 'csv') { - repeaters.forEach(function (form) { - form.classList.remove('frm_hidden'); - }); - } else { - repeaters.forEach(function (form) { - form.classList.add('frm_hidden'); - }); - } - searchContent.call(document.querySelector('.frm-auto-search')); - } - function preventMultipleExport() { - var type = jQuery('select[name=format]'); - var selected = type.find(':selected'); - var count = selected.data('count'); - var exportField = jQuery('input[name="frm_export_forms[]"]'); - if (count === 'single') { - // Disable all other fields to prevent multiple selections. - if (this.checked) { - exportField.prop('disabled', true); - this.removeAttribute('disabled'); - } else { - exportField.prop('disabled', false); - } - } else { - exportField.prop('disabled', false); - } - } - function initiateMultiselect() { - jQuery('.frm_multiselect').hide().each(frmDom.bootstrap.multiselect.init); - } - - /* Addons page */ - function installMultipleAddons(e) { - e.preventDefault(); - toggleAddonState(this, 'frm_multiple_addons'); - } - function activateAddon(e) { - e.preventDefault(); - toggleAddonState(this, 'frm_activate_addon'); - } - function installAddon(e) { - e.preventDefault(); - toggleAddonState(this, 'frm_install_addon'); - } - function toggleAddonState(clicked, action) { - var addonState = __webpack_require__(/*! ./addon-state */ "./js/src/admin/addon-state.js"); - addonState.toggleAddonState(clicked, action); - } - - /* Templates */ - function showActiveCampaignForm() { - loadApiEmailForm(); - } - function handleApiFormError(inputId, errorId, type, message) { - var $error = jQuery(errorId); - $error.removeClass('frm_hidden').attr('frm-error', type); - if (message !== undefined) { - $error.find("span[frm-error=\"".concat(type, "\"]")).text(message); - } - jQuery(inputId).one('keyup', function () { - $error.addClass('frm_hidden'); - }); - } - function handleEmailAddressError(type) { - handleApiFormError('#frm_leave_email', '#frm_leave_email_error', type); - } - function loadApiEmailForm() { - var formContainer = document.getElementById('frmapi-email-form'); - jQuery.ajax({ - dataType: 'json', - url: formContainer.getAttribute('data-url'), - success: function success(json) { - var form = json.renderedHtml; - form = form.replace(/]*(formidableforms.css|action=frmpro_css)[^>]*>/gi, ''); - formContainer.innerHTML = form; - } - }); - } - function initAutocomplete(container) { - frmDom.autocomplete.initSelectionAutocomplete(container); - } - function nextInstallStep(thisStep) { - thisStep.classList.add('frm_grey'); - thisStep.nextElementSibling.classList.remove('frm_grey'); - } - function installTemplateFieldset(e) { - /*jshint validthis:true */ - var fieldset = this.parentNode.parentNode; - var action = fieldset.elements.type.value; - var button = this; - e.preventDefault(); - button.classList.add('frm_loading_button'); - installNewForm(fieldset, action, button); - } - function installTemplate(e) { - /*jshint validthis:true */ - var action = this.elements.type.value; - var button = this.querySelector('button'); - e.preventDefault(); - button.classList.add('frm_loading_button'); - installNewForm(this, action, button); - } - function installNewForm(form, action, button) { - var formData = formToData(form); - var formName = formData.template_name; - var formDesc = formData.template_desc; - var link = form.elements.link.value; - var data = { - action: action, - xml: link, - name: formName, - desc: formDesc, - form: JSON.stringify(formData), - nonce: frmGlobal.nonce - }; - var hookName = 'frm_before_install_new_form'; - var filterArgs = { - formData: formData - }; - data = wp.hooks.applyFilters(hookName, data, filterArgs); - postAjax(data, function (response) { - if (response.redirect !== undefined) { - var redirect = response.redirect; - if (form.elements.redirect === undefined) { - window.location = redirect; - } else { - var href = document.getElementById('frm-redirect-link'); - if (link !== undefined && href) { - // Show the next installation step. - href.setAttribute('href', redirect); - href.classList.remove('frm_grey', 'disabled'); - nextInstallStep(form.parentNode.parentNode); - button.classList.add('frm_grey', 'disabled'); - } - } - } else { - jQuery('.spinner').css('visibility', 'hidden'); - - // Show response.message - if ('string' === typeof response.message) { - showInstallFormErrorModal(response.message); - } - } - button.classList.remove('frm_loading_button'); - }); - } - function showInstallFormErrorModal(message) { - var modalContent = div(message); - modalContent.style.padding = '20px 40px'; - var modal = frmDom.modal.maybeCreateModal('frmInstallFormErrorModal', { - title: __('Unable to install template', 'formidable'), - content: modalContent - }); - modal.classList.add('frm_common_modal'); - } - function handleCaptchaTypeChange(e) { - var thresholdContainer = document.getElementById('frm_captcha_threshold_container'); - if (thresholdContainer) { - thresholdContainer.classList.toggle('frm_hidden', 'v3' !== e.target.value); - } - } - function trashTemplate(e) { - /*jshint validthis:true */ - var id = this.getAttribute('data-id'); - e.preventDefault(); - var data = { - action: 'frm_forms_trash', - id: id, - nonce: frmGlobal.nonce - }; - postAjax(data, function () { - var card = document.getElementById("frm-template-custom-".concat(id)); - fadeOut(card, function () { - card.remove(); - }); - }); - } - function searchContent() { - /*jshint validthis:true */ - var i; - var regEx = false; - var searchText = this.value.toLowerCase(); - var toSearch = this.getAttribute('data-tosearch'); - var items = document.getElementsByClassName(toSearch); - if (this.tagName === 'SELECT') { - searchText = selectedOptions(this); - searchText = searchText.join('|').toLowerCase(); - regEx = true; - } - if (toSearch === 'frm-action' && searchText !== '') { - var addons = document.getElementById('frm_email_addon_menu').classList; - addons.remove('frm-all-actions'); - addons.add('frm-limited-actions'); - } - for (i = 0; i < items.length; i++) { - var innerText = items[i].innerText.toLowerCase(); - var itemCanBeShown = !(getExportOption() === 'xml' && items[i].classList.contains('frm-is-repeater')); - if (searchText === '') { - if (itemCanBeShown && checkContextualShortcode(items[i])) { - items[i].classList.remove('frm_hidden'); - } - items[i].classList.remove('frm-search-result'); - } else if (regEx && new RegExp(searchText).test(innerText) || innerText.includes(searchText) || textMatchesPlural(innerText, searchText)) { - if (itemCanBeShown && checkContextualShortcode(items[i])) { - items[i].classList.remove('frm_hidden'); - } - items[i].classList.add('frm-search-result'); - } else { - items[i].classList.add('frm_hidden'); - items[i].classList.remove('frm-search-result'); - } - } - - // Updates the visibility of category headings based on search results. - updateCatHeadingVisibility(); - jQuery(this).trigger('frmAfterSearch'); - } - - /** - * Allow a search for "signatures" to still match "signature" for example when searching fields. - * - * @since 6.15 - * - * @param {string} text The text in the element we are checking for a match. - * @param {string} searchText The text value that is being searched. - * @return {boolean} True if the text matches when pluralized. - */ - function textMatchesPlural(text, searchText) { - if (searchText === 's') { - // Don't match everything when just "s" is searched. - return false; - } - if (text[text.length - 1] === 's') { - // Do not match something with double s if the text already ends in s. - return false; - } - return "".concat(text, "s").includes(searchText); - } - - /** - * Updates the visibility of category headings based on search results. - * If all associated fields are hidden (indicating no search matches), - * the heading is hidden. - * - * @since 6.4.1 - */ - function updateCatHeadingVisibility() { - var insertFieldsElement = document.querySelector('#frm-insert-fields'); - if (!insertFieldsElement) { - return; - } - var headingElements = insertFieldsElement.querySelectorAll(':scope > .frm-with-line'); - headingElements.forEach(function (heading) { - var fieldsListElement = heading.nextElementSibling; - if (!fieldsListElement) { - return; - } - var listItemElements = fieldsListElement.querySelectorAll(':scope > li.frmbutton'); - var allHidden = Array.from(listItemElements).every(function (li) { - return li.classList.contains('frm_hidden'); - }); - - // Add or remove class based on `allHidden` condition - heading.classList.toggle('frm_hidden', allHidden); - }); - } - function stopPropagation(e) { - e.stopPropagation(); - } - - /* Helpers */ - - function selectedOptions(select) { - var opt; - var result = []; - var options = select === null || select === void 0 ? void 0 : select.options; - for (var i = 0, iLen = options === null || options === void 0 ? void 0 : options.length; i < iLen; i++) { - opt = options[i]; - if (opt.selected) { - result.push(opt.value); - } - } - return result; - } - function triggerEvent(element, event) { - var evt = document.createEvent('HTMLEvents'); - evt.initEvent(event, false, true); - element.dispatchEvent(evt); - } - function postAjax(data, success) { - var response; - var xmlHttp = new XMLHttpRequest(); - var params = typeof data === 'string' ? data : Object.keys(data).map(function (k) { - return "".concat(encodeURIComponent(k), "=").concat(encodeURIComponent(data[k])); - }).join('&'); - xmlHttp.open('post', ajaxurl, true); - xmlHttp.onreadystatechange = function () { - if (xmlHttp.readyState > 3 && xmlHttp.status == 200) { - response = xmlHttp.responseText; - try { - response = JSON.parse(response); - } catch (e) { - // The response may not be JSON, so just return it. - } - success(response); - } - }; - xmlHttp.setRequestHeader('X-Requested-With', 'XMLHttpRequest'); - xmlHttp.setRequestHeader('Content-type', 'application/x-www-form-urlencoded'); - xmlHttp.send(params); - return xmlHttp; - } - function fadeOut(element, success) { - element.classList.add('frm-fade'); - setTimeout(success, 1000); - } - function invisible(classes) { - jQuery(classes).css('visibility', 'hidden'); - } - function visible(classes) { - jQuery(classes).css('visibility', 'visible'); - } - function initModal(id, width) { - var upgradePopup = __webpack_require__(/*! ./upgrade-popup */ "./js/src/admin/upgrade-popup.js"); - return upgradePopup.initModal(id, width); - } - function toggle(cname, id) { - if (id === '#') { - var cont = document.getElementById(cname); - var hidden = cont.style.display; - if (hidden === 'none') { - cont.style.display = 'block'; - } else { - cont.style.display = 'none'; - } - } else { - var vis = cname.is(':visible'); - if (vis) { - cname.hide(); - } else { - cname.show(); - } - } - } - function removeWPUnload() { - window.onbeforeunload = null; - var w = jQuery(window); - w.off('beforeunload.widgets'); - w.off('beforeunload.edit-post'); - } - function addMultiselectLabelListener() { - var clickListener = function clickListener(e) { - if ('LABEL' !== e.target.nodeName) { - return; - } - var labelFor = e.target.getAttribute('for'); - if (!labelFor) { - return; - } - var input = document.getElementById(labelFor); - if (!input || !input.nextElementSibling) { - return; - } - var buttonToggle = input.nextElementSibling.querySelector('button.dropdown-toggle.multiselect'); - if (!buttonToggle) { - return; - } - var triggerMultiselectClick = function triggerMultiselectClick() { - return buttonToggle.click(); - }; - setTimeout(triggerMultiselectClick, 0); - }; - document.addEventListener('click', clickListener); - } - function maybeChangeEmbedFormMsg() { - var fieldId = jQuery(this).closest('.frm-single-settings').data('fid'); - var fieldItem = document.getElementById("frm_field_id_".concat(fieldId)); - if (!fieldItem || 'form' !== fieldItem.dataset.type) { - return; - } - fieldItem = jQuery(fieldItem); - if (this.options[this.selectedIndex].value) { - fieldItem.find('.frm-not-set')[0].classList.add('frm_hidden'); - var embedMsg = fieldItem.find('.frm-embed-message'); - embedMsg.html(embedMsg.data('embedmsg') + this.options[this.selectedIndex].text); - fieldItem.find('.frm-embed-field-placeholder')[0].classList.remove('frm_hidden'); - } else { - fieldItem.find('.frm-not-set')[0].classList.remove('frm_hidden'); - fieldItem.find('.frm-embed-field-placeholder')[0].classList.add('frm_hidden'); - } - } - function toggleProductType() { - var settings = jQuery(this).closest('.frm-single-settings'); - var container = settings.find('.frmjs_product_choices'); - var heading = settings.find('.frm_prod_options_heading'); - var currentVal = this.options[this.selectedIndex].value; - container.removeClass('frm_prod_type_single frm_prod_type_user_def'); - heading.removeClass('frm_prod_user_def'); - if ('single' === currentVal) { - container.addClass('frm_prod_type_single'); - } else if ('user_def' === currentVal) { - container.addClass('frm_prod_type_user_def'); - heading.addClass('frm_prod_user_def'); - } - } - - /** - * @param {number | string} fieldId - * @return {boolean} True if the field is a product field. - */ - function isProductField(fieldId) { - var field = document.getElementById("frm_field_id_".concat(fieldId)); - if (!field) { - return false; - } - return 'product' === field.getAttribute('data-type'); - } - - /** - * Serialize form data with vanilla JS. - * @param {HTMLElement} form The form element to serialize. - */ - function formToData(form) { - var subKey; - var i; - var object = {}; - var formData = form.elements; - for (i = 0; i < formData.length; i++) { - var input = formData[i]; - var key = input.name; - var value = input.value; - var names = key.match(/(.*)\[(.*)\]/); - if ((input.type === 'radio' || input.type === 'checkbox') && !input.checked) { - continue; - } - if (names !== null) { - key = names[1]; - subKey = names[2]; - if (!Reflect.has(object, key)) { - object[key] = {}; - } - object[key][subKey] = value; - continue; - } - - // Reflect.has in favor of: object.hasOwnProperty(key) - if (!Reflect.has(object, key)) { - object[key] = value; - continue; - } - if (!Array.isArray(object[key])) { - object[key] = [object[key]]; - } - object[key].push(value); - } - return object; - } - - /** - * Show, hide, and sort subfields of Name field on form builder. - * - * @since 4.11 - */ - function handleNameFieldOnFormBuilder() { - /** - * Gets subfield element from cache. - * - * @param {string} fieldId Field ID. - * @param {string} key Cache key. - * @return {HTMLElement|undefined} Return the element from cache or undefined if not found. - */ - var getSubFieldElFromCache = function getSubFieldElFromCache(fieldId, key) { - window.frmCachedSubFields = window.frmCachedSubFields || {}; - window.frmCachedSubFields[fieldId] = window.frmCachedSubFields[fieldId] || {}; - return window.frmCachedSubFields[fieldId][key]; - }; - - /** - * Sets subfield element to cache. - * - * @param {string} fieldId Field ID. - * @param {string} key Cache key. - * @param {HTMLElement} el Element. - */ - var setSubFieldElToCache = function setSubFieldElToCache(fieldId, key, el) { - window.frmCachedSubFields = window.frmCachedSubFields || {}; - window.frmCachedSubFields[fieldId] = window.frmCachedSubFields[fieldId] || {}; - window.frmCachedSubFields[fieldId][key] = el; - }; - - /** - * Gets column class from the number of columns. - * - * @param {number} colCount Number of columns. - * @return {string} The column CSS class name. - */ - var getColClass = function getColClass(colCount) { - return "frm".concat(parseInt(12 / colCount)); - }; - var colClasses = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12].map(function (num) { - return "frm".concat(num); - }); - var allSubFieldNames = ['first', 'middle', 'last']; - - /** - * Handles name layout change. - * - * @param {Event} event Event object. - */ - var onChangeLayout = function onChangeLayout(event) { - var value = event.target.value; - var subFieldNames = value.split('_'); - var fieldId = event.target.dataset.fieldId; - - /* - * Live update form on the form builder. - */ - var container = document.querySelector("#field_".concat(fieldId, "_inner_container .frm_combo_inputs_container")); - var newColClass = getColClass(subFieldNames.length); - - // Set all sub field elements to cache and hide all of them first. - allSubFieldNames.forEach(function (name) { - var subFieldEl = container.querySelector("[data-sub-field-name=\"".concat(name, "\"]")); - if (subFieldEl) { - var _subFieldEl$classList; - subFieldEl.classList.add('frm_hidden'); - (_subFieldEl$classList = subFieldEl.classList).remove.apply(_subFieldEl$classList, _toConsumableArray(colClasses)); - setSubFieldElToCache(fieldId, name, subFieldEl); - } - }); - subFieldNames.forEach(function (subFieldName) { - var subFieldEl = getSubFieldElFromCache(fieldId, subFieldName); - if (!subFieldEl) { - return; - } - subFieldEl.classList.remove('frm_hidden'); - subFieldEl.classList.add(newColClass); - container.append(subFieldEl); - }); - - /* - * Live update subfield options. - */ - // Hide all subfield options. - allSubFieldNames.forEach(function (name) { - var optionsEl = document.querySelector(".frm_sub_field_options-".concat(name, "[data-field-id=\"").concat(fieldId, "\"]")); - if (optionsEl) { - optionsEl.classList.add('frm_hidden'); - setSubFieldElToCache(fieldId, "".concat(name, "_options"), optionsEl); - } - }); - subFieldNames.forEach(function (subFieldName) { - var optionsEl = getSubFieldElFromCache(fieldId, "".concat(subFieldName, "_options")); - if (!optionsEl) { - return; - } - optionsEl.classList.remove('frm_hidden'); - }); - }; - var dropdownSelector = '.frm_name_layout_dropdown'; - document.addEventListener('change', function (event) { - if (event.target.matches(dropdownSelector)) { - onChangeLayout(event); - } - }, false); - } - function debounce(func) { - var wait = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 100; - return frmDom.util.debounce(func, wait); - } - function addSaveAndDragIconsToOption(fieldId, liObject) { - var li; - var useTag; - var useTagHref; - var hasDragIcon = false; - var hasSaveIcon = false; - if (liObject.newOption) { - var parser = new DOMParser(); - li = parser.parseFromString(liObject.newOption, 'text/html').body.childNodes[0]; - } else { - li = liObject; - } - var liIcons = li.querySelectorAll('svg'); - liIcons.forEach(function (svg) { - useTag = svg.getElementsByTagNameNS('http://www.w3.org/2000/svg', 'use')[0]; - if (!useTag) { - return; - } - useTagHref = getSVGHref(useTag); - if (useTagHref === '#frm_drag_icon') { - hasDragIcon = true; - } - if (useTagHref === '#frm_save_icon') { - hasSaveIcon = true; - } - }); - if (!hasDragIcon) { - li.prepend(icons.drag.cloneNode(true)); - } - if (li.querySelector("[id^=field_key_".concat(fieldId, "-]")) && !hasSaveIcon) { - li.querySelector("[id^=field_key_".concat(fieldId, "-]")).after(icons.save.cloneNode(true)); - } - if (liObject.newOption) { - liObject.newOption = li; - } - } - function maybeAddSaveAndDragIcons(fieldId) { - var fieldOptions = document.querySelectorAll("[id^=frm_delete_field_".concat(fieldId, "-]")); - // return if there are no options. - if (fieldOptions.length < 2) { - return; - } - var options = _toConsumableArray(fieldOptions).slice(1); - options.forEach(function (li, _key) { - if (li.classList.contains('frm_other_option')) { - return; - } - addSaveAndDragIconsToOption(fieldId, li); - }); - } - - /** - * Enforce the maximum number of entries list columns dynamically. - * - * @since 6.24 - * - * @return {void} - */ - function maybeInitEntriesListPage() { - if (!document.body.classList.contains('frm-admin-page-entries')) { - return; - } - var screenOptionsWrapper = document.getElementById('screen-options-wrap'); - if (!screenOptionsWrapper) { - return; - } - var maxSelectionsNote = div({ - className: 'frm_warning_style', - text: __('Only 10 columns can be selected at a time.', 'formidable') - }); - maxSelectionsNote.style.margin = 0; - var legend = screenOptionsWrapper.querySelector('legend'); - legend.parentNode.insertBefore(maxSelectionsNote, legend.nextElementSibling); - var checkboxes = Array.from(screenOptionsWrapper.querySelectorAll('input[type="checkbox"]')); - var maximumColumns = 10; - var getSelectedCount = function getSelectedCount() { - return checkboxes.reduce(function (count, checkbox) { - return checkbox.checked ? count + 1 : count; - }, 0); - }; - var disableCheckboxesIfAtMax = function disableCheckboxesIfAtMax() { - if (getSelectedCount() >= maximumColumns) { - maxSelectionsNote.classList.remove('frm_hidden'); - checkboxes.forEach(function (checkbox) { - if (!checkbox.checked) { - checkbox.parentNode.classList.add('frm_noallow'); - checkbox.disabled = true; - } - }); - } else { - maxSelectionsNote.classList.add('frm_hidden'); - } - }; - var addCheckboxListeners = function addCheckboxListeners() { - checkboxes.forEach(function (checkbox) { - checkbox.addEventListener('change', function (event) { - if (event.target.checked) { - disableCheckboxesIfAtMax(); - } else { - maxSelectionsNote.classList.add('frm_hidden'); - - // Enable all checkboxes when a checkbox is unchecked. - checkboxes.forEach(function (checkbox) { - checkbox.parentNode.classList.remove('frm_noallow'); - checkbox.disabled = false; - }); - } - }); - }); - }; - disableCheckboxesIfAtMax(); - addCheckboxListeners(); - } - function initOnSubmitAction() { - var onChangeType = function onChangeType(event) { - if (!event.target.checked) { - return; - } - var actionEl = event.target.closest('.frm_form_action_settings'); - actionEl.querySelectorAll('.frm_on_submit_dependent_setting:not(.frm_hidden)').forEach(function (el) { - el.classList.add('frm_hidden'); - }); - var activeEls = actionEl.querySelectorAll(".frm_on_submit_dependent_setting[data-show-if-".concat(event.target.value, "]")); - activeEls.forEach(function (activeEl) { - activeEl.classList.remove('frm_hidden'); - }); - actionEl.setAttribute('data-on-submit-type', event.target.value); - }; - frmDom.util.documentOn('change', '.frm_on_submit_type input[type="radio"]', onChangeType); - } - - /** - * Listen for click events for an API-loaded email collection form. - * - * This is used for the Active Campaign sign-up form in the inbox page (when there are no messages). - */ - function initAddMyEmailAddress() { - jQuery(document).on('click', '#frm-add-my-email-address', function (event) { - event.preventDefault(); - addMyEmailAddress(); - }); - var emptyInbox = document.getElementById('frm_empty_inbox'); - var leaveEmailInput = document.getElementById('frm_leave_email'); - if (emptyInbox && leaveEmailInput) { - var leaveEmailModal = document.getElementById('frm-leave-email-modal'); - leaveEmailModal.classList.remove('frm_hidden'); - leaveEmailModal.querySelector('.frm_modal_footer').classList.add('frm_hidden'); - leaveEmailInput.addEventListener('keyup', function (event) { - if ('Enter' === event.key) { - var button = document.getElementById('frm-add-my-email-address'); - if (button) { - button.click(); - } - } - }); - } - } - function addMyEmailAddress() { - var email = document.getElementById('frm_leave_email').value.trim(); - if ('' === email) { - handleEmailAddressError('empty'); - return; - } - var regex = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i; - if (regex.test(email) === false) { - handleEmailAddressError('invalid'); - return; - } - var $hiddenForm = jQuery('#frmapi-email-form').find('form'); - var $hiddenEmailField = $hiddenForm.find('[type="email"]').not('.frm_verify'); - if (!$hiddenEmailField.length) { - return; - } - var emptyInbox = document.getElementById('frm_empty_inbox'); - if (emptyInbox) { - document.getElementById('frm-add-my-email-address').remove(); - var emailWrapper = document.getElementById('frm_leave_email_wrapper'); - if (emailWrapper) { - emailWrapper.classList.add('frm_hidden'); - var spinner = span({ - className: 'frm-wait frm_spinner' - }); - spinner.style.visibility = 'visible'; - spinner.style.float = 'none'; - spinner.style.width = 'unset'; - emailWrapper.parentElement.insertBefore(spinner, emailWrapper.nextElementSibling); - } - } - $hiddenEmailField.val(email); - jQuery.ajax({ - type: 'POST', - url: $hiddenForm.attr('action'), - data: "".concat($hiddenForm.serialize(), "&action=frm_forms_preview") - }).done(function (data) { - var message = jQuery(data).find('.frm_message').text().trim(); - if (!message.includes('Thanks!')) { - handleEmailAddressError('invalid'); - return; - } - var apiForm = document.getElementById('frmapi-email-form'); - var spinner = apiForm.parentElement.querySelector('.frm_spinner'); - if (spinner) { - spinner.remove(); - } - var showSuccessMessage = wp.hooks.applyFilters('frm_thank_you_on_signup', true); - if (showSuccessMessage) { - // Handle successful form submission. - // handle the Active Campaign form on the inbox page. - document.getElementById('frm_leave_email_wrapper').replaceWith(span(__('Thank you for signing up!', 'formidable'))); - } - }); - } - - /** - * Adds footer links to the admin body content. - * - * @return {void} - */ - function addAdminFooterLinks() { - var _document$querySelect7; - var footerLinks = document.querySelector('.frm-admin-footer-links'); - var container = (_document$querySelect7 = document.querySelector('.frm_page_container')) !== null && _document$querySelect7 !== void 0 ? _document$querySelect7 : document.getElementById('wpbody-content'); - if (!footerLinks || !container) { - return; - } - container.append(footerLinks); - footerLinks.classList.remove('frm_hidden'); - } - - /** - * Apply zebra striping to a table while ignoring empty rows. - * - * @param {string} tableSelector The CSS selector for the table. - * @param {string} emptyRowClass The class name used to identify empty rows. - */ - function applyZebraStriping(tableSelector, emptyRowClass) { - // Get all non-empty table rows within the specified table - var rows = document.querySelectorAll("".concat(tableSelector, " tr").concat(emptyRowClass ? ":not(.".concat(emptyRowClass, ")") : '')); - if (rows.length < 1) { - return; - } - var isOdd = true; - rows.forEach(function (row) { - // Clean old "frm-odd" or "frm-even" classes and add the appropriate new class - row.classList.remove('frm-odd', 'frm-even'); - row.classList.add(isOdd ? 'frm-odd' : 'frm-even'); - isOdd = !isOdd; - }); - var tables = document.querySelectorAll(tableSelector); - tables.forEach(function (table) { - return table.classList.add('frm-zebra-striping'); - }); - } - function maybeHideShortcodes(e) { - var _e$target$parentEleme; - if (!builderPage) { - e.stopPropagation(); - } - if (e.target.classList.contains('frm-show-box') || (_e$target$parentEleme = e.target.parentElement) !== null && _e$target$parentEleme !== void 0 && _e$target$parentEleme.classList.contains('frm-show-box')) { - return; - } - var sidebar = document.getElementById('frm_adv_info'); - if (!sidebar) { - return; - } - if (sidebar.dataset.fills === e.target.id && e.target.id !== undefined) { - return; - } - var isChild = e.target.closest('#frm_adv_info'); - if (!isChild && sidebar.style.display !== 'none') { - hideShortcodes(sidebar); - } - } - - /** - * Initializes and manages the visibility of dependent elements based on the selected options in dropdowns with the 'frm_select_with_dependency' class. - * It sets up initial visibility at page load and updates it on each dropdown change. - * - * @since 6.9 - * - * @return {void} - */ - function initSelectDependencies() { - var selects = document.querySelectorAll('select.frm_select_with_dependency'); - - /** - * Toggles the visibility of dependent elements associated with a select element based on its current selection. - * - * @since 6.9 - * - * @param {HTMLElement} select The select element whose dependencies need to be managed. - * @return {void} - */ - function toggleDependencyVisibility(select) { - var selectedOption = select.options[select.selectedIndex]; - select.querySelectorAll('option[data-dependency]:not([data-dependency-skip])').forEach(function (option) { - var dependencyElement = document.querySelector(option.dataset.dependency); - dependencyElement === null || dependencyElement === void 0 || dependencyElement.classList.toggle('frm_hidden', selectedOption !== option); - }); - } - - // Initial setup: Show dependencies based on the current selection in each dropdown - selects.forEach(toggleDependencyVisibility); - - // Update dependencies visibility on dropdown change - frmDom.util.documentOn('change', 'select.frm_select_with_dependency', function (event) { - return toggleDependencyVisibility(event.target); - }); - } - - /** - * Moves the focus to the next single option input field in the list and positions the cursor at the end of the text. - * - * @param {HTMLElement} currentInput The currently focused input element. - */ - function focusNextSingleOptionInput(currentInput) { - var optionsList = currentInput.closest('.frm_single_option').parentElement; - var inputs = optionsList.querySelectorAll('.frm_single_option input[name^="field_options[" ], .frm_single_option input[name^="rows_"]'); - var inputsArray = Array.from(inputs); - - // Find the index of the currently focused input - var currentIndex = inputsArray.indexOf(currentInput); - if (currentIndex < 0) { - return; - } - - // Find the next visible input field - var nextInput = inputsArray.slice(currentIndex + 1).find(function (input) { - return input.offsetParent !== null; - }); - if (nextInput) { - nextInput.focus(); - - // Move the cursor to the end of the text in the next input field - var textLength = nextInput.value.length; - nextInput.setSelectionRange(textLength, textLength); - } - } - return { - init: function init() { - initAddMyEmailAddress(); - addAdminFooterLinks(); - document.addEventListener('show.bs.dropdown', function () { - // Fixes issues with tooltips lingering after a dropdown is shown. - deleteTooltips(); - }); - s = {}; - - // Bootstrap dropdown button - jQuery('.wp-admin').on('click', function (e) { - var t = jQuery(e.target); - var $openDrop = jQuery('.dropdown.open'); - if ($openDrop.length && !t.hasClass('dropdown') && !t.closest('.dropdown').length) { - $openDrop.removeClass('open'); - } - }); - jQuery('#frm_bs_dropdown:not(.open) a').on('click', focusSearchBox); - if (thisFormId === undefined) { - thisFormId = jQuery(document.getElementById('form_id')).val(); - } - - // Add event listener for dismissible warning messages. - document.querySelectorAll('.frm-warning-dismiss').forEach(function (dismissIcon) { - onClickPreventDefault(dismissIcon, dismissWarningMessage); - }); - frmAdminBuild.inboxBannerInit(); - if ($newFields.length > 0) { - // only load this on the form builder page - frmAdminBuild.buildInit(); - } else if (document.getElementById('frm_notification_settings') !== null) { - // only load on form settings page - frmAdminBuild.settingsInit(); - } else if (document.getElementById('frm_styling_form') !== null) { - // load styling settings js - frmAdminBuild.styleInit(); - } else if (document.getElementById('form_global_settings') !== null) { - // global settings page - frmAdminBuild.globalSettingsInit(); - } else if (document.getElementById('frm_export_xml') !== null) { - // import/export page - frmAdminBuild.exportInit(); - } else if (null !== document.querySelector('.frm-inbox-wrapper')) { - // Dashboard page inbox. - frmAdminBuild.inboxInit(); - } else if (document.getElementById('frm-welcome') !== null) { - // Solution install page - frmAdminBuild.solutionInit(); - } else { - maybeInitEntriesListPage(); - initAutocomplete(); - jQuery('[data-frmprint]').on('click', function () { - window.print(); - return false; - }); - } - jQuery(document).on('change', 'select[data-toggleclass], input[data-toggleclass]', toggleFormOpts); - initSelectDependencies(); - var $advInfo = jQuery(document.getElementById('frm_adv_info')); - if ($advInfo.length > 0 || jQuery('.frm_field_list').length > 0) { - // only load on the form, form settings, and view settings pages - frmAdminBuild.panelInit(); - } - loadTooltips(); - initUpgradeModal(); - frmDom.util.documentOn('click', '[data-modal-title]', showBasicModal); - - // used on build, form settings, and view settings - var $shortCodeDiv = jQuery(document.getElementById('frm_shortcodediv')); - if ($shortCodeDiv.length > 0) { - jQuery('a.edit-frm_shortcode').on('click', function () { - if ($shortCodeDiv.is(':hidden')) { - $shortCodeDiv.slideDown('fast'); - this.style.display = 'none'; - } - return false; - }); - jQuery('.cancel-frm_shortcode', '#frm_shortcodediv').on('click', function () { - $shortCodeDiv.slideUp('fast'); - $shortCodeDiv.siblings('a.edit-frm_shortcode').show(); - return false; - }); - } - - // tabs - jQuery(document).on('click', '#frm-nav-tabs a', clickNewTab); - jQuery('.post-type-frm_display .frm-nav-tabs a, .frm-category-tabs a').on('click', function () { - var showUpgradeTab = this.classList.contains('frm_show_upgrade_tab'); - if (this.classList.contains('frm_noallow') && !showUpgradeTab) { - return; - } - if (showUpgradeTab) { - populateUpgradeTab(this); - } - clickTab(this); - return false; - }); - clickTab(jQuery('.starttab a'), 'auto'); - - // submit the search form with dropdown - jQuery(document).on('click', '#frm-fid-search-menu a', function () { - var val = this.id.replace('fid-', ''); - jQuery('select[name="fid"]').val(val); - triggerSubmit(document.getElementById('posts-filter')); - return false; - }); - jQuery('.frm_select_box').on('click focus', function () { - this.select(); - }); - jQuery(document).on('input search change', '.frm-auto-search:not(#frm-form-templates-page #template-search-input)', searchContent); - jQuery(document).on('focusin click', '.frm-auto-search', stopPropagation); - var autoSearch = jQuery('.frm-auto-search'); - if (autoSearch.val() !== '') { - autoSearch.trigger('keyup'); - } - - // Initialize Formidable Connection. - FrmFormsConnect.init(); - jQuery(document).on('click', '.frm-install-addon', installAddon); - jQuery(document).on('click', '.frm-activate-addon', activateAddon); - jQuery(document).on('click', '.frm-solution-multiple', installMultipleAddons); - - // prevent annoying confirmation message from WordPress - jQuery('button, input[type=submit]').on('click', removeWPUnload); - addMultiselectLabelListener(); - frmAdminBuild.hooks.addFilter('frm_before_embed_modal', function (ids, _ref4) { - var element = _ref4.element, - type = _ref4.type; - if ('form' !== type) { - return ids; - } - var formId; - var formKey; - var row = element.closest('tr'); - if (row) { - // Embed icon on form index. - formId = parseInt(row.querySelector('.column-id').textContent); - formKey = row.querySelector('.column-form_key').textContent; - } else { - // Embed button in form builder / form settings. - formId = document.getElementById('form_id').value; - var formKeyInput = document.getElementById('frm_form_key'); - if (formKeyInput) { - formKey = formKeyInput.value; - } else { - var previewDrop = document.getElementById('frm-previewDrop'); - if (previewDrop) { - formKey = previewDrop.nextElementSibling.querySelector('.dropdown-item a').getAttribute('href').split('form=')[1]; - } - } - } - return [formId, formKey]; - }); - document.querySelectorAll('#frm-show-fields > li, .frm_grid_container li').forEach(function (el, _key) { - el.addEventListener('click', function () { - var _this$querySelector; - var fieldId = ((_this$querySelector = this.querySelector('li')) === null || _this$querySelector === void 0 ? void 0 : _this$querySelector.dataset.fid) || this.dataset.fid; - maybeAddSaveAndDragIcons(fieldId); - }); - }); - var smallScreenProceedButton = document.getElementById('frm_small_screen_proceed_button'); - if (smallScreenProceedButton) { - onClickPreventDefault(smallScreenProceedButton, function () { - var _document$getElementB5; - (_document$getElementB5 = document.getElementById('frm_small_device_message_container')) === null || _document$getElementB5 === void 0 || _document$getElementB5.remove(); - doJsonPost('small_screen_proceed', new FormData()); - }); - } - var saleBanner = document.getElementById('frm_sale_banner'); - var saleDismiss = saleBanner === null || saleBanner === void 0 ? void 0 : saleBanner.querySelector('.dismiss'); - if (saleBanner) { - onClickPreventDefault(saleBanner, function (event) { - var target = event.target; - if (target.closest('.dismiss')) { - return; - } - window.location.href = saleBanner.getAttribute('data-url'); - }); - if (saleDismiss) { - onClickPreventDefault(saleDismiss, function () { - saleBanner.remove(); - var formData = new FormData(); - doJsonPost('sale_banner_dismiss', formData); - }); - } - } - }, - buildInit: function buildInit() { - jQuery('#frm_builder_page').on('mouseup', '*:not(.frm-show-box)', maybeHideShortcodes); - var loadFieldId; - debouncedSyncAfterDragAndDrop = debounce(syncAfterDragAndDrop, 10); - postBodyContent = document.getElementById('post-body-content'); - $postBodyContent = jQuery(postBodyContent); - if (jQuery('.frm_field_loading').length) { - loadFieldId = jQuery('.frm_field_loading').first().attr('id'); - loadFields(loadFieldId); - } - setupSortable('ul.frm_sorting'); - document.querySelectorAll('.field_type_list > li:not(.frm_show_upgrade):not(.frm_show_update)').forEach(makeDraggable); - jQuery('ul.field_type_list, .field_type_list li, ul.frm_code_list, .frm_code_list li, .frm_code_list li a, #frm_adv_info #category-tabs li, #frm_adv_info #category-tabs li a').disableSelection(); - jQuery('.frm_submit_ajax').on('click', submitBuild); - jQuery('.frm_submit_no_ajax').on('click', submitNoAjax); - addFormNameModalEvents(); - jQuery('a.edit-form-status').on('click', slideDown); - jQuery('.cancel-form-status').on('click', slideUp); - jQuery('.save-form-status').on('click', function () { - var newStatus = jQuery(document.getElementById('form_change_status')).val(); - jQuery('input[name="new_status"]').val(newStatus); - jQuery(document.getElementById('form-status-display')).html(newStatus); - jQuery('.cancel-form-status').trigger('click'); - return false; - }); - jQuery('.frm_form_builder form').first().on('submit', function () { - jQuery('.inplace_field').trigger('blur'); - }); - initiateMultiselect(); - renumberPageBreaks(); - var $builderForm = jQuery(builderForm); - var builderArea = document.getElementById('frm_form_editor_container'); - $builderForm.on('click', '.frm_add_logic_row', addFieldLogicRow); - $builderForm.on('click', '.frm_add_watch_lookup_row', addWatchLookupRow); - $builderForm.on('change', '.frm_get_values_form', updateGetValueFieldSelection); - $builderForm.on('change', '.frm_logic_field_opts', getFieldValues); - $builderForm.on('frm-multiselect-changed', 'select[name^="field_options[admin_only_"]', adjustVisibilityValuesForEveryoneValues); - jQuery(document.getElementById('frm-insert-fields')).on('click', '.frm_add_field', addFieldClick); - $newFields.on('click', '.frm_clone_field', duplicateField); - $builderForm.on('blur', 'input[id^="frm_calc"]', checkCalculationCreatedByUser); - $builderForm.on('change', 'input.frm_format_opt, input.frm_max_length_opt', toggleInvalidMsg); - $builderForm.on('change click', '[data-changeme]', liveChanges); - $builderForm.on('click', 'input.frm_req_field', markRequired); - $builderForm.on('click', '.frm_mark_unique', markUnique); - $builderForm.on('change', '.frm_repeat_format', toggleRepeatButtons); - $builderForm.on('change', '.frm_repeat_limit', checkRepeatLimit); - $builderForm.on('change', '.frm_js_checkbox_limit', checkCheckboxSelectionsLimit); - $builderForm.on('input', 'input[name^="field_options[add_label_"]', function () { - updateRepeatText(this, 'add'); - }); - $builderForm.on('input', 'input[name^="field_options[remove_label_"]', function () { - updateRepeatText(this, 'remove'); - }); - $builderForm.on('change', 'select[name^="field_options[data_type_"]', maybeClearWatchFields); - jQuery(builderArea).on('click', '.frm-collapse-page', maybeCollapsePage); - jQuery(builderArea).on('click', '.frm-collapse-section', maybeCollapseSection); - $builderForm.on('click', '.frm-single-settings h3, .frm-single-settings h4.frm-collapsible', maybeCollapseSettings); - $builderForm.on('keydown', '.frm-single-settings h3, .frm-single-settings h4.frm-collapsible', function (event) { - // If so, only proceed if the key pressed was 'Enter' or 'Space' - if (event.key === 'Enter' || event.key === ' ') { - event.preventDefault(); - maybeCollapseSettings.call(this, event); - } - }); - jQuery(builderArea).on('show.bs.dropdown hide.bs.dropdown', changeSectionStyle); - $builderForm.on('click', '.frm_toggle_sep_values', toggleSepValues); - $builderForm.on('click', '.frm_toggle_image_options', toggleImageOptions); - $builderForm.on('click', '.frm_remove_image_option', removeImageFromOption); - $builderForm.on('click', '.frm_choose_image_box', addImageToOption); - $builderForm.on('change', '.frm_hide_image_text', refreshOptionDisplay); - $builderForm.on('change', '.frm_field_options_image_size', setImageSize); - $builderForm.on('click', '.frm_multiselect_opt', toggleMultiselect); - $newFields.on('mousedown', 'input, textarea, select', stopFieldFocus); - $newFields.on('click', 'input[type=radio], input[type=checkbox]', stopFieldFocus); - $newFields.on('click', '.frm_delete_field', clickDeleteField); - $newFields.on('click', '.frm_select_field', clickSelectField); - jQuery(document).on('click', '.frm_delete_field_group', clickDeleteFieldGroup); - jQuery(document).on('click', '.frm_clone_field_group', duplicateFieldGroup); - jQuery(document).on('click', '#frm_field_group_controls > span:first-child', clickFieldGroupLayout); - jQuery(document).on('click', '.frm-row-layout-option', handleFieldGroupLayoutOptionClick); - jQuery(document).on('click', '.frm-merge-fields-into-row .frm-row-layout-option', handleFieldGroupLayoutOptionInsideMergeClick); - jQuery(document).on('click', '.frm-custom-field-group-layout', customFieldGroupLayoutClick); - jQuery(document).on('click', '.frm-merge-fields-into-row .frm-custom-field-group-layout', customFieldGroupLayoutInsideMergeClick); - jQuery(document).on('click', '.frm-break-field-group', breakFieldGroupClick); - $newFields.on('click', '#frm_field_group_popup .frm_grid_container input', focusFieldGroupInputOnClick); - jQuery(document).on('click', '.frm-cancel-custom-field-group-layout', cancelCustomFieldGroupClick); - jQuery(document).on('click', '.frm-save-custom-field-group-layout', saveCustomFieldGroupClick); - $newFields.on('click', 'ul.frm_sorting', fieldGroupClick); - jQuery(document).on('click', '.frm-merge-fields-into-row', mergeFieldsIntoRowClick); - jQuery(document).on('click', '.frm-delete-field-groups', deleteFieldGroupsClick); - $newFields.on('click', '.frm-field-action-icons [data-toggle="dropdown"]', function () { - this.closest('li.form-field').classList.add('frm-field-settings-open'); - jQuery(document).on('click', '#frm_builder_page', handleClickOutsideOfFieldSettings); - }); - $newFields.on('mousemove', 'ul.frm_sorting', checkForMultiselectKeysOnMouseMove); - $newFields.on('show.bs.dropdown', '.frm-field-action-icons', onFieldActionDropdownShow); - jQuery(document).on('show.bs.dropdown', '#frm_field_group_controls', onFieldGroupActionDropdownShow); - $builderForm.on('click', '.frm_single_option a[data-removeid]', deleteFieldOption); - $builderForm.on('mousedown', '.frm_single_option input[type=radio]', maybeUncheckRadio); - $builderForm.on('focusin', '.frm_single_option input[type=text]', maybeClearOptText); - $builderForm.on('click', '.frm_add_opt', addFieldOption); - $builderForm.on('change', '.frm_single_option input', resetOptOnChange); - $builderForm.on('change', '.frm_image_id', resetOptOnChange); - $builderForm.on('change', '.frm_toggle_mult_sel', toggleMultSel); - $newFields.on('click', '.frm_primary_label', clickLabel); - $newFields.on('click', '.frm_description', clickDescription); - $newFields.on('click', 'li.ui-state-default:not(.frm_noallow)', clickVis); - $newFields.on('dblclick', 'li.ui-state-default', openAdvanced); - $builderForm.on('change', '.frm_tax_form_select', toggleFormTax); - $builderForm.on('change', 'select.conf_field', addConf); - $builderForm.on('change', '.frm_get_field_selection', getFieldSelection); - $builderForm.on('click', '.frm-show-inline-modal', maybeShowInlineModal); - $builderForm.on('keydown', '.frm-show-inline-modal', function (event) { - var key = event.key; - if (key === 'Enter' || key === ' ') { - event.preventDefault(); - maybeShowInlineModal.call(this, event); - } - }); - $builderForm.on('click', '.frm-inline-modal .dismiss', dismissInlineModal); - jQuery(document).on('change', '[data-frmchange]', changeInputtedValue); - document.addEventListener('click', closeModalOnOutsideClick); - $builderForm.on('change', '.frm_include_extras_field', rePopCalcFieldsForSummary); - $builderForm.on('change', 'select[name^="field_options[form_select_"]', maybeChangeEmbedFormMsg); - jQuery(document).on('submit', '#frm_js_build_form', buildSubmittedNoAjax); - jQuery(document).on('change', '#frm_builder_page input:not(.frm-search-input):not(.frm-custom-grid-size-input), #frm_builder_page select, #frm_builder_page textarea', fieldUpdated); - popAllProductFields(); - jQuery(document).on('change', '.frmjs_prod_data_type_opt', toggleProductType); - jQuery(document).on('focus', '.frm-single-settings ul input[type="text"][name^="field_options[options_"]', onOptionTextFocus); - jQuery(document).on('blur', '.frm-single-settings ul input[type="text"][name^="field_options[options_"]', onOptionTextBlur); - frmDom.util.documentOn('click', '.frm-show-field-settings', clickVis); - frmDom.util.documentOn('change', 'select.frm_format_dropdown, select.frm_phone_type_dropdown', maybeUpdateFormatInput); - - // Navigate to the next input field on pressing Enter in a single option field - $builderForm.on('keydown', '.frm_single_option input[name^="field_options["], .frm_single_option input[name^="rows_"]', function (event) { - if ('Enter' === event.key) { - focusNextSingleOptionInput(event.currentTarget); - } - }); - initBulkOptionsOverlay(); - hideEmptyEle(); - document.addEventListener('frm_added_field', hideEmptyEle); - maybeHideQuantityProductFieldOption(); - handleNameFieldOnFormBuilder(); - toggleSectionHolder(); - handleShowPasswordLiveUpdate(); - document.addEventListener('scroll', updateShortcodesPopupPosition, true); - document.addEventListener('change', handleBuilderChangeEvent); - document.querySelector('.frm_form_builder').addEventListener('mousedown', function (event) { - if (event.shiftKey) { - event.preventDefault(); - } - }); - wp.hooks.addAction('frmShowedFieldSettings', 'formidableAdmin', function (showBtn, fieldSettingsEl) { - fieldSettingsEl.querySelectorAll('.frm-collapse-me').forEach(addSlideAnimationCssVars); - }, 9999); - }, - settingsInit: function settingsInit() { - var $formActions = jQuery(document.getElementById('frm_notification_settings')); - - // BCC, CC, and Reply To button functionality - $formActions.on('click', '.frm_email_buttons', showEmailRow); - $formActions.on('click', '.frm_remove_field', hideEmailRow); - $formActions.on('change', '.frm_to_row, .frm_from_row', showEmailWarning); - $formActions.on('change', '.frm_tax_selector', changePosttaxRow); - $formActions.on('change', 'select.frm_single_post_field', checkDupPost); - $formActions.on('change', 'select.frm_toggle_post_content', togglePostContent); - $formActions.on('change', 'select.frm_dyncontent_opt', fillDyncontent); - $formActions.on('change', '.frm_post_type', switchPostType); - $formActions.on('click', '.frm_add_postmeta_row', addPostmetaRow); - $formActions.on('click', '.frm_add_posttax_row', addPosttaxRow); - $formActions.on('click', '.frm_toggle_cf_opts', toggleCfOpts); - $formActions.on('click', '.frm_duplicate_form_action', copyFormAction); - jQuery('.frm_actions_list').on('click', '.frm_active_action', addFormAction); - jQuery('#frm-show-groups, #frm-hide-groups').on('click', toggleActionGroups); - initiateMultiselect(); - - //set actions icons to inactive - jQuery('ul.frm_actions_list li').each(function () { - checkActiveAction(jQuery(this).children('a').data('actiontype')); - - // If the icon is a background image, don't add BG color. - var icon = jQuery(this).find('i'); - if (icon.css('background-image') !== 'none') { - icon.addClass('frm-inverse'); - } - }); - jQuery('.frm_submit_settings_btn').on('click', submitSettings); - addFormNameModalEvents(); - var formSettings = jQuery('.frm_form_settings'); - formSettings.on('click', '.frm_add_form_logic', addFormLogicRow); - formSettings.on('click', '.frm_already_used', actionLimitMessage); - document.addEventListener('click', function handleImageUploadClickEvents(event) { - var target = event.target; - if (!target.closest('.frm_image_preview_wrapper')) { - return; - } - if (target.closest('.frm_choose_image_box')) { - addImageToOption.bind(target)(event); - return; - } - if (target.closest('.frm_remove_image_option')) { - removeImageFromOption.bind(target)(event); - } - }); - - // Close shortcode modal on click. - formSettings.on('mouseup', '*:not(.frm-show-box)', maybeHideShortcodes); - - //Warning when user selects "Do not store entries ..." - jQuery(document.getElementById('no_save')).on('change', function () { - if (this.checked) { - if (confirm(frmAdminJs.no_save_warning) !== true) { - // Uncheck box if user hits "Cancel" - jQuery(this).attr('checked', false); - } - } - }); - jQuery('select[name="options[edit_action]"]').on('change', showSuccessOpt); - var $loggedIn = document.getElementById('logged_in'); - jQuery($loggedIn).on('change', function () { - if (this.checked) { - visible('.hide_logged_in'); - } else { - invisible('.hide_logged_in'); - } - }); - var $cookieExp = jQuery(document.getElementById('frm_cookie_expiration')); - jQuery(document.getElementById('frm_single_entry_type')).on('change', function () { - if (this.value === 'cookie') { - $cookieExp.fadeIn('slow'); - } else { - $cookieExp.fadeOut('slow'); - } - }); - var $singleEntry = document.getElementById('single_entry'); - jQuery($singleEntry).on('change', function () { - if (this.checked) { - visible('.hide_single_entry'); - } else { - invisible('.hide_single_entry'); - } - if (this.checked && jQuery(document.getElementById('frm_single_entry_type')).val() === 'cookie') { - $cookieExp.fadeIn('slow'); - } else { - $cookieExp.fadeOut('slow'); - } - }); - jQuery('.hide_save_draft').hide(); - var $saveDraft = jQuery(document.getElementById('save_draft')); - $saveDraft.on('change', function () { - if (this.checked) { - jQuery('.hide_save_draft').fadeIn('slow'); - } else { - jQuery('.hide_save_draft').fadeOut('slow'); - } - }); - triggerChange($saveDraft); - - //If Allow editing is checked/unchecked - var $editable = document.getElementById('editable'); - jQuery($editable).on('change', function () { - if (this.checked) { - jQuery('.hide_editable').fadeIn('slow'); - triggerChange(document.getElementById('edit_action')); - } else { - jQuery('.hide_editable').fadeOut('slow'); - jQuery('.edit_action_message_box').fadeOut('slow'); //Hide On Update message box - } - }); - - //If File Protection is checked/unchecked - jQuery(document).on('change', '#protect_files', function () { - if (this.checked) { - jQuery('.hide_protect_files').fadeIn('slow'); - } else { - jQuery('.hide_protect_files').fadeOut('slow'); - } - }); - jQuery(document).on('frm-multiselect-changed', '#protect_files_role', adjustVisibilityValuesForEveryoneValues); - jQuery(document).on('submit', '.frm_form_settings', settingsSubmitted); - jQuery(document).on('change', '#form_settings_page input:not(.frm-search-input), #form_settings_page select, #form_settings_page textarea', fieldUpdated); - - // Page Selection Autocomplete - initAutocomplete(); - jQuery(document).on('frm-action-loaded', onActionLoaded); - initOnSubmitAction(); - wp.hooks.addAction('frm_reset_fields_updated', 'formidableAdmin', resetFieldsUpdated); - }, - panelInit: function panelInit() { - jQuery('.frm_wrap, #postbox-container-1').on('click', '.frm_insert_code', insertCode); - jQuery(document).on('change', '.frm_insert_val', function () { - insertFieldCode(jQuery(this).data('target'), jQuery(this).val()); - jQuery(this).val(''); - }); - jQuery(document).on('click change', '[name="frm-id-key-condition"]', resetLogicBuilder); - jQuery(document).on('keyup change', '.frm-build-logic', setLogicExample); - showInputIcon(); - jQuery(document).on('frmElementAdded', function (event, parentEle) { - /* This is here for add-ons to trigger */ - showInputIcon(parentEle); - }); - jQuery(document).on('mousedown', '.frm-show-box', showShortcodes); - var settingsPage = document.getElementById('form_settings_page'); - var viewPage = document.body.classList.contains('post-type-frm_display'); - var insertFieldsTab = document.getElementById('frm_insert_fields_tab'); - if (settingsPage || viewPage || builderPage) { - jQuery(document).on('focusin', 'form input, form textarea', function (e) { - var htmlTab; - e.stopPropagation(); - maybeShowModal(this); - if (jQuery(this).is(':not(:submit, input[type=button], .frm-search-input, input[type=checkbox])')) { - if (jQuery(e.target).closest('#frm_adv_info').length) { - // Don't trigger for fields inside of the modal. - return; - } - if (settingsPage || builderPage) { - /* form settings page */ - htmlTab = jQuery('#frm_html_tab'); - if (jQuery(this).closest('#html_settings').length > 0) { - htmlTab.show(); - htmlTab.siblings().hide(); - jQuery('#frm_html_tab a').trigger('click'); - toggleAllowedHTML(this); - } else { - showElement(jQuery('.frm-category-tabs li')); - insertFieldsTab.click(); - htmlTab.hide(); - htmlTab.siblings().show(); - } - } else if (viewPage) { - var event = new CustomEvent('frm_legacy_views_handle_field_focus'); - event.frmData = { - idAttrValue: this.id - }; - document.dispatchEvent(event); - } - } - }); - } - jQuery('.frm_wrap, #postbox-container-1').on('mousedown', '#frm_adv_info a, .frm_field_list a', function (e) { - e.preventDefault(); - }); - var customPanel = jQuery('#frm_adv_info'); - customPanel.on('click', '.subsubsub a.frmids', function (e) { - toggleKeyID('frmids', e); - }); - customPanel.on('click', '.subsubsub a.frmkeys', function (e) { - toggleKeyID('frmkeys', e); - }); - }, - inboxInit: function inboxInit() { - var _document$getElementB6; - jQuery('.frm_inbox_dismiss').on('click', function (e) { - var message = this.parentNode.parentNode; - var key = message.getAttribute('data-message'); - var href = this.getAttribute('href'); - var dismissedMessage = message.cloneNode(true); - var dismissedMessagesWrapper = document.querySelector('.frm-dismissed-inbox-messages'); - if ('free_templates' === key && !this.classList.contains('frm_inbox_dismiss')) { - return; - } - e.preventDefault(); - var data = { - action: 'frm_inbox_dismiss', - key: key, - nonce: frmGlobal.nonce - }; - var isInboxSlideIn = 'frm_inbox_slide_in' === message.id; - if (isInboxSlideIn) { - message.classList.remove('s11-fadein'); - message.classList.add('s11-fadeout'); - message.addEventListener('animationend', function () { - return message.remove(); - }, { - once: true - }); - } - postAjax(data, function () { - if (isInboxSlideIn) { - return; - } - if (href !== '#') { - window.location = href; - return true; - } - fadeOut(message, function () { - if (dismissedMessagesWrapper) { - var _dismissedMessage$que; - dismissedMessage.classList.remove('frm-fade'); - (_dismissedMessage$que = dismissedMessage.querySelector('.frm-inbox-message-heading .frm_inbox_dismiss')) === null || _dismissedMessage$que === void 0 || _dismissedMessage$que.remove(); - dismissedMessagesWrapper.append(dismissedMessage); - } - if (1 === message.parentNode.querySelectorAll('.frm-inbox-message-container').length) { - document.getElementById('frm_empty_inbox').classList.remove('frm_hidden'); - message.parentNode.closest('.frm-active').classList.add('frm-empty-inbox'); - showActiveCampaignForm(); - } - message.remove(); - }); - }); - }); - if (false === ((_document$getElementB6 = document.getElementById('frm_empty_inbox')) === null || _document$getElementB6 === void 0 ? void 0 : _document$getElementB6.classList.contains('frm_hidden'))) { - showActiveCampaignForm(); - } - }, - solutionInit: function solutionInit() { - jQuery(document).on('submit', '#frm-new-template', installTemplate); - }, - styleInit: function styleInit() { - var $previewWrapper = jQuery('.frm_image_preview_wrapper'); - $previewWrapper.on('click', '.frm_choose_image_box', addImageToOption); - $previewWrapper.on('click', '.frm_remove_image_option', removeImageFromOption); - wp.hooks.doAction('frm_style_editor_init'); - }, - customCSSInit: function customCSSInit() { - console.warn('Calling frmAdminBuild.customCSSInit is deprecated.'); - }, - globalSettingsInit: function globalSettingsInit() { - jQuery(document).on('click', '[data-frmuninstall]', uninstallNow); - initiateMultiselect(); - - // activate addon licenses - var licenseTab = document.getElementById('licenses_settings'); - if (licenseTab) { - jQuery(licenseTab).on('click', '.edd_frm_save_license', saveAddonLicense); - } - - // Solution install page - jQuery(document).on('click', '#frm-new-template button', installTemplateFieldset); - jQuery('#frm-dismissable-cta .dismiss').on('click', function (event) { - event.preventDefault(); - jQuery.post(ajaxurl, { - action: 'frm_lite_settings_upgrade', - nonce: frmGlobal.nonce - }); - jQuery('.settings-lite-cta').remove(); - }); - var captchaType = document.getElementById('frm_re_type'); - if (captchaType) { - captchaType.addEventListener('change', handleCaptchaTypeChange); - } - document.querySelector('.frm_captchas').addEventListener('change', function (event) { - var _document$querySelect8; - var captchaValueOnLoad = (_document$querySelect8 = document.querySelector('.frm_captchas input[checked="checked"]')) === null || _document$querySelect8 === void 0 ? void 0 : _document$querySelect8.value; - var showNote = event.target.value !== captchaValueOnLoad; - document.querySelector('.captcha_settings .frm_note_style').classList.toggle('frm_hidden', !showNote); - }); - - // Set fieldsUpdated to 0 to avoid the unsaved changes pop up. - frmDom.util.documentOn('submit', '.frm_settings_form', function () { - fieldsUpdated = 0; - }); - var manageStyleSettings = document.getElementById('manage_styles_settings'); - if (manageStyleSettings) { - manageStyleSettings.addEventListener('change', function (event) { - var target = event.target; - if ('SELECT' !== target.nodeName || !target.dataset.name || target.getAttribute('name')) { - return; - } - target.setAttribute('name', target.dataset.name); - }); - } - var paymentsSettings = document.getElementById('payments_settings'); - var paymentSettingsTabs = paymentsSettings === null || paymentsSettings === void 0 ? void 0 : paymentsSettings.querySelectorAll('[name="frm_payment_section"]'); - if (paymentSettingsTabs) { - paymentSettingsTabs.forEach(function (element) { - element.addEventListener('change', function () { - if (!element.checked) { - return; - } - var label = paymentsSettings.querySelector("label[for=\"".concat(element.id, "\"]")); - if (label) { - label.setAttribute('aria-selected', 'true'); - } - paymentSettingsTabs.forEach(function (tab) { - if (tab === element) { - return; - } - var label = paymentsSettings.querySelector("label[for=\"".concat(tab.id, "\"]")); - if (label) { - label.setAttribute('aria-selected', 'false'); - } - }); - }); - }); - } - }, - exportInit: function exportInit() { - jQuery('.frm_form_importer').on('submit', startFormMigration); - jQuery(document.getElementById('frm_export_xml')).on('submit', validateExport); - jQuery('#frm_export_xml input, #frm_export_xml select').on('change', removeExportError); - jQuery('input[name="frm_import_file"]').on('change', checkCSVExtension); - document.querySelector('select[name="format"]').addEventListener('change', exportTypeChanged); - jQuery('input[name="frm_export_forms[]"]').on('click', preventMultipleExport); - initiateMultiselect(); - jQuery('.frm-feature-banner .dismiss').on('click', function (event) { - event.preventDefault(); - jQuery.post(ajaxurl, { - action: 'frm_dismiss_migrator', - plugin: this.id, - nonce: frmGlobal.nonce - }); - this.parentElement.remove(); - }); - showOrHideRepeaters(getExportOption()); - document.querySelector('#frm-export-select-all').addEventListener('change', function (event) { - document.querySelectorAll('[name="frm_export_forms[]"]').forEach(function (cb) { - cb.checked = event.target.checked; - }); - }); - }, - inboxBannerInit: function inboxBannerInit() { - var banner = document.getElementById('frm_banner'); - if (!banner) { - return; - } - var dismissButton = banner.querySelector('.frm-banner-dismiss'); - document.addEventListener('click', function (event) { - if (event.target !== dismissButton) { - return; - } - var data = { - action: 'frm_inbox_dismiss', - key: banner.dataset.key, - nonce: frmGlobal.nonce - }; - postAjax(data, function () { - jQuery(banner).fadeOut(400, function () { - banner.remove(); - }); - }); - }); - }, - updateOpts: function updateOpts(fieldId, opts, modal) { - var separate = usingSeparateValues(fieldId); - var action = isProductField(fieldId) ? 'frm_bulk_products' : 'frm_import_options'; - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: { - action: action, - field_id: fieldId, - opts: opts, - separate: separate, - nonce: frmGlobal.nonce - }, - success: function success(html) { - document.getElementById("frm_field_".concat(fieldId, "_opts")).innerHTML = html; - wp.hooks.doAction('frm_after_bulk_edit_opts', fieldId); - resetDisplayedOpts(fieldId); - if (modal !== undefined) { - modal.dialog('close'); - document.getElementById('frm-update-bulk-opts').classList.remove('frm_loading_button'); - } - } - }); - }, - /* remove conditional logic if the field doesn't exist */triggerRemoveLogic: function triggerRemoveLogic(fieldID, metaName) { - jQuery("#frm_logic_".concat(fieldID, "_").concat(metaName, " .frm_remove_tag")).trigger('click'); - }, - downloadXML: function downloadXML(controller, ids, isTemplate) { - var url = "".concat(ajaxurl, "?action=frm_").concat(controller, "_xml&ids=").concat(ids); - if (isTemplate !== null) { - url = "".concat(url, "&is_template=").concat(isTemplate); - } - location.href = url; - }, - /** - * @since 5.0.04 - */ - hooks: { - applyFilters: function applyFilters(hookName) { - var _wp$hooks; - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key2 = 1; _key2 < _len; _key2++) { - args[_key2 - 1] = arguments[_key2]; - } - return (_wp$hooks = wp.hooks).applyFilters.apply(_wp$hooks, [hookName].concat(args)); - }, - addFilter: function addFilter(hookName, callback, priority) { - return wp.hooks.addFilter(hookName, 'formidable', callback, priority); - }, - doAction: function doAction(hookName) { - var _wp$hooks2; - for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key3 = 1; _key3 < _len2; _key3++) { - args[_key3 - 1] = arguments[_key3]; - } - return (_wp$hooks2 = wp.hooks).doAction.apply(_wp$hooks2, [hookName].concat(args)); - }, - addAction: function addAction(hookName, callback, priority) { - return wp.hooks.addAction(hookName, 'formidable', callback, priority); - } - }, - applyZebraStriping: applyZebraStriping, - initModal: initModal, - infoModal: infoModal, - offsetModalY: offsetModalY, - adjustConditionalLogicOptionOrders: adjustConditionalLogicOptionOrders, - addRadioCheckboxOpt: addRadioCheckboxOpt, - installNewForm: installNewForm, - toggleAddonState: toggleAddonState, - purifyHtml: purifyHtml, - loadApiEmailForm: loadApiEmailForm, - addMyEmailAddress: addMyEmailAddress, - fillDropdownOpts: fillDropdownOpts, - showSaveAndReloadModal: showSaveAndReloadModal, - clearSettingsBox: clearSettingsBox, - deleteField: deleteField, - insertFormField: insertFormField, - confirmLinkClick: confirmLinkClick, - handleInsertFieldByDraggingResponse: handleInsertFieldByDraggingResponse, - handleAddFieldClickResponse: handleAddFieldClickResponse, - syncLayoutClasses: syncLayoutClasses, - moveFieldSettings: moveFieldSettings, - maybeCollapseSettings: maybeCollapseSettings - }; -}; -window.frmAdminBuild = frmAdminBuildJS(); -jQuery(document).ready(function () { - var _document$querySelect9; - frmAdminBuild.init(); - document.querySelectorAll('.frm-dropdown-menu').forEach(convertOldBootstrapDropdownsToBootstrap5); - (_document$querySelect9 = document.querySelector('.preview.dropdown .frm-dropdown-toggle')) === null || _document$querySelect9 === void 0 || _document$querySelect9.setAttribute('data-bs-toggle', 'dropdown'); - - // Bootstrap 5 uses data-bs-toggle instead of data-toggle. - document.querySelectorAll('[data-toggle]').forEach(function (toggle) { - return toggle.setAttribute('data-bs-toggle', toggle.getAttribute('data-toggle')); - }); - function convertOldBootstrapDropdownsToBootstrap5(frmDropdownMenu) { - frmDropdownMenu.classList.add('dropdown-menu'); - var toggle = frmDropdownMenu.querySelector('.frm-dropdown-toggle'); - if (toggle) { - if (!toggle.hasAttribute('role')) { - toggle.setAttribute('role', 'button'); - } - if (!toggle.hasAttribute('tabindex')) { - toggle.setAttribute('tabindex', 0); - } - } - - // Convert
            • and
                tags. - if ('UL' === frmDropdownMenu.tagName) { - convertBootstrapUl(frmDropdownMenu); - } - } - function convertBootstrapUl(ul) { - var html = ul.outerHTML; - html = html.replace('
                  ', ''); - html = html.replaceAll('
                • ', '
                • ', ''); - ul.outerHTML = html; - } -}); -window.frm_show_div = function (div, value, showIf, classId) { - if (value == showIf) { - jQuery(classId + div).fadeIn('slow').css('visibility', 'visible'); - } else { - jQuery(classId + div).fadeOut('slow'); - } -}; -window.frmCheckAll = function (checked, n) { - jQuery("input[name^=\"".concat(n, "\"]")).prop('checked', Boolean(checked)); -}; -window.frmCheckAllLevel = function (checked, n, level) { - var $kids = jQuery(".frm_catlevel_".concat(level)).children('.frm_checkbox').children('label'); - $kids.children("input[name^=\"".concat(n, "\"]")).prop('checked', Boolean(checked)); -}; -window.frmGetFieldValues = function (fieldId, cur, rowNumber, fieldType, htmlName, callback) { - if (!fieldId) { - return; - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: "action=frm_get_field_values¤t_field=".concat(cur, "&field_id=").concat(fieldId, "&name=").concat(htmlName, "&t=").concat(fieldType, "&form_action=").concat(jQuery('input[name="frm_action"]').val(), "&nonce=").concat(frmGlobal.nonce), - success: function success(msg) { - document.getElementById("frm_show_selected_values_".concat(cur, "_").concat(rowNumber)).innerHTML = msg; - if ('function' === typeof callback) { - callback(); - } - } - }); -}; -window.frmImportCsv = function (formID) { - var urlVars = ''; - if (typeof __FRMURLVARS !== 'undefined') { - urlVars = __FRMURLVARS; - } - jQuery.ajax({ - type: 'POST', - url: ajaxurl, - data: "action=frm_import_csv&nonce=".concat(frmGlobal.nonce, "&frm_skip_cookie=1").concat(urlVars), - success: function success(count) { - var max = jQuery('.frm_admin_progress_bar').attr('aria-valuemax'); - var imported = max - count; - var percent = imported / max * 100; - jQuery('.frm_admin_progress_bar').css('width', "".concat(percent, "%")).attr('aria-valuenow', imported); - if (parseInt(count, 10) > 0) { - jQuery('.frm_csv_remaining').html(count); - frmImportCsv(formID); - } else { - jQuery(document.getElementById('frm_import_message')).html(frm_admin_js.import_complete); - setTimeout(function () { - location.href = "?page=formidable-entries&frm_action=list&form=".concat(formID, "&import-message=1"); - }, 2000); - } - } - }); -}; -})(); - -/******/ })() -; -//# sourceMappingURL=formidable_admin.js.map \ No newline at end of file +(()=>{var e={65:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(8793),o=r(1323);function i(e){var t=(0,n.A)(e);return function(e){return(0,o.A)(t,e)}}},1323:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n={"!":function(e){return!e},"*":function(e,t){return e*t},"/":function(e,t){return e/t},"%":function(e,t){return e%t},"+":function(e,t){return e+t},"-":function(e,t){return e-t},"<":function(e,t){return e":function(e,t){return e>t},">=":function(e,t){return e>=t},"==":function(e,t){return e===t},"!=":function(e,t){return e!==t},"&&":function(e,t){return e&&t},"||":function(e,t){return e||t},"?:":function(e,t,r){if(e)throw t;return r}};function o(e,t){var r,o,i,a,l,s,c=[];for(r=0;r{"use strict";r.d(t,{A:()=>o});var n=r(65);function o(e){var t=(0,n.A)(e);return function(e){return+t({n:e})}}},8793:(e,t,r)=>{"use strict";var n,o,i,a;function l(e){for(var t,r,l,s,c=[],d=[];t=e.match(a);){for(r=t[0],(l=e.substr(0,t.index).trim())&&c.push(l);s=d.pop();){if(i[r]){if(i[r][0]===s){r=i[r][1]||r;break}}else if(o.indexOf(s)>=0||n[s]l}),n={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},o=["(","?"],i={")":["("],":":["?","?:"]},a=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/},7521:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(6956),o=r(7395);const i=function(e,t){return function(r,i,a){var l=arguments.length>3&&void 0!==arguments[3]?arguments[3]:10,s=e[t];if((0,o.A)(r)&&(0,n.A)(i))if("function"==typeof a)if("number"==typeof l){var c={callback:a,priority:l,namespace:i};if(s[r]){var d,f=s[r].handlers;for(d=f.length;d>0&&!(l>=f[d-1].priority);d--);d===f.length?f[d]=c:f.splice(d,0,c),s.__current.forEach(function(e){e.name===r&&e.currentIndex>=d&&e.currentIndex++})}else s[r]={handlers:[c],runs:0};"hookAdded"!==r&&e.doAction("hookAdded",r,i,a,l)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}}},11:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(){var r,n,o=e[t];return null!==(r=null===(n=o.__current[o.__current.length-1])||void 0===n?void 0:n.name)&&void 0!==r?r:null}}},5375:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(7395);const o=function(e,t){return function(r){var o=e[t];if((0,n.A)(r))return o[r]&&o[r].runs?o[r].runs:0}}},3561:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r){var n=e[t];return void 0===r?void 0!==n.__current[0]:!!n.__current[0]&&r===n.__current[0].name}}},8830:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r,n){var o=e[t];return void 0!==n?r in o&&o[r].handlers.some(function(e){return e.namespace===n}):r in o}}},7765:(e,t,r)=>{"use strict";r.d(t,{A:()=>u});var n=r(3029),o=r(7521),i=r(4194),a=r(8830),l=r(6763),s=r(11),c=r(3561),d=r(5375),f=function e(){(0,n.A)(this,e),this.actions=Object.create(null),this.actions.__current=[],this.filters=Object.create(null),this.filters.__current=[],this.addAction=(0,o.A)(this,"actions"),this.addFilter=(0,o.A)(this,"filters"),this.removeAction=(0,i.A)(this,"actions"),this.removeFilter=(0,i.A)(this,"filters"),this.hasAction=(0,a.A)(this,"actions"),this.hasFilter=(0,a.A)(this,"filters"),this.removeAllActions=(0,i.A)(this,"actions",!0),this.removeAllFilters=(0,i.A)(this,"filters",!0),this.doAction=(0,l.A)(this,"actions"),this.applyFilters=(0,l.A)(this,"filters",!0),this.currentAction=(0,s.A)(this,"actions"),this.currentFilter=(0,s.A)(this,"filters"),this.doingAction=(0,c.A)(this,"actions"),this.doingFilter=(0,c.A)(this,"filters"),this.didAction=(0,d.A)(this,"actions"),this.didFilter=(0,d.A)(this,"filters")};const u=function(){return new f}},4194:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(6956),o=r(7395);const i=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(i,a){var l=e[t];if((0,o.A)(i)&&(r||(0,n.A)(a))){if(!l[i])return 0;var s=0;if(r)s=l[i].handlers.length,l[i]={runs:l[i].runs,handlers:[]};else for(var c=l[i].handlers,d=function(e){c[e].namespace===a&&(c.splice(e,1),s++,l.__current.forEach(function(t){t.name===i&&t.currentIndex>=e&&t.currentIndex--}))},f=c.length-1;f>=0;f--)d(f);return"hookRemoved"!==i&&e.doAction("hookRemoved",i,a),s}}}},6763:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var o=e[t];o[n]||(o[n]={handlers:[],runs:0}),o[n].runs++;for(var i=o[n].handlers,a=arguments.length,l=new Array(a>1?a-1:0),s=1;s{"use strict";r.d(t,{se:()=>n});var n=(0,r(7765).A)();n.addAction,n.addFilter,n.removeAction,n.removeFilter,n.hasAction,n.hasFilter,n.removeAllActions,n.removeAllFilters,n.doAction,n.applyFilters,n.currentAction,n.currentFilter,n.doingAction,n.doingFilter,n.didAction,n.didFilter,n.actions,n.filters},7395:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The hook name must be a non-empty string."),!1):/^__/.test(e)?(console.error("The hook name cannot begin with `__`."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(e)||(console.error("The hook name can only contain numbers, letters, dashes, periods and underscores."),!1)}},6956:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The namespace must be a non-empty string."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(e)||(console.error("The namespace can only contain numbers, letters, dashes, periods, underscores and slashes."),!1)}},772:(e,t,r)=>{"use strict";r.d(t,{h:()=>c});var n=r(4467),o=r(5397);function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,n)}return r}function a(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:"default";n.data[t]=a(a(a({},l),n.data[t]),e),n.data[t][""]=a(a({},l[""]),n.data[t][""])},f=function(e,t){d(e,t),c()},u=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",t=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;return n.data[e]||d(void 0,e),n.dcnpgettext(e,t,r,o,i)},m=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},_=function(e,t,n){var o=u(n,t,e);return r?(o=r.applyFilters("i18n.gettext_with_context",o,e,t,n),r.applyFilters("i18n.gettext_with_context_"+m(n),o,e,t,n)):o};if(e&&f(e,t),r){var p=function(e){s.test(e)&&c()};r.addAction("hookAdded","core/i18n",p),r.addAction("hookRemoved","core/i18n",p)}return{getLocaleData:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[e]},setLocaleData:f,resetLocaleData:function(e,t){n.data={},n.pluralForms={},f(e,t)},subscribe:function(e){return i.add(e),function(){return i.delete(e)}},__:function(e,t){var n=u(t,void 0,e);return r?(n=r.applyFilters("i18n.gettext",n,e,t),r.applyFilters("i18n.gettext_"+m(t),n,e,t)):n},_x:_,_n:function(e,t,n,o){var i=u(o,void 0,e,t,n);return r?(i=r.applyFilters("i18n.ngettext",i,e,t,n,o),r.applyFilters("i18n.ngettext_"+m(o),i,e,t,n,o)):i},_nx:function(e,t,n,o,i){var a=u(i,o,e,t,n);return r?(a=r.applyFilters("i18n.ngettext_with_context",a,e,t,n,o,i),r.applyFilters("i18n.ngettext_with_context_"+m(i),a,e,t,n,o,i)):a},isRTL:function(){return"rtl"===_("ltr","text direction")},hasTranslation:function(e,t,o){var i,a,l=t?t+""+e:e,s=!(null===(i=n.data)||void 0===i||null===(a=i[null!=o?o:"default"])||void 0===a||!a[l]);return r&&(s=r.applyFilters("i18n.has_translation",s,e,t,o),s=r.applyFilters("i18n.has_translation_"+m(o),s,e,t,o)),s}}}},5839:(e,t,r)=>{"use strict";r.d(t,{__:()=>a});var n=r(772),o=r(2133),i=(0,n.h)(void 0,void 0,o.se),a=(i.getLocaleData.bind(i),i.setLocaleData.bind(i),i.resetLocaleData.bind(i),i.subscribe.bind(i),i.__.bind(i));i._x.bind(i),i._n.bind(i),i._nx.bind(i),i.isRTL.bind(i),i.hasTranslation.bind(i)},9575:(e,t,r)=>{"use strict";r.d(t,{__:()=>n.__}),r(181),r(772);var n=r(5839)},181:(e,t,r)=>{"use strict";var n=r(8616),o=r.n(n);r(7604),o()(console.error)},1105:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addonError:()=>u,afterAddonInstall:()=>f,extractErrorFromAddOnResponse:()=>d,toggleAddonState:()=>c});var n=r(9575);function o(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,i,a,l=[],s=!0,c=!1;try{if(i=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;s=!1}else for(;!(s=(n=i.call(r)).done)&&(l.push(n.value),l.length!==t);s=!0);}catch(e){c=!0,o=e}finally{try{if(!s&&null!=r.return&&(a=r.return(),Object(a)!==a))return}finally{if(c)throw o}}return l}}(e,t)||function(e,t){if(e){if("string"==typeof e)return i(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?i(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r5&&void 0!==arguments[5]?arguments[5]:"frm_activate_addon",d=frm_admin_js,f=document.querySelectorAll(".frm-addon-status");f.forEach(function(t){t.textContent=e,t.style.display="block"}),t.css({opacity:"0"}),document.querySelectorAll(".frm-oneclick").forEach(function(e){e.style.display="none"}),function(){var e=document.getElementById("frm_upgrade_modal");if(e){e.classList.add("frm-success");var t=e.querySelector(".frm-upgrade-message");if(t){var r=t.querySelector("img");t.replaceChildren((0,n.__)("Great! Everything's ready to go!","formidable"),document.createElement("br"),(0,n.__)("You just need to refresh the builder so the new field becomes available.","formidable")),r&&t.append(r)}var o=document.querySelector(".frm-addon-status");o&&(o.textContent="");var i,a=e.querySelector(".frm-circled-icon");if(a)a.classList.add("frm-circled-icon-green"),null===(i=a.querySelector("svg"))||void 0===i||i.replaceWith(s({href:"#frm_checkmark_icon"}))}}();var u={frm_activate_addon:{class:"frm-addon-active",message:d.active},frm_deactivate_addon:{class:"frm-addon-installed",message:d.installed},frm_uninstall_addon:{class:"frm-addon-not-installed",message:d.not_installed}};u.frm_install_addon=u.frm_activate_addon;var _=o(r,1)[0];_&&(_.textContent=u[c].message);var p=o(i,1)[0].parentElement;p.classList.remove("frm-addon-not-installed","frm-addon-installed","frm-addon-active"),p.classList.add(u[c].class),o(t,1)[0].classList.remove("frm_loading_button"),document.querySelectorAll(".frm-admin-page-import, #frm-admin-smtp, #frm-welcome").length>0?window.location.reload():["settings","form_builder"].includes(a)&&f.forEach(function(e){var t=null!==e.closest("#frm_upgrade_modal");e.append(function(e,t){var r,o=[m(e)];return t&&o.push(((r=document.createElement("a")).setAttribute("href","#"),r.classList.add("button","button-secondary","frm-button-secondary","dismiss"),r.textContent=(0,n.__)("Not Now","formidable"),r)),l({className:"frm-save-and-reload-options",children:o})}(a,t))})}function u(e,t,r){e.form?(jQuery(".frm-inline-error").remove(),r.closest(".frm-card").html(e.form).css({padding:5}).find("#upgrade").attr("rel",r.attr("rel")).on("click",_)):(t.append('

                  '.concat(e.message,"

                  ")),r.removeClass("frm_loading_button"),jQuery(".frm-addon-error").delay(4e3).fadeOut())}function m(e){var t=document.createElement("button");return t.classList.add("frm-save-and-reload","button","button-primary","frm-button-primary"),t.textContent=(0,n.__)("Save and Reload","formidable"),t.addEventListener("click",function(){var t;"form_builder"===e?((t=document.getElementById("frm_submit_side_top")).classList.contains("frm_submit_ajax")&&t.setAttribute("data-new-addon-installed",!0),t.click()):"settings"===e&&function(){var e=document.getElementById("form_settings_page");if(e){var t=e.querySelector("form.frm_form_settings");null!==t&&(wp.hooks.doAction("frm_reset_fields_updated"),t.submit())}}()}),t}function _(e){e.preventDefault();var t=jQuery(this),r=t.parent().parent(),n=t.attr("rel");t.addClass("frm_loading_button"),jQuery.ajax({url:ajaxurl,type:"POST",async:!0,cache:!1,dataType:"json",data:{action:"frm_install_addon",nonce:frmAdminJs.nonce,plugin:n,hostname:r.find("#hostname").val(),username:r.find("#username").val(),password:r.find("#password").val()},success:function(e){var n,o,i=d(e=null!==(n=null===(o=e)||void 0===o?void 0:o.data)&&void 0!==n?n:e);i?u(i,r,t):f(e,t,message,r)},error:function(){t.removeClass("frm_loading_button")}})}},4260:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addOneClick:()=>i,initModal:()=>a,initUpgradeModal:()=>l});var n=r(9575),o=frmDom.svg;function i(e,t,r){var i;if("modal"===t)i=document.getElementById("frm_upgrade_modal");else{if("tab"!==t)return;i=document.getElementById(e.getAttribute("href").substr(1))}var a,l=i.querySelector(".frm-oneclick"),s=i.querySelector(".frm-upgrade-message"),c=i.querySelector(".frm-upgrade-link"),d=i.querySelector(".frm-oneclick-button"),f=i.querySelector(".frm-addon-status"),u=e.getAttribute("data-oneclick"),m=e.getAttribute("data-message"),_="block",p="block",g="none",y=i.querySelector(".frm-circled-icon");y&&(y.classList.remove("frm-circled-icon-green"),null===(a=y.querySelector("svg"))||void 0===a||a.replaceWith(o({href:"#frm_filled_lock_icon"})));var v=i.querySelector(".frm-learn-more");if(v&&(v.href=e.dataset.learnMore),null!==l&&null!==d&&void 0!==u&&u){null===m&&(p="none"),_="none",g="block",u=JSON.parse(u),d.className=d.className.replace(" frm-install-addon","").replace(" frm-activate-addon",""),d.className="".concat(d.className," ").concat(u.class),d.rel=u.url,l.textContent=(0,n.__)("This plugin is not activated. Would you like to activate it now?","formidable"),d.textContent=(0,n.__)("Activate","formidable");var h=e.querySelector("use");h&&(null==y||y.querySelector("svg").replaceWith(o({href:h.getAttribute("href")||h.getAttribute("xlink:href"),classList:["frm_svg32"]})))}m||(m=s.getAttribute("data-default")),void 0!==r&&(m=m.replace('',r)),s.innerHTML=m,e.dataset.upsellImage&&s.append(frmDom.img({src:e.dataset.upsellImage,alt:e.dataset.upgrade})),c.href=function(e,t){var r=e.getAttribute("data-link");return null!=r&&""!==r||(r=t.getAttribute("data-default")),r}(e,c),f.style.display="none",l&&(l.style.display=g),d&&(d.style.display="block"===g?"inline-block":g),s.style.display=p,c.style.display="block"===_?"inline-block":_;var b=c.closest(".frm-upgrade-modal-actions");b&&(b.style.display="block"===_?"flex":_)}function a(e,t){var r=jQuery(e);if(!r.length)return!1;void 0===t&&(t="552px");var n={dialogClass:"frm-dialog",modal:!0,autoOpen:!1,closeOnEscape:!0,width:t,resizable:!1,draggable:!1,open:function(){var e,t;jQuery(".ui-dialog-titlebar").addClass("frm_hidden").removeClass("ui-helper-clearfix"),jQuery("#wpwrap").addClass("frm_overlay"),jQuery(".frm-dialog").removeClass("ui-widget ui-widget-content ui-corner-all"),r.removeClass("ui-dialog-content ui-widget-content"),e=r,t=function(){e.dialog("close")},jQuery(".ui-widget-overlay").on("click",t),e.on("click","a.dismiss",t)},close:function(){jQuery("#wpwrap").removeClass("frm_overlay"),jQuery(".spinner").css("visibility","hidden"),this.removeAttribute("data-option-type");var e=document.getElementById("bulk-option-type");e&&(e.value="")}};return r.dialog(n),r}function l(){var e=a("#frm_upgrade_modal");function t(t){var r,o,a;if((r=t.target).classList){var l=r.classList.contains("frm_show_expired_modal")||null!==r.querySelector(".frm_show_expired_modal")||r.closest(".frm_show_expired_modal");if("change"===t.type&&r.classList.contains("frm_select_with_upgrade")){var s=r.options[r.selectedIndex];s&&s.dataset.upgrade&&(r=s)}if(!r.dataset.upgrade){var c=r.closest("[data-upgrade]");if(!c){if(!(c=r.closest(".frm_field_box")))return;r.dataset.upgrade=""}r=c}if(l)wp.hooks.doAction("frm_show_expired_modal",r);else{var d=r.dataset.upgrade;if(d&&!r.classList.contains("frm_show_upgrade_tab")){t.preventDefault();var f=e.get(0);f.classList.remove("frm-success");var u=f.querySelector(".frm_lock_icon");u&&(u.style.display="block",u.classList.remove("frm_lock_open_icon"),u.querySelector("use").setAttribute("href","#frm_lock_icon"));var m="frm_upgrade_modal_image",_=document.getElementById(m);_&&_.remove(),r.dataset.image&&u&&(u.style.display="none",u.parentNode.insertBefore(frmDom.img({id:m,src:"".concat(frmGlobal.url,"/images/").concat(r.dataset.image)}),u));var p=f.querySelector(".license-level");p&&(p.textContent=function(e){return e.dataset.requires?e.dataset.requires:"Pro"}(r)),i(r,"modal",d);var g=f.querySelector(".frm_are_not_installed");g.style.display=r.dataset.image||r.dataset.oneclick?"none":"inline-block",g.textContent=g.dataset.default,f.querySelector(".frm-upgrade-modal-title-prefix").style.display=r.dataset.oneclick?"inline":"none",f.querySelector(".frm_feature_label").textContent=d,f.querySelector(".frm-upgrade-modal-title-suffix").style.display="none",f.querySelector("h2").style.display="block",e.dialog("open");var y=f.querySelector(".button-primary:not(.frm-oneclick-button)");o=y.getAttribute("href").replace(/(medium=)[a-z_-]+/gi,"$1".concat(r.getAttribute("data-medium"))),null===(a=r.getAttribute("data-content"))&&(a=""),o=o.replace(/(content=)[a-z_-]+/gi,"$1".concat(a)),y.setAttribute("href",o),r.classList.contains("frm_show_update")&&function(e){var t=e.querySelector(".frm-upgrade-modal-title-prefix");t&&(t.style.display="none");var r=e.querySelector(".frm_are_not_installed");r&&(r.textContent=(0,n.__)("require an update","formidable"),r.style.display="");var o=e.querySelector(".frm-oneclick");o&&(o.style.display="none");var i=e.querySelector(".frm-oneclick-button");i&&(i.textContent=(0,n.__)("Update Now","formidable"))}(f)}}}}!1!==e&&(document.addEventListener("click",t),frmDom.util.documentOn("change","select.frm_select_with_upgrade",t))}},8616:e=>{e.exports=function(e,t){var r,n,o=0;function i(){var i,a,l=r,s=arguments.length;e:for(;l;){if(l.args.length===arguments.length){for(a=0;a{var n;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function i(e){return function(e,t){var r,n,a,l,s,c,d,f,u,m=1,_=e.length,p="";for(n=0;n<_;n++)if("string"==typeof e[n])p+=e[n];else if("object"==typeof e[n]){if((l=e[n]).keys)for(r=t[m],a=0;a=0),l.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,l.width?parseInt(l.width):0);break;case"e":r=l.precision?parseFloat(r).toExponential(l.precision):parseFloat(r).toExponential();break;case"f":r=l.precision?parseFloat(r).toFixed(l.precision):parseFloat(r);break;case"g":r=l.precision?String(Number(r.toPrecision(l.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=l.precision?r.substring(0,l.precision):r;break;case"t":r=String(!!r),r=l.precision?r.substring(0,l.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=l.precision?r.substring(0,l.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=l.precision?r.substring(0,l.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}o.json.test(l.type)?p+=r:(!o.number.test(l.type)||f&&!l.sign?u="":(u=f?"+":"-",r=r.toString().replace(o.sign,"")),c=l.pad_char?"0"===l.pad_char?"0":l.pad_char.charAt(1):" ",d=l.width-(u+r).length,s=l.width&&d>0?c.repeat(d):"",p+=l.align?u+r+s:"0"===c?u+s+r:s+u+r)}return p}(function(e){if(l[e])return l[e];for(var t,r=e,n=[],i=0;r;){if(null!==(t=o.text.exec(r)))n.push(t[0]);else if(null!==(t=o.modulo.exec(r)))n.push("%");else{if(null===(t=o.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){i|=1;var a=[],s=t[2],c=[];if(null===(c=o.key.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(c[1]);""!==(s=s.substring(c[0].length));)if(null!==(c=o.key_access.exec(s)))a.push(c[1]);else{if(null===(c=o.index_access.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(c[1])}t[2]=a}else i|=2;if(3===i)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return l[e]=n}(e),arguments)}function a(e,t){return i.apply(null,[e].concat(t||[]))}var l=Object.create(null);"undefined"!=typeof window&&(window.sprintf=i,window.vsprintf=a,void 0===(n=function(){return{sprintf:i,vsprintf:a}}.call(t,r,t,e))||(e.exports=n))}()},5397:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(1364),o={contextDelimiter:"",onMissingKey:null};function i(e,t){var r;for(r in this.data=e,this.pluralForms={},this.options={},o)this.options[r]=void 0!==t&&r in t?t[r]:o[r]}i.prototype.getPluralForm=function(e,t){var r,o,i,a=this.pluralForms[e];return a||("function"!=typeof(i=(r=this.data[e][""])["Plural-Forms"]||r["plural-forms"]||r.plural_forms)&&(o=function(e){var t,r,n;for(t=e.split(";"),r=0;r{"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}r.d(t,{A:()=>n})},4467:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(9922);function o(e,t,r){return(t=(0,n.A)(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}},2327:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(2284);function o(e,t){if("object"!=(0,n.A)(e)||!e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var o=r.call(e,t||"default");if("object"!=(0,n.A)(o))return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}},9922:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(2284),o=r(2327);function i(e){var t=(0,o.A)(e,"string");return"symbol"==(0,n.A)(t)?t:t+""}},2284:(e,t,r)=>{"use strict";function n(e){return n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(e)}r.d(t,{A:()=>n})}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var i=t[n]={exports:{}};return e[n](i,i.exports,r),i.exports}function n(e){return function(e){if(Array.isArray(e))return i(e)}(e)||function(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)}(e)||o(e)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function o(e,t){if(e){if("string"==typeof e)return i(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?i(e,t):void 0}}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},window.FrmFormsConnect=window.FrmFormsConnect||function(e,t,r){var n={messageBox:null,reset:null,setElements:function(){n.messageBox=e.querySelector(".frm_pro_license_msg"),n.reset=e.getElementById("frm_reconnect_link")}},o={init:function(){n.setElements(),r(e.getElementById("frm_deauthorize_link")).on("click",o.deauthorize),r(".frm_authorize_link").on("click",o.authorize),r(".frm-dashboard-license-options").on("click","#frm_deauthorize_link",o.deauthorize),r(".frm-dashboard-license-options").on("click","#frm_reconnect_link",o.reauthorize),null!==n.reset&&r(n.reset).on("click",o.reauthorize)},authorize:function(){var t=this,n=this.getAttribute("data-plugin"),i=e.getElementById("edd_".concat(n,"_license_key")),a=i.value,l=e.getElementById("proplug-wpmu");this.classList.add("frm_loading_button"),l=l&&l.checked?1:0,r.ajax({type:"POST",url:ajaxurl,dataType:"json",data:{action:"frm_addon_activate",license:a,plugin:n,wpmu:l,nonce:frmGlobal.nonce},success:function(e){o.afterAuthorize(e,i),t.classList.remove("frm_loading_button")}})},afterAuthorize:function(e,t){!0===e.success&&(t.value="•••••••••••••••••••"),wp.hooks.doAction("frm_after_authorize",e),o.showMessage(e)},showProgress:function(e){null===n.messageBox&&n.setElements();var t=n.messageBox;null!==t&&(!0===e.success?(t.classList.remove("frm_error_style"),t.classList.add("frm_message","frm_updated_message")):(t.classList.add("frm_error_style"),t.classList.remove("frm_message","frm_updated_message")),t.classList.remove("frm_hidden"),t.innerHTML=e.message)},showMessage:function(r){null===n.messageBox&&n.setElements();var i=n.messageBox;!0===r.success&&(o.showAuthorized(!0),o.showInlineSuccess(),wp.hooks.doAction("frmAdmin.afterLicenseAuthorizeSuccess",{msg:r})),o.showProgress(r),""!==r.message&&(setTimeout(function(){i.innerHTML="",i.classList.add("frm_hidden"),i.classList.remove("frm_error_style","frm_message","frm_updated_message")},1e4),e.querySelector(".frm-admin-page-dashboard")&&setTimeout(function(){t.location.reload()},1e3))},showAuthorized:function(t){var r=t?"unauthorized":"authorized",n=t?"authorized":"unauthorized",o=e.querySelectorAll(".frm_".concat(r,"_box"));o.length&&o.forEach(function(e){e.className=e.className.replace("frm_".concat(r,"_box"),"frm_".concat(n,"_box"))})},showInlineSuccess:function(){var t=e.querySelectorAll(".frm-confirm-msg [data-success]");t.length&&t.forEach(function(e){e.innerHTML=frmAdminBuild.purifyHtml(e.getAttribute("data-success"))})},reauthorize:function(){return this.innerHTML='',r.ajax({type:"POST",url:ajaxurl,dataType:"json",data:{action:"frm_reset_cache",plugin:"formidable_pro",nonce:frmGlobal.nonce},success:function(e){n.reset.textContent=e.message,"1"===n.reset.getAttribute("data-refresh")&&t.location.reload()}}),!1},deauthorize:function(){if(!confirm(frmGlobal.deauthorize))return!1;var t=this.getAttribute("data-plugin"),n=e.getElementById("edd_".concat(t,"_license_key")),i=n.value,a=this;return this.innerHTML='',r.ajax({type:"POST",url:ajaxurl,data:{action:"frm_addon_deactivate",license:i,plugin:t,nonce:frmGlobal.nonce},success:function(){o.showAuthorized(!1),n.value="",a.replaceWith("Disconnected"),wp.hooks.doAction("frmAdmin.afterLicenseDeauthorizeSuccess",{})}}),!1}};return o}(document,window,jQuery),window.frmAdminBuildJS=function(){var e,t,i=frm_admin_js,l=frmDom,s=l.tag,c=l.div,d=l.span,f=l.a,u=l.svg,m=l.img,_=frmDom.util.onClickPreventDefault,p=frmDom.ajax.doJsonPost;i.contextualShortcodes=(t=null===(e=document.getElementById("frm_adv_info"))||void 0===e?void 0:e.dataset.contextualShortcodes)?((t=JSON.parse(t)).addressSelector="[id^=email_to], [id^=from_], [id^=cc], [id^=bcc]",t.bodySelector="[id^=email_message_]",t):[];var g,y,v,h={save:u({href:"#frm_save_icon"}),drag:u({href:"#frm_drag_icon",classList:["frm_drag_icon","frm-drag"]})},b=jQuery(document.getElementById("frm-show-fields")),j=document.getElementById("new_fields"),w=document.getElementById("form_id"),Q=!1,x=0,E=0,k=0,A={},S=0,L=wp.i18n,I=L.__,B=L.sprintf,q={dragging:!1};w&&(E=w.value);var C,N=new URL(window.location.href),T=N.searchParams,O=document.getElementById("frm_builder_page");function F(e){e.stopPropagation(),e.preventDefault(),D(this)}function D(e){var t=e.getAttribute("data-frmverify"),r=e.getAttribute("data-loaded-from");return null===t||"frm-confirmed-click"===e.id||("entries-list"===r?wp.hooks.applyFilters("frm_on_multiple_entries_delete",{link:e,initModal:Bi}):function(e){var t=Bi("#frm_confirm_modal","400px"),r=document.getElementById("frm-confirmed-click");if(!1===t)return!1;r&&(r.style.display="block");var n=e.getAttribute("data-frmverify"),o=n?e.getAttribute("data-frmverify-btn"):"",i=jQuery(".frm-confirm-msg");i.empty(),n&&(i.append(document.createTextNode(n)),o&&(null==r||r.classList.add(o)));var a=e.dataset;if(r){for(var l in r.dataset)r.removeAttribute("data-".concat(l));for(var s in a)"frmverify"!==s&&r.setAttribute("data-".concat(s),a[s])}return wp.hooks.doAction("frmAdmin.beforeOpenConfirmModal",{$info:t,link:e}),t.dialog("open"),null==r||r.setAttribute("href",e.getAttribute("href")||e.getAttribute("data-href")),!1}(e))}function M(e){var t=Bi("#frm_info_modal","400px");return!1===t||(jQuery(".frm-info-msg").html(e),t.dialog("open")),!1}function P(e){var t=this.getAttribute("data-frmtoggle"),r=this.getAttribute("data-toggletext"),n=jQuery(t);return e.preventDefault(),n.toggle(),null!==r&&""!==r&&(this.setAttribute("data-toggletext",this.innerHTML),this.textContent=r),!1}function H(e){var t=this.getAttribute("data-frmhide"),r=this.getAttribute("data-frmshow"),n=this.getAttribute("data-frmuncheck"),o=n?n.split(","):[];"INPUT"!==this.nodeName||"checkbox"!==this.type||this.checked||(null!==t?(r=t,t=null):null!==r&&(t=r,r=null)),e.preventDefault();var i=this.getAttribute("data-toggleclass")||"frm_hidden";null!==t&&jQuery(t).addClass(i),null!==r&&jQuery(r).removeClass(i);var a=this.parentNode.querySelectorAll("a.current");if(null!==a){for(var l=0;l1&&(e="",t=""):0===o.indexOf("frm_postmeta_")&&(jQuery("#frm_postmeta_rows .frm_postmeta_row").length<2&&(e=".frm_add_postmeta_row.button"),jQuery(".frm_toggle_cf_opts").length&&jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(o,")")).last().length&&(""!==e&&(e+=","),e+="#".concat(jQuery("#frm_postmeta_rows .frm_postmeta_row:not(#".concat(o,")")).last().attr("id")," .frm_toggle_cf_opts")));var i=document.getElementById(o),a=jQuery(i);return a.fadeOut(300,function(){var r;a.remove(),Po(),""!==t&&jQuery(t).hide(),""!==e&&jQuery("".concat(e," a,").concat(e)).removeClass("frm_hidden").fadeIn("slow"),this.closest(".frm_form_action_settings")&&function(e){so(e);var t={type:e};wp.hooks.doAction("frm_after_action_removed",t)}(this.closest(".frm_form_action_settings").querySelector(".frm_action_name").value),null===(r=document.querySelector(".tooltip"))||void 0===r||r.remove()}),void 0!==r&&(r=jQuery(r)).fadeOut(400,function(){r.remove()}),""!==e&&jQuery(this).closest(".frm_logic_rows").fadeOut("slow"),wp.hooks.doAction("frm_admin_tag_removed",o,i),!1}}function G(e,t){void 0===t&&(t=this),Ze(t,!1);var r=jQuery(t).closest(".frm_form_action_settings"),n=e.target;if(r.length&&void 0!==n){var o=n.parentElement.className;if("string"==typeof o&&(o.includes("frm_email_icons")||o.includes("frm_toggle")))return void e.stopPropagation()}var i=r.children(".widget-inside");if(r.length&&i.find("p, div, table").length<1){var a=r.find('input[name$="[ID]"]').val(),l=r.find('input[name$="[post_excerpt]"]').val();l&&(i.html(''),r.find(".spinner").fadeIn("slow"),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_form_action_fill",action_id:a,action_type:l,nonce:frmGlobal.nonce},success:function(e){i.html(e),ci(),Xn("#".concat(r.attr("id"))),yi(i),jQuery(t).trigger("frm-action-loaded"),wp.hooks.doAction("frm_filled_form_action",i)}}))}jQuery(t).closest(".frm_field_box").siblings().find(".widget-inside").slideUp("fast"),void 0!==t.className&&t.className.includes("widget-action")||jQuery(t).closest(".start_divider").length<1||((i=jQuery(t).closest("div.widget").children(".widget-inside")).is(":hidden")?i.slideDown("fast"):i.slideUp("fast"))}function U(){var e=this.getAttribute("href");if(void 0===e)return!1;var t=e.replace("#","."),r=jQuery(this);r.closest("li").addClass("frm-tabs active").siblings("li").removeClass("frm-tabs active starttab"),r.closest("div").children(".tabs-panel").not(e).not(t).hide();var n=document.getElementById(e.replace("#",""));return n&&(n.style.display="block"),"frm_insert_fields_tab"!==this.id||this.closest("#frm_adv_info")||$e(),!1}function W(e,t){var r=(e=jQuery(e)).attr("href");if(void 0!==r){var n,o,i=r.replace("#",".");if(e.closest("li").addClass("frm-tabs active").siblings("li").removeClass("frm-tabs active starttab"),e.closest("div").find(".tabs-panel").length)e.closest("div").children(".tabs-panel").not(r).not(i).hide();else if(null!==document.getElementById("form_global_settings")){var a=e.data("frmajax");e.closest(".frm_wrap").find(".tabs-panel, .hide_with_tabs").hide(),void 0!==a&&"1"==a&&(n=r.replace("#",""),(o=jQuery(".frm_".concat(n,"_ajax"))).length&&jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_settings_tab",tab:n.replace("_settings",""),nonce:frmGlobal.nonce},success:function(e){o.replaceWith(e)}}))}else jQuery("#frm-categorydiv .tabs-panel, .hide_with_tabs").hide();jQuery(r).show(),jQuery(i).show(),$o(),"auto"!==t&&(jQuery(".frm_updated_message").hide(),jQuery(".frm_warning_style").hide()),jQuery(e).closest("#frm_adv_info").length||(jQuery(".frm_form_settings").length?jQuery(".frm_form_settings").attr("action","?page=formidable&frm_action=settings&id=".concat(jQuery('.frm_form_settings input[name="id"]').val(),"&t=").concat(r.replace("#",""))):jQuery(".frm_settings_form").attr("action","?page=formidable-settings&t=".concat(r.replace("#",""))))}}function V(e){var t,r;document.querySelectorAll(e).forEach(function(e){$(e),Array.from(e.children).forEach(function(e){return X(e,".frm-move")});var t=jQuery(e).children('[data-type="divider"]').children(".divider_section_only");t.length&&$(t)}),t=jQuery("#frm_builder_page"),r={items:".frm_sortable_field_opts li",axis:"y",opacity:.65,forcePlaceholderSize:!1,handle:".frm-drag",helper:function(e,t){return Q=t.clone().insertAfter(t),t.clone()},stop:function(e,t){Q&&Q.remove(),on(t.item.attr("id").replace("frm_delete_field_","").replace("-".concat(t.item.data("optkey"),"_container"),"")),Po()}},jQuery(t).sortable(r)}function $(e){jQuery(e).droppable({accept:".frmbutton, li.frm_field_box",deactivate:re,over:K,out:J,tolerance:"pointer"})}function K(e,t){var r=function(e){return e.classList.contains("divider_section_only")&&(e=jQuery(e).nextAll(".start_divider.frm_sorting").get(0)),e}(e.target);if(!je(t.draggable[0],r,e))return r.classList.remove("frm-over-droppable"),void jQuery(r).parents("ul.frm_sorting").addClass("frm-over-droppable");document.querySelectorAll(".frm-over-droppable").forEach(function(e){return e.classList.remove("frm-over-droppable")}),r.classList.add("frm-over-droppable"),jQuery(r).parents("ul.frm_sorting").addClass("frm-over-droppable")}function J(e){e.target.classList.remove("frm-over-droppable")}function X(e,t){var r={helper:Y,revert:"invalid",delay:10,start:Z,stop:ee,drag:te,cursor:"grabbing",refreshPositions:!0,cursorAt:{top:0,left:90}};"string"==typeof t&&(r.handle=t),jQuery(e).draggable(r)}function Y(e){var t,r=e.delegateTarget;if(Qe(r)){var n=document.getElementById("frm-insert-fields").querySelector(".frm_ttext").cloneNode(!0);return n.querySelector("use").setAttributeNS("http://www.w3.org/1999/xlink","href","#frm_field_group_layout_icon"),n.querySelector("span").textContent=I("Field Group","formidable"),n.classList.add("frm_field_box"),n.classList.add("ui-sortable-helper"),n}if(r.classList.contains("frmbutton"))return(t=r.cloneNode(!0)).classList.add("ui-sortable-helper"),r.classList.add("frm-new-field"),t;if(r.hasAttribute("data-ftype")){var o=r.getAttribute("data-ftype");if(t=document.getElementById("frm-insert-fields").querySelector(".frm_t".concat(o)))return(t=t.cloneNode(!0)).classList.add("form-field"),t.classList.add("ui-sortable-helper"),t.cloneNode(!0)}return c({className:"frmbutton"})}function Z(e,t){if(e.target.classList.contains("frm_at_limit"))return Se(),!1;q.dragging=!0;var r,n=y;n.classList.add("frm-dragging-field"),document.body.classList.add("frm-dragging"),t.helper.addClass("frm-sortable-helper"),t.helper.initialOffset=n.scrollTop,e.target.classList.add("frm-drag-fade"),yr(),(r=document.querySelectorAll("ul.start_divider")).length&&r.forEach(function(e){[].slice.call(e.children).forEach(function(e){(0===e.children.length||1===e.children.length&&"ul"===e.firstElementChild.nodeName.toLowerCase()&&0===e.firstElementChild.children.length)&&e.remove()})}),Fe(),Ne(),z()}function ee(){y.classList.remove("frm-dragging-field"),document.body.classList.remove("frm-dragging");var e=document.querySelector(".frm-drag-fade");e&&e.classList.remove("frm-drag-fade")}function te(e,t){!function(e){v.scrollTop(function(t,r){var n=e.clientY,o=y.offsetHeight,i=e.clientY-y.offsetTop,a=i-o/2;return i>o-50&&n>5?r+.1*a:i<70&&n<130?r-Math.abs(.1*a):r})}(e);var r=e.target,n=function(){for(var e=document.getElementById("frm-show-fields");e.querySelector(".frm-over-droppable");)e=e.querySelector(".frm-over-droppable");return"frm-show-fields"!==e.id||e.classList.contains("frm-over-droppable")||(e=!1),e}(),o=document.getElementById("frm_drag_placeholder");if(je(r,n,e)){o||(o=s("li",{id:"frm_drag_placeholder",className:"sortable-placeholder"}));var i,a=t.helper.get(0);if((a.classList.contains("form-field")||a.classList.contains("frm_field_box"))&&(a.style.transform="translateY(".concat((i=t.helper,y.scrollTop-i.initialOffset),"px)")),"frm-show-fields"===n.id||n.classList.contains("start_divider"))return o.style.left=0,void function(e){var t,r=e.y,n=e.placeholder,o=jQuery(e.droppable),i=o.children().not(".edit_field_type_end_divider");if(0===i.length)o.prepend(n),t=0;else{var a=ne(o,r);if(a===i.length){var l=jQuery(i.get(a-1));t=l.offset().top+l.outerHeight(),o.append(n);var s=o.children(".edit_field_type_end_divider");s.length&&o.append(s)}else t=jQuery(i.get(a)).offset().top,jQuery(i.get(a)).before(n)}t-=o.offset().top,n.style.top="".concat(t,"px")}({droppable:n,y:e.clientY,placeholder:o});o.style.top="",function(e){var t,r=e.x,n=e.placeholder,o=jQuery(e.droppable),i=ie(o);if(i.length){var a=function(e,t){var r,n,o,i,a=ie(e);for(i=0,r=a.length-1;r>=0;--r)if(n=a.get(r),t>(o=jQuery(n).offset().left)){i=r,t>o+jQuery(n).outerWidth()/2&&(i=r+1);break}return i}(o,r);if(a===i.length){var l=jQuery(i.get(a-1));t=l.offset().left+l.outerWidth(),o.append(n)}else t=jQuery(i.get(a)).offset().left,jQuery(i.get(a)).before(n),t-=0===a?4:8;t-=o.offset().left,n.style.left="".concat(t,"px")}}({droppable:n,x:e.clientX,placeholder:o})}else o&&o.remove()}function re(e,t){if(q.dragging){q.dragging=!1;var r=t.draggable[0],n=document.getElementById("frm_drag_placeholder");if(!n)return t.helper.remove(),void g();!function(e){if(e.previousElementSibling&&e.previousElementSibling.classList.contains("frm-is-collapsed")){var t=jQuery(e).prevUntil('[data-type="break"]');if(t.length){var r=t.find(".frm-collapse-page").get(0);r&&r.click()}}}(n);var o=t.helper.parent(),i=t.helper.get(0).closest("ul.start_divider"),a=n.closest("ul.start_divider");r.classList.contains("frm-new-field")?function(e){if(pe(e))wp.hooks.doAction("frm_stopped_inserting_by_dragging",e);else{var t=document.getElementById("frm_drag_placeholder"),r="".concat(e.replace("|","-"),"_").concat(be()),n=s("li",{id:r,className:"frm-wait frmbutton_loadingnow"}),o=jQuery(n),i=de(jQuery(t)),a=fe(i),l=ue(i);t.parentNode.insertBefore(n,t),t.remove(),ae(o);var c=0;"summary"===e&&(c=jQuery(".frmbutton_loadingnow#".concat(r)).prevAll('li[data-type="break"]').length?1:0),jQuery.ajax({type:"POST",url:ajaxurl,data:_e(e,l,a,c),success:function(t){ge(t,o);var r=ye(t);r&&wp.hooks.doAction("frm_after_field_added_in_form_builder",{field:t,fieldId:r,fieldType:e,form_id:a})},error:he})}}(r.id):(function(e,t){t.parentNode.insertBefore(e,t)}(r,n),function(e){if("UL"===e.nodeName&&!e.classList.contains("start_divider")&&"frm-show-fields"!==e.id){var t=e.closest("li");t&&!t.classList.contains("ui-draggable")&&X(t,".frm-move")}}(n.parentElement));var l=i?parseInt(i.closest(".edit_field_type_divider").getAttribute("data-fid")):0,c=a?parseInt(a.closest(".edit_field_type_divider").getAttribute("data-fid")):0;n.remove(),t.helper.remove();var d=o.length?ie(o):[];!function(e,t){var r;e.length&&(t.length?ae(t.first()):(r=e.get(0).closest("li.frm_field_box"))&&!r.classList.contains("edit_field_type_divider")&&r.remove())}(o,d),function(e,t){0===t.length&&1===ie(jQuery(e.parentNode)).length||ae(jQuery(e))}(r,d),l!==c&&me(jQuery(r),i),g()}}function ne(e,t){var r,n,o,i,a=e.children().not(".edit_field_type_end_divider"),l=a.length;if(!document.querySelector(".frm-has-fields .frm_no_fields"))return 0;for(i=0,r=l-1;r>=0;--r)if(n=a.get(r),t>(o=jQuery(n).offset().top)){i=r,t>o+jQuery(n).outerHeight()/2&&(i=r+1);break}return i}function oe(){document.querySelectorAll("ul#frm-show-fields, ul.start_divider").forEach(function(e){e.childNodes.forEach(function(e){void 0!==e.classList&&(e.classList.contains("edit_field_type_end_divider")||void 0!==e.classList&&e.classList.contains("form-field")&&Ue(e))})}),kn(),document.querySelectorAll(".edit_field_type_end_divider").forEach(function(e){return e.parentNode.append(e)}),document.querySelectorAll("li.form_field_box:not(.form-field)").forEach(function(e){return!e.children.length&&e.remove()}),En();var e=new Event("frm_sync_after_drag_and_drop",{bubbles:!1});document.dispatchEvent(e)}function ie(e){var t=jQuery(),r=e.get(0);return r.children?(Array.from(r.children).forEach(function(e){if("none"!==e.style.display){var r=e.classList;!r.contains("form-field")||r.contains("edit_field_type_end_divider")||r.contains("frm-sortable-helper")||(t=t.add(e))}}),t):t}function ae(e,t){var r;void 0===t&&(t="even");var n=e.parent().children("li.form-field, li.frmbutton_loadingnow").not(".edit_field_type_end_divider"),o=n.length,i=["frm_full","frm_half","frm_third","frm_fourth","frm_sixth","frm_two_thirds","frm_three_fourths","frm1","frm2","frm3","frm4","frm5","frm6","frm7","frm8","frm9","frm10","frm11","frm12"];"even"===t&&5!==o?n.each(ce(i,$t(o))):"clear"===t?n.each(ce(i,"")):(r=["left","right","middle","even"].includes(t)?function(e){return Vt(o,t,e)}:function(e){return lr(t[e])},n.each(ce(i,r))),le(e.parent(),n.length)}function le(e,t){if(void 0!==e.offset()){var r=t>=2,n=document.getElementById("frm_field_group_controls");if(!n){if(!r)return;(n=c()).id="frm_field_group_controls",n.setAttribute("role","group"),n.setAttribute("tabindex",0),function(e){var t=document.createElement("span");t.innerHTML='';var r=I("Set Row Layout","formidable");se(t,r),zt(t,r);var n=document.createElement("span");n.innerHTML='',n.classList.add("frm-move");var o=I("Move Field Group","formidable");se(n,o),zt(n,o),e.innerHTML="",e.append(t),e.append(n),e.append(function(){var e=d({className:"dropdown"}),t=f({className:"frm_bstooltip frm-hover-icon frm-dropdown-toggle dropdown-toggle",children:[d({child:u({href:"#frm_thick_more_vert_icon"})}),d({className:"screen-reader-text",text:I("Toggle More Options Dropdown","formidable")})]});frmDom.setAttributes(t,{title:I("More Options","formidable"),"data-bs-toggle":"dropdown","data-bs-container":"body","data-bs-display":"static"}),zt(t,I("More Options","formidable")),e.append(t);var r=c({className:"frm-dropdown-menu dropdown-menu dropdown-menu-right"});return r.setAttribute("role","menu"),e.append(r),e}())}(n),O.append(n)}e.append(n),n.style.display=r?"block":"none"}}function se(e,t){e.setAttribute("data-bs-toggle","tooltip"),e.setAttribute("data-bs-container","body"),e.setAttribute("title",t),e.addEventListener("mouseover",function(){null===e.getAttribute("data-original-title")&&jQuery(e).tooltip()})}function ce(e,t){return function(r){for(var n="function"==typeof t?t(r):t,o=e.length,i=!1,a=0;a0&&document.getElementById("form_id").value!==r||(o.last_row_field_ids=function(){var e=document.querySelector(".edit_field_type_submit");if(!e)return[];for(var t=e.parentNode.children,r=[],n=0;nt.childElementCount-1:i<=jQuery(t.querySelector(".edit_field_type_submit").closest("#frm-show-fields > li")).index()}if(n)return!(t.classList.contains("start_divider")||!we(t.parentElement)&&(!we(t.parentElement.nextElementSibling)||e.parentElement.querySelector("li.frm_field_box:not(.edit_field_type_submit)")));var a=t.classList.contains("start_divider")&&null!==t.closest(".repeat_section"),l=null!==t.closest(".repeat_section");if(a||l){if(e.classList.contains("edit_field_type_gdpr")||"gdpr"===e.id)return!1;if(wp.hooks.applyFilters("frm_deny_drop_in_repeater",!1,e))return!1}if(!a){if(!function(e,t){if(e.length<12)return!0;if(e.length>12)return!1;var r=t.attr("data-fid");return 1===jQuery(e).filter('[data-fid="'.concat(r,'"]')).length}(ie(jQuery(t)),jQuery(e)))return!1;if("divider"===e.id&&t.closest(".start_divider"))return!1}return e.classList.contains("frm-new-field")?function(e,t){var r=e.classList,n=r.contains("frm_tbreak"),o=r.contains("frm_thidden"),i=r.contains("frm_tdivider"),a=r.contains("frm_tform"),l=r.contains("frm_tuser_id");return"frm-show-fields"===t.id||t.classList.contains("start_divider")?!(n||o||i||a)||(!(t.classList.contains("start_divider")||null!==t.closest(".start_divider"))||!a&&!i):!(xe(t)||o||n||l)}(e,t):function(e,t){if(Qe(e))return function(e,t){return!(!t.classList.contains("start_divider")||null!==e.querySelector(".start_divider"))}(e,t);if(e.classList.contains("edit_field_type_break"))return!1;if(t.classList.contains("start_divider"))return function(e){return!e.classList.contains("edit_field_type_form")&&!e.querySelector(".edit_field_type_form")&&!(e.classList.contains("edit_field_type_divider")||e.querySelector(".edit_field_type_divider"))}(e);var r=e.classList.contains("edit_field_type_hidden"),n=e.classList.contains("edit_field_type_user_id");return!r&&!n&&function(e,t){if(xe(t))return!1;if(jQuery(e).children("ul.frm_sorting").not(".start_divider").length>0)return!1;var r=e.classList.contains("edit_field_type_divider")||e.querySelector(".edit_field_type_divider"),n=e.classList.contains("edit_field_type_form");return null===t.closest(".start_divider")||!r&&!n}(e,t)}(e,t)}function we(e){return e&&e.matches("#frm-show-fields > li:last-child")}function Qe(e){return e.classList.contains("frm_field_box")&&!e.classList.contains("form-field")}function xe(e){return null!==e.querySelector(".edit_field_type_break, .edit_field_type_hidden, .edit_field_type_user_id")}function Ee(e){var t=document.getElementById(e),r=jQuery(t),n=[],o=function(e){var t=e.querySelector(".frm_hidden_fdata");e.classList.add("frm_load_now"),null!==t&&n.push(t.innerHTML)};o(t);for(var i=ke(t);i&&n.length<15;)o(i),i=ke(i);jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_load_field",field:n,form_id:E,nonce:frmGlobal.nonce},success:function(e){return function(e,t,r){var n,o;if(0===(e=e.replace(/^\s+|\s+$/g,"")).indexOf("{")){for(n in e=JSON.parse(e)){jQuery("#frm_field_id_".concat(n)).replaceWith(e[n]);var i=document.getElementById("frm_field_id_".concat(n));i&&(i.querySelectorAll("[data-toggle]").forEach(function(e){return e.setAttribute("data-bs-toggle",e.getAttribute("data-toggle"))}),i.querySelectorAll(".frm-dropdown-menu").forEach(function(e){return e.classList.add("dropdown-menu")})),V("#frm_field_id_".concat(n,".edit_field_type_divider ul.frm_sorting")),X(document.getElementById("frm_field_id_".concat(n)))}((o=t.nextAll(".frm_field_loading:not(.frm_load_now)")).length||(o=jQuery(document.getElementById("frm-show-fields")).find(".frm_field_loading:not(.frm_load_now)")).length)&&Ee(o.attr("id")),ci(),Fr(),Ie();var a=new Event("frm_ajax_loaded_field",{bubbles:!1});a.frmFields=r.map(function(e){return JSON.parse(e)}),document.dispatchEvent(a)}else jQuery(".frm_load_now").removeClass(".frm_load_now").html("Error")}(e,r,n)}})}function ke(e){var t;return e.nextElementSibling?e.nextElementSibling:null===(t=e.parentNode)||void 0===t||null===(t=t.closest(".frm_field_box"))||void 0===t||null===(t=t.nextElementSibling)||void 0===t?void 0:t.querySelector(".form-field")}function Ae(){var e=jQuery(this);if(e.hasClass("disabled"))return!1;var t=e.closest(".frmbutton"),r=t.attr("id");if(t.hasClass("frm_at_limit"))return Se(),!1;if(!pe(r)){var n=0;"summary"===r&&(n=b.children('li[data-type="break"]').length>0?1:0);var o=E;return jQuery.ajax({type:"POST",url:ajaxurl,data:_e(r,0,o,n),success:function(e){Le(e);var t=ye(e);t&&wp.hooks.doAction("frm_after_field_added_in_form_builder",{field:e,fieldId:t,fieldType:r,form_id:o})},error:he}),!1}}function Se(){var e=document.querySelector(".frm_wrap");if(e){var t=document.createElement("a");t.setAttribute("data-frmverify",I("This field type has reached its limit.","formidable")),e.append(t),t.click(),t.remove();var r=document.getElementById("frm-confirmed-click");r&&(r.style.display="none")}}function Le(e){document.getElementById("frm_form_editor_container").classList.add("frm-has-fields");var t=Ge(e),r=b[0].querySelector(".edit_field_type_submit");r?jQuery(r.closest(".frm_field_box:not(.form-field)")).before(t):b.append(t),We(e,!0),t.each(function(){$(this.querySelector("ul.frm_sorting")),X(this.querySelector(".form-field"),".frm-move")})}function Ie(){var e=!0,t=document.querySelectorAll(".frmjs_prod_field_opt_cont");b.find("li.edit_field_type_product").length>1&&(e=!1);for(var r=0;r'),o.append(document.createTextNode(" ")),o.append(i),n.append(o),e.append(n)})}(t,!0===e);var r=jQuery(t);r.offset().left>jQuery(window).width()-r.outerWidth()?t.style.left="".concat(-r.outerWidth(),"px"):y&&r.offset().left").addClass("frm_field_box").html(jQuery("
                    ").addClass("frm_grid_container frm_sorting").append(e)))}),r}function Ue(e){var t=s("ul",{className:"frm_grid_container frm_sorting"}),r=s("li",{className:"frm_field_box",child:t});e.replaceWith(r),t.append(e),$(t),X(r,".frm-move")}function We(e,t){var r,n,o=/id="(\S+)"/.exec(e),i=document.getElementById(o[1]),l="#".concat(o[1],".edit_field_type_divider ul.frm_sorting.start_divider"),s=jQuery(l),d=i.getAttribute("data-type");r=e,(n=c()).innerHTML=r,n.querySelectorAll(".form-field").forEach(Ve);var f,u,m=!1;if(Po(),V(l),"quantity"===d&&function(e){var t=e.getAttribute("data-fid"),r=document.getElementById("field_options[product_field_".concat(t,"]"));r&&(rt(r),oo(document.getElementById("frm-single-settings-".concat(t))))}(i),"product"!==d&&"quantity"!==d||Ie(),s.length)s.parent(".frm_field_box").children(".frm_no_section_fields").addClass("frm_block");else{var _=jQuery(i).closest("ul.frm_sorting.start_divider");_.length&&(An(_),m=!0)}e.includes("frm-collapse-page")&&Fr(),u="frm-newly-added",(f=i).classList?f.classList.add(u):f.className+=" ".concat(u),setTimeout(function(){i.classList.remove("frm-newly-added")},1e3);var p,g=i.querySelector("#frm-last-row-fields-order");if(g&&((p=JSON.parse(g.value))&&"object"===a(p)&&Object.keys(p).forEach(function(e){var t=document.querySelector('input[name="field_options[field_order_'.concat(e,']"]'));t&&(t.value=p[e])})),t){var y=i.getBoundingClientRect(),v=document.getElementById("post-body-content");y.top>=0&&y.left>=0&&y.right<=(window.innerWidth||document.documentElement.clientWidth)&&y.bottom<=(window.innerHeight||document.documentElement.clientHeight)||v.scroll({top:v.scrollHeight,left:0,behavior:"smooth"}),!1===m&&An(s)}Ke(),ci(),document.getElementById("frm-show-fields").classList.remove("frm-over-droppable"),function(e){var t=document.getElementById(e);null!=t&&t.dataset.limit&&kr(e)>=t.dataset.limit&&t.classList.add("frm_at_limit")}(d),i.querySelectorAll("[data-toggle]").forEach(function(e){return e.setAttribute("data-bs-toggle",e.getAttribute("data-toggle"))}),i.querySelectorAll(".frm-dropdown-menu").forEach(function(e){return e.classList.add("dropdown-menu")});var h=new Event("frm_added_field",{bubbles:!1});h.frmField=i,h.frmSection=l,h.frmType=d,h.frmToggles=m,document.dispatchEvent(h)}function Ve(e){if(e.dataset.fid){var t=document.getElementById("draft_fields");t&&(""===t.value?t.value=e.dataset.fid:t.value.split(",").includes(e.dataset.fid)||(t.value+=",".concat(e.dataset.fid)))}}function $e(e){jQuery("#new_fields .frm-single-settings").addClass("frm_hidden"),jQuery("#frm-options-panel > .frm-single-settings").removeClass("frm_hidden"),Ke(e)}function Ke(e){jQuery("li.ui-state-default.selected").removeClass("selected"),jQuery(".frm-show-field-settings.selected").removeClass("selected"),e||yr()}function Je(){var e=this.value,t=function(e){var t,r=[],n=e.split(""),o=n.length,a=["{","[","("],l={"}":"{",")":"(","]":"["},s=!1;for(t=0;t0||s?"".concat(i.unmatched_parens,"\n\n"):""}(e);t+=function(e,t){var r=function(e,t){var r="";return function(e){return jQuery(e).siblings('label[for^="calc_type"]').children("input").prop("checked")}(t)||/\[(date|time|email|ip)\]/.test(e)&&(r="".concat(i.text_shortcodes,"\n\n")),r}(e,t);return r+=function(e){var t="";return/\[id\]|\[key\]|\[if\s\w+\]|\[foreach\s\w+\]|\[created-at(\s*)?/g.test(e)&&(t+="".concat(i.view_shortcodes,"\n\n")),t}(e)}(e,this),""!==t&&M("".concat(e,"\n\n").concat(t))}function Xe(e,t){for(var r=!1,n=0;n").concat(l[t].fieldName,""))):(r=r?" checked":"",o.push('"));e.innerHTML=o.join("")}function nt(){for(var e=document.querySelectorAll(".frmjs_prod_field_opt"),t=0;t'):(d.innerHTML=_n(c),"TEXTAREA"===d.nodeName&&d.classList.contains("wp-editor-area")&&jQuery(d).trigger("change"),d.classList.contains("frm_primary_label")&&"break"===d.nextElementSibling.getAttribute("data-ftype")&&(d.nextElementSibling.querySelector(".frm_button_submit").textContent=c)))}function at(e){var t=parseFloat(e.getAttribute("max")),r=parseFloat(e.getAttribute("min"));return(t-r)/2+r}function lt(){var e=this.getAttribute("data-fid"),t="";["field_options_max_","frm_format_"].forEach(function(r){var n=document.getElementById(r+e);n&&(t+=n.value)});var r=document.getElementsByName("field_options[type_".concat(e,"]"))[0];"text"===r.options[r.selectedIndex].value&&ct(""!==t,".frm_invalid_msg".concat(e))}function st(){var e=this.id.replace("frm_","").replace("req_field_",""),t=this.checked,r=jQuery("#field_label_".concat(e," .frm_required"));if(ct(t,".frm_required_details".concat(e)),t){var n=jQuery('input[name="field_options[required_indicator_'.concat(e,']"]'));""===n.val()&&n.val("*"),r.removeClass("frm_hidden")}else r.addClass("frm_hidden")}function ct(e,t){var r=jQuery(t);if(e)r.fadeIn("fast").closest(".frm_validation_msg").fadeIn("fast");else{var n=r.fadeOut("fast").closest(".frm_validation_box"),o=n.css("display","block").children(":not(".concat(t,"):visible")).length;n.css("display",""),0===o&&r.closest(".frm_validation_msg").fadeOut("fast")}}function dt(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=jQuery(".frm_unique_details".concat(e));if(this.checked){t.fadeIn("fast").closest(".frm_validation_msg").fadeIn("fast");var r=jQuery(".frm_unique_details".concat(e," input"));""===r.val()&&r.val(i.default_unique)}else{var n=t.fadeOut("fast").closest(".frm_validation_box"),o=n.css("display","block").children(":not(.frm_unique_details".concat(e,"):visible")).length;n.css("display",""),0===o&&t.closest(".frm_validation_msg").fadeOut("fast")}}function ft(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=jQuery(this).val(),r=jQuery(document.getElementById("frm_field_id_".concat(e)));if(ct(""!==t,".frm_conf_details".concat(e)),""!==t){var n=jQuery(".frm_validation_box .frm_conf_details".concat(e," input"));""===n.val()&&n.val(i.default_conf),function(e){var t=document.getElementsByName("field_options[type_".concat(e,"]"))[0].value;ut(document.getElementById("field_description_".concat(e)),"field_options[description_".concat(e,"]"),i["enter_".concat(t)]),ut(document.getElementById("conf_field_description_".concat(e)),"field_options[conf_desc_".concat(e,"]"),i["confirm_".concat(t)])}(e),"inline"===t?r.removeClass("frm_conf_below").addClass("frm_conf_inline"):"below"===t&&r.removeClass("frm_conf_inline").addClass("frm_conf_below"),jQuery(".frm-conf-box-".concat(e)).removeClass("frm_hidden")}else jQuery(".frm-conf-box-".concat(e)).addClass("frm_hidden"),setTimeout(function(){r.removeClass("frm_conf_inline frm_conf_below")},200)}function ut(e,t,r){e.innerHTML===i.desc&&(e.innerHTML=r,document.getElementsByName(t)[0].value=r)}function mt(e){var t=JSON.parse(this.getAttribute("data-opts"));return e.preventDefault(),document.getElementById("frm_bulk_options").value=t.join("\n"),!1}function _t(){var e,t,r,n=jQuery(this).closest(".frm-single-settings").data("fid"),o=jQuery("#frm_field_".concat(n,"_opts .frm_option_template")).prop("outerHTML"),i=jQuery(this).data("opttype"),a=0,l="000",s=function(e){for(var t=0,r=0,n=jQuery("#frm_field_".concat(e,"_opts li")),o=0;to||"000"===o)&&(o=r)}return o}(n);if(s!==l&&(a=s+1),"other"===i){document.getElementById("other_input_".concat(n)).value=1;var c=jQuery(this).data("ftype");"radio"!==c&&"select"!==c||jQuery(this).fadeOut("slow");var d={action:"frm_add_field_option",field_id:n,opt_key:a,opt_type:i,nonce:frmGlobal.nonce};jQuery.post(ajaxurl,d,function(e){jQuery(document.getElementById("frm_field_".concat(n,"_opts"))).append(e),on(n)})}else{o=(o=(o=(o=(o=o.replace(new RegExp('optkey="'.concat(l,'"'),"g"),'optkey="'.concat(a,'"'))).replace(new RegExp("-".concat(l,"_"),"g"),"-".concat(a,"_"))).replace(new RegExp("-".concat(l,'"'),"g"),"-".concat(a,'"'))).replace(new RegExp("\\[".concat(l,"\\]"),"g"),"[".concat(a,"]"))).replace("frm_hidden frm_option_template",""),Di(n,o={newOption:o});var f=this.closest(".frm_single_option");f?f.after(o.newOption):jQuery("#frm_field_".concat(n,"_opts")).append(o.newOption),on(n)}null==(r=(e=this).classList.contains("frm-add-option-legacy")?null===(t=e.closest(".frm-collapse-me"))||void 0===t?void 0:t.querySelector(".frm_sortable_field_opts"):e.closest(".frm_sortable_field_opts"))||r.querySelectorAll(".frm_remove_tag.frm_disabled").forEach(function(e){return e.classList.remove("frm_disabled")}),Po()}function pt(){gt(jQuery(this).closest(".frm-single-settings").data("fid"),this.value)}function gt(e,t){var r=jQuery(".frm_multiple_cont_".concat(e));"select"===t?r.fadeIn("fast"):r.fadeOut("fast")}function yt(){var e=jQuery(this).closest(".frm-single-settings").data("fid");qi(jQuery(".field_".concat(e,"_option_key"))),jQuery(".field_".concat(e,"_option")).toggleClass("frm_with_key")}function vt(){var e=jQuery(this).closest(".frm-single-settings"),t=e.data("fid"),r=document.getElementById("frm_field_id_".concat(t));wt(jQuery(this)),qi(jQuery(".field_".concat(t,"_image_id"))),qi(jQuery(".frm_toggle_image_options_".concat(t))),qi(jQuery(".frm_image_size_".concat(t))),qi(jQuery(".frm_alignment_".concat(t))),qi(jQuery(".frm-add-other#frm_add_field_".concat(t)));var n=vn(t);if(n){bt(t,"inline"),ht(r);var o=nn(t);r.classList.add("frm_image_options"),r.classList.add("frm_image_size_".concat(o)),e.find(".frm-bulk-edit-link").hide()}else r.classList.remove("frm_image_options"),ht(r),bt(t,"block"),e.find(".frm-bulk-edit-link").show();wp.hooks.doAction("frm_image_options_toggled",e[0],n)}function ht(e){e.classList.remove("frm_image_size_","frm_image_size_small","frm_image_size_medium","frm_image_size_large","frm_image_size_xlarge")}function bt(e,t){jQuery("#field_options_align_".concat(e)).val(t).trigger("change")}function jt(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=document.getElementById("frm_field_id_".concat(e));Qt(),vn(e)&&(ht(t),t.classList.add("frm_image_options"),t.classList.add("frm_image_size_".concat(nn(e))))}function wt(e){var t=e.closest(".frm-single-settings").data("fid");jQuery(".field_".concat(t,"_option")).trigger("change")}function Qt(){wt(jQuery(this))}function xt(e){var t,r=e.target.closest(".frm_image_preview_wrapper");if(null!==(t=wp)&&void 0!==t&&t.media&&(null==r||!r.dataset.upgrade)){e.preventDefault(),wp.media.model.settings.post.id=0;var n=wp.media.frames.file_frame=wp.media({multiple:!1,library:{type:["image"]}});n.on("select",function(){var e=n.state().get("selection").first().toJSON(),t=r.querySelector("img");t.setAttribute("src",e.url),t.classList.remove("frm_hidden"),t.removeAttribute("srcset"),r.querySelector(".frm_image_preview_frame").style.display="block",r.querySelector(".frm_image_preview_title").textContent=e.filename,r.querySelector(".frm_choose_image_box").style.display="none";var o=jQuery(r);o.siblings('input[name*="[label]"]').data("frmimgurl",e.url),o.find("input.frm_image_id").val(e.id).trigger("change"),wp.media.model.settings.post.id=0}),n.open()}}function Et(e){var t=jQuery(this).closest(".frm_image_preview_wrapper");e.preventDefault(),e.stopPropagation(),t.find("img").attr("src",""),t.find(".frm_image_preview_frame").hide(),t.find(".frm_choose_image_box").show(),t.find("input.frm_image_id").val(0).trigger("change")}function kt(){var e=jQuery(this).closest("li").find(".frm_form_fields select");this.checked?e.attr("multiple","multiple"):e.removeAttr("multiple")}function At(){var e=document.getElementById("dropform-search-input");e&&setTimeout(function(){e.focus()},100)}function St(e){var t=e.target,r=t.closest(".frm_warning_style");jQuery(r).fadeOut(400,function(){return r.remove()});var n=t.dataset.action,o=new FormData;p(n,o)}function Lt(e){e.preventDefault()}function It(){var e,t,r=this.parentNode,n=r.parentNode,o=n.querySelectorAll("li:not(.frm_hidden)");2===o.length&&(null===(e=Array.from(o).find(function(e){return e!==r}).querySelector(".frm_remove_tag"))||void 0===e||e.classList.add("frm_disabled"));var i=this.getAttribute("data-fid");jQuery(r).fadeOut("fast",function(){wp.hooks.doAction("frm_before_delete_field_option",this),jQuery(r).remove(),jQuery(n).find(".frm_other_option").length<1&&((t=document.getElementById("other_input_".concat(i)))&&(t.value=0),jQuery("#other_button_".concat(i)).fadeIn("fast"))}),Po()}function Bt(){var e=jQuery(this);if(e.is(":checked")){var t,r=function(){e.off("mouseup",t)};t=function(){setTimeout(function(){e.prop("checked",!1)},0),r()},e.on("mouseup",t),e.one("mouseout",r)}}function qt(){this.value===i.new_option&&(this.setAttribute("data-value-on-focus",this.value),this.value="")}function Ct(e){return B(I("Are you sure you want to delete these %1$s selected field(s)?","formidable"),e)}function Nt(){var e=i.conf_delete,t=this.parentNode.parentNode.parentNode.parentNode.parentNode,r=t.parentNode,n=jQuery(this).closest("li.form-field"),o=n.data("fid");if("divider"===n.data("ftype")){var a=document.querySelectorAll(".frm-field-group-hover-target .start_divider .frm_field_box"),l=0;a.forEach(function(e){var t=e.querySelectorAll("li.form-field");t&&(l+=t.length)}),l&&(e=Ct(++l))}return r.classList.contains("frm-section-collapsed")||r.classList.contains("frm-page-collapsed")||("divider_section_only"===t.className&&(e=i.conf_delete_sec),this.setAttribute("data-frmverify",e),this.setAttribute("data-frmverify-btn","frm-button-red"),this.setAttribute("data-deletefield",o),Ne(),D(this)),!1}function Tt(){this.closest("li.form-field").click()}function Ot(){var e=document.querySelector(".frm-field-group-hover-target");if(e){e.classList.add("frm-selected-field-group");var t=document.createElement("div");t.classList.add("frm-delete-field-groups","frm_hidden"),document.body.append(t),t.click()}}function Ft(){var e=document.querySelector(".frm-field-group-hover-target");if(e){var t="frm_field_group_".concat(be()),r=document.createTextNode("");Ue(r);var n=jQuery(r).closest("li").get(0);n.classList.add("frm_hidden");var o=n.querySelector("ul");o.id=t,jQuery(e.closest("li.frm_field_box")).after(n);var i=ie(jQuery(e)),a=[],l=[],s=i.length,c={},d=0;jQuery(n).on("frm_added_duplicated_field_to_row",function(e,t){if(c[jQuery(t.duplicatedFieldHtml).attr("data-fid")]=t.originalFieldId,!(s>++d)){var r=jQuery(o),i=ie(r);l.forEach(function(e){e.remove()});for(var f=0;f6)return t.append(Gt(e,"even")),t;if(5!==e&&t.append(Gt(e,"even")),e%2==1&&t.append(Gt(e,"middle")),e<6)t.append(Gt(e,"left")),t.append(Gt(e,"right"));else{var r=c();r.classList.add("frm_fourth"),t.prepend(r)}return t}(e),l=t.closest("ul.frm_sorting");return l&&function(e,t){for(var r=t.children.length,n=0;n6?"frm_full":e%2==1?"frm_fourth":"frm_third"}return n.classList.add(r),n.setAttribute("layout-type",t),n.append(function(e,t){for(var r=Xt(),n=0;n6?"frm1":[2,3,4,6].includes(e)?lr(12/e):5===e&&void 0!==t?0===t?"frm4":"frm2":"frm12"}function Kt(e){switch(e){case 2:case 3:return"frm3";case 4:case 5:return"frm2";case 6:return"frm1";default:return"frm12"}}function Jt(e){switch(e){case 2:return"frm9";case 3:case 4:return"frm6";case 5:return"frm4";case 6:return"frm7";default:return"frm12"}}function Xt(){var e=c();return e.classList.add("frm_grid_container"),e}function Yt(){var e=document.querySelector(".frm-field-group-hover-target");if(e){var t=this.getAttribute("layout-type");ae(ie(jQuery(e)).first(),t),fr()}}function Zt(){var e=er(),t=this.getAttribute("layout-type");ae(ie(e).first(),t),yr()}function er(){var e=jQuery(".frm-selected-field-group"),t=e.first();return e.not(t).each(function(){ie(jQuery(this)).each(function(){var e=this.parentNode;ie(t).last().after(this),jQuery(e).children("li.form-field").length||e.closest("li.frm_field_box").remove()})}),En(),ae(ie(t).first()),t}function tr(){null===this.closest(".frm-merge-fields-into-row")&&rr(ie(jQuery(".frm-field-group-hover-target")))}function rr(e){var t=e.length,r=document.getElementById("frm_field_group_popup");r.innerHTML="";var n=c();n.style.padding="0 24px";var o=$t(5===t?6:t),i=c();if(i.style.padding="20px 0",i.classList.add("frm_grid_container"),5===t){var a=document.createElement("span");a.classList.add("frm1"),i.append(a)}var l=jr()>0&&ir($t(t));!1!==l&&l>=12&&(l=Math.floor(12/t));for(var s=0;s',""),t);e.prepend(r),document.getElementById("frm-field-group-message-dismiss").addEventListener("click",function(){_r(document.getElementById("frm-field-group-message"))})}}(),"ul"===e.originalEvent.target.nodeName.toLowerCase()){var t=document.querySelector(".frm-field-group-hover-target");if(t){var r=e.ctrlKey||e.metaKey,n=e.shiftKey,o=t.classList.contains("frm-selected-field-group"),i=function(){var e=jQuery(".frm-selected-field-group");if(e.length)return e;var t=pr();if(t){var r=t.closest("ul");if(r&&1===ie(jQuery(r)).length)return r.classList.add("frm-selected-field-group"),jQuery(r)}return jQuery()}(),a=i.length;if(r||n){var l=pr();if(null===l||jQuery(l).siblings("li.form-field").length||(l.parentNode.classList.add("frm-selected-field-group"),++a),r){if(o)return--a,t.classList.remove("frm-selected-field-group"),void gr(a);++a}else if(n&&!o){++a;var s=i.first();(s.parent().index()=2||1===e&&ie(jQuery(document.querySelector(".frm-selected-field-group"))).length>1?function(){var e=document.getElementById("frm_field_multiselect_popup");if(e)return e.classList.toggle("frm-unmergable",!hr()),e;(e=c()).id="frm_field_multiselect_popup",hr()||e.classList.add("frm-unmergable");var t=c();t.classList.add("frm-merge-fields-into-row"),t.textContent=I("Merge into row","formidable");var r=document.createElement("a");r.style.marginLeft="5px",r.classList.add("frm_icon_font","frm_arrowdown6_icon"),r.setAttribute("href","#"),t.append(r),e.append(t);var n=c();n.classList.add("frm-multiselect-popup-separator"),e.append(n);var o=c();o.classList.add("frm-delete-field-groups"),o.append(Rt("frm_trash_svg")),e.append(o),document.getElementById("post-body-content").append(e),jQuery(e).hide().fadeIn()}():vr(),Fe()}function yr(e){if(void 0!==e){if(null!==e.originalEvent.target.closest("#frm-show-fields"))return;if(e.originalEvent.target.classList.contains("frm-merge-fields-into-row"))return;if(null!==e.originalEvent.target.closest(".frm-merge-fields-into-row"))return;if(e.originalEvent.target.classList.contains("frm-custom-field-group-layout"))return;if(e.originalEvent.target.classList.contains("frm-cancel-custom-field-group-layout"))return}jQuery(".frm-selected-field-group").removeClass("frm-selected-field-group"),jQuery(document).off("click",yr),vr()}function vr(){var e=document.getElementById("frm_field_multiselect_popup");e&&e.remove()}function hr(){var e=document.querySelectorAll(".frm-selected-field-group"),t=e.length;if(1===t)return!1;for(var r=0,n=0;n12)return!1}return!0}function br(e){if(null===e.originalEvent.target.closest("#frm_field_group_popup")&&!e.originalEvent.target.classList.contains("frm-custom-field-group-layout")){var t=Ht(jr(),document.querySelector(".frm-selected-field-group").firstChild);this.append(t)}}function jr(){var e=0;return jQuery(document.querySelectorAll(".frm-selected-field-group")).each(function(){e+=ie(jQuery(this)).length}),e}function wr(){var e,t=(e=[],jQuery(".frm-selected-field-group > li.form-field").each(function(){e.push(this.dataset.fid)}),e),r=function(e){return function(t){t.preventDefault(),function(e){e.forEach(function(e){xr(e)})}(e)}}(t),n=document.getElementById("frm_field_multiselect_popup");n&&n.remove(),this.setAttribute("data-frmverify",Ct(t.length)),D(this);var o=document.getElementById("frm-confirmed-click");null==o||o.removeAttribute("data-deletefield"),jQuery(o).on("click",r),jQuery("#frm_confirm_modal").one("dialogclose",function(){jQuery(o).off("click",r)})}function Qr(){xr(this.getAttribute("data-deletefield"))}function xr(e){var t=jQuery("#frm_field_id_".concat(e));Er(e),t.hasClass("edit_field_type_divider")&&t.find("li.frm_field_box[data-fid]").each(function(){Er(this.getAttribute("data-fid"))}),kn()}function Er(e){jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_delete_field",field_id:e,nonce:frmGlobal.nonce},success:function(){var t,r,n,o=jQuery(document.getElementById("frm_field_id_".concat(e))),i=jQuery("#frm-single-settings-".concat(e));i.is(":visible")&&(null===(t=document.querySelector(".frm-settings-panel .frm-tabs-navs ul > li:first-child"))||void 0===t||t.click(),document.querySelector("#frm-options-panel .frm-single-settings").classList.remove("frm_hidden")),function(e){var t=e[0].querySelectorAll(".frm-inline-modal[data-fills]");t.length&&t.forEach(function(e){e.classList.add("frm_hidden"),e.removeAttribute("data-fills"),e.closest("form").append(e)})}(i),i.remove(),o.fadeOut("slow",function(){var e,t=o.closest(".start_divider"),r=o.data("type"),n=o.siblings("li.form-field");if(n.length||(o.is(".edit_field_type_end_divider")?n.length=o.closest("li.form-field").siblings():e=o.closest("ul.frm_sorting").parent()),o.remove(),"break"===r?Fr():"product"===r&&(Ie(),nt()),n.length?ae(n.first()):e.remove(),0===jQuery("#frm-show-fields li").length||function(){if(b.get(0).childElementCount>1)return!1;var e=b.get(0).firstElementChild.firstElementChild.querySelectorAll("li.frm_field_box");return!(e.length>1)&&e[0].classList.contains("edit_field_type_submit")}()){var i=document.getElementById("frm_form_editor_container");i.classList.remove("frm-has-fields"),i.classList.add("frm-empty-fields")}else t.length&&An(t);z()}),o.length&&(r=o.data("type"),(n=document.getElementById(r))&&n.dataset.limit&&kr(r)-11)for(document.getElementById("frm-fake-page").style.display="block",e=0;e200)&&(M(i.repeat_limit_min),this.value="")}function Yr(){var e=this.value;""!==e&&(e<1||e>200)&&(M(i.checkbox_limit),this.value="")}function Zr(e,t){jQuery(e).closest(".frm_field_box").find(".frm_".concat(t,"_form_row .frm_repeat_label")).text(e.value)}function en(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=this.value,r=document.getElementById("frm_show_selected_fields_".concat(e)),n=document.getElementById("frm_show_selected_forms_".concat(e));jQuery(n).find("select").val(""),"form"===t?(n.style.display="inline",function(e){if(null!==e)for(;e.firstChild;)e.firstChild.remove()}(r)):(r.style.display="none",n.style.display="none",xn(t,e))}function tn(){var e=rn(this);if(e){var t=jQuery(this).closest(".frm_single_option");!function(e,t,r){var n=r.data("optkey"),o=yn(e),i=jQuery('label[for="field_'.concat(t,"-").concat(n,'"]')),a="field_options[options_".concat(e,"][").concat(n,"]"),l=jQuery('input[name="'.concat(a,'[label]"]'));if(i.length<1)return on(e),void(r.find('input[name^="default_value_"]').is(":checked")&&l.length>0&&jQuery('select[name^="item_meta['.concat(e,']"]')).val(l.val()));var s,d=i.children("input");if(s=l.length<1?(l=jQuery('input[name="'.concat(a,'"]'))).val():o?jQuery('input[name="'.concat(a,'[value]"]')).val():l.val(),!(l.length<1)){var f=i[0].childNodes;if(vn(e)){var u=function(e,t,r){var n,o=e.find("img");o&&(n=o.attr("src"));var i=hn(t);return pn(r.val(),i,n)}(r,e,l),m=i.find(".frm_image_option_container");m.length>0?m.replaceWith(u):(f[f.length-1].nodeValue="",i.append(u))}else{var _=!1;f.forEach(function(t,r){if(!1===_)"INPUT"===t.tagName&&(_=r);else if(r===_+1){var n="";!function(e){var t=document.getElementsByName("field_options[image_options_".concat(e,"]")),r=Array.from(t).find(function(e){return e.checked&&"buttons"===e.value});return void 0!==r}(e)?t.nodeValue=" ".concat(l.val()):(n=c({className:"frm_label_button_container",text:" ".concat(l.val())}),i[0].replaceChild(n,t))}else t.remove()})}d.val(s),defaultVal=r.find('input[name^="default_value_"]'),d.prop("checked",!!defaultVal.is(":checked"))}}(e.fieldId,e.fieldKey,t)}}function rn(e){var t=jQuery(e).closest(".frm_sortable_field_opts");return!!t.length&&{fieldId:t.attr("id").replace("frm_field_","").replace("_opts",""),fieldKey:t.data("key")}}function nn(e){var t,r=document.getElementById("field_options_image_size_".concat(e)),n="";return r&&""!==(t=r.value)&&(n=t),n}function on(e){var t=jQuery('[name^="item_meta['.concat(e,']"]'));if(!(t.length<1)){if(t.is("select")){var r=document.getElementById("frm_placeholder_".concat(e));r&&""!==r.value?dn(t[0],{sourceID:e,placeholder:r.value}):dn(t[0],{sourceID:e})}else{var n=un(e);jQuery("#field_".concat(e,"_inner_container > .frm_form_fields")).html("");for(var o=rn(jQuery("#frm_delete_field_".concat(e,"-000_container"))),i=jQuery("#field_".concat(e,"_inner_container > .frm_form_fields")),a=vn(e),l=a?nn(e):"",s=a?"frm_image_option frm_image_".concat(l," "):"",c=Oi(e),d="hidden"===t.attr("type")?t.data("field-type"):t.attr("type"),f=0;f=0;f--)d();var u=c.querySelector('option[value=""]');null!==u&&c.prepend(u)}}}function sn(e,t,r,n){null!==t||e.querySelector('option[value="'.concat(r,'"]'))||((t=frmDom.tag("option",{text:n})).value=r),e.prepend(t)}function cn(e,t,r,n,o,i){var a="",l=t.key.includes("other"),s="field_".concat(n,"-").concat(t.key),c="scale"===e?"radio":e,d='');return this.getSingle=function(){return""!==(a=wp.hooks.applyFilters("frm_admin.build_single_option_template",a,{opt:t,type:e,fieldId:r,classes:i,id:s}))?a:'
                    \n\t\t\t\t\t\n\t\t\t\t\t").concat(l?d:"","\n\t\t\t\t
                    ")},this.getSingle()}function dn(e,t){if(e){var r=t.sourceID,n=t.placeholder,o=Oi(r),i=t.other;!function(e){var t;if(void 0!==e.options)for(t=e.options.length-1;t>=0;t--)e.remove(t)}(e);for(var a=un(r,e.id.includes("frm_field_logic_opt")),l=void 0!==n,s=0;s1&&void 0!==arguments[1]&&arguments[1],s=[],c=jQuery('input[name^="field_options[options_'.concat(e,']"]')).filter('[name$="[label]"], [name*="[other_"]'),d=Oi(e),f=hn(e),u=vn(e),m=yn(e);for(t=0;t0||(o=r=c[t].value,i=c[t].name.replace("field_options[options_".concat(e,"]["),"").replace("[label]","").replace("]",""),m&&(n=c[t].name.replace("[label]","[value]"),r=jQuery('input[name="'.concat(n,'"]')).val(),l&&""===o&&(o=""!==r?r:frm_admin_js.no_label)),u&&(o=pn(o,f,mn(c[t]))),a={saved:r,label:o=frmAdminBuild.hooks.applyFilters("frm_choice_field_label",o,e,c[t],u),checked:gn(c[t].id),key:i},d&&(n=c[t].name.replace("[label]","[price]"),a.price=jQuery('input[name="'.concat(n,'"]')).val()),s.push(a));return s}function mn(e){var t=jQuery(e).siblings(".frm_image_preview_wrapper");if(!t.length)return"";var r=t.find("img");return r.length?r.attr("src"):""}function _n(e){(e instanceof Element||e instanceof Document)&&(e=e.outerHTML);var t=jQuery.parseHTML(e).reduce(function(e,t){var r=frmDom.cleanNode(t);return"#text"===r.nodeName?e+r.textContent:e+r.outerHTML},"");return t!==e?_n(t):t}function pn(e,t,r){var n,o=e;o=_n(o),r?n=m({src:r,alt:o}):(n=c({className:"frm_empty_url"})).innerHTML=i.image_placeholder_icon;var a=t?" frm_label_with_image":"",l=s("span",{className:"frm_text_label_for_image_inner"});return l.innerHTML=o,s("span",{className:"frm_image_option_container".concat(a),children:[n,s("span",{className:"frm_text_label_for_image",child:l})]})}function gn(e){var t=jQuery("#".concat(e));if(0===t.length)return!1;var r=t.siblings("input[type=checkbox]");return r.length&&r.prop("checked")}function yn(e){return bn("separate_value_".concat(e))}function vn(e){for(var t=!1,r=document.getElementsByName("field_options[image_options_".concat(e,"]")),n=0;n=0&&(t.splice(r,1),e.val(t),e.next(".btn-group").find('.multiselect-container input[value=""]').prop("checked",!1))}(jQuery(this))}function Bn(e){e.val(""),e.next(".btn-group").find('.multiselect-container input[value!=""]').prop("checked",!1)}function qn(){jQuery(".frm-hide-empty").each(function(){0===jQuery(this).text().trim().length&&jQuery(this).remove()})}function Cn(e){e.preventDefault(),function(e,t,r){var n=document.getElementById(e.getAttribute("data-open")),o=jQuery(e).closest("p,ul"),i=void 0!==t;if(o.hasClass("frm-open"))o.removeClass("frm-open"),n.classList.add("frm_hidden");else{if(i||(t=Wo(e)),t){if(!i){var a=r.key;"Enter"!==a&&" "!==a&&t.focus()}o.after(n),n.setAttribute("data-fills",t.id.replace("-proxy-input","")),0===n.id.indexOf("frm-calc-box")&&Ze(n,!0)}o.addClass("frm-open"),n.classList.remove("frm_hidden"),wp.hooks.doAction("frm_show_inline_modal",n,e)}}(this,void 0,e)}function Nn(e){e.preventDefault(),this.parentNode.classList.add("frm_hidden"),jQuery('.frm-open [data-open="'.concat(this.parentNode.id,'"]')).closest(".frm-open").removeClass("frm-open")}function Tn(e){var t=e.target;t.closest(".frm-inline-modal.frm-modal-no-dismiss")||t.closest(".frm-show-inline-modal")||t.closest("#frm_adv_info")||t.closest(".frm-token-proxy-input")||document.querySelectorAll(".frm-inline-modal.frm-modal-no-dismiss:not(.frm_hidden)").forEach(function(e){e.classList.add("frm_hidden"),e.previousElementSibling.classList.remove("frm-open")})}function On(){var e,t=this.getAttribute("data-frmchange").split(",");for(e=0;e').before('')}function Yn(){var e="success";"options[edit_action]"===this.name&&(e="edit");var t=jQuery(this).val();jQuery(".".concat(e,"_action_box")).hide(),"redirect"===t?jQuery(".".concat(e,"_action_redirect_box.").concat(e,"_action_box")).fadeIn("slow"):"page"===t?jQuery(".".concat(e,"_action_page_box.").concat(e,"_action_box")).fadeIn("slow"):jQuery(".".concat(e,"_action_message_box.").concat(e,"_action_box")).fadeIn("slow")}function Zn(e){if(!function(e){var t=jQuery(e),r=t.closest(".frm_form_action_settings"),n=r.find(".widget-inside");if(n.find("p, div, table").length)return!1;var o=r.find(".widget-top");return o.on("frm-action-loaded",function(){t.trigger("click"),r.removeClass("open"),n.hide()}),o.trigger("click"),!0}(e.target)){var t=e.target.closest(".frm_form_action_settings"),r=t.querySelectorAll(".wp-editor-area");r.length&&r.forEach(function(e){tinymce.EditorManager.execCommand("mceRemoveEditor",!0,e.id)});var n=jQuery(t).clone(),o=n.attr("id").replace("frm_form_action_",""),i=eo(o);n.find(".frm_action_id, .frm-btn-group").remove(),n.find('input[name$="['.concat(o,'][ID]"]')).val(""),n.find(".widget-inside").hide(),n.find("input[type=text], textarea, input[type=number]").prop("defaultValue",function(){return this.value}),n.find("input[type=checkbox], input[type=radio]").prop("defaultChecked",function(){return this.checked});var a=new RegExp("\\[".concat(o,"\\]"),"g"),l=new RegExp("_".concat(o,'"'),"g"),s=new RegExp("-".concat(o,'"'),"g"),d=new RegExp('"'.concat(o,'"'),"g"),f=n.html().replace(a,"[".concat(i,"]")).replace(l,"_".concat(i,'"'));f=f.replace(s,"-".concat(i,'"')).replace(d,'"'.concat(i,'"'));var u=c({id:"frm_form_action_".concat(i),className:n.get(0).className});u.setAttribute("data-actionkey",i),u.innerHTML=f,u.querySelectorAll(".wp-editor-wrap, .wp-editor-wrap *").forEach(function(e){"string"==typeof e.className&&(e.className=e.className.replace(o,i)),e.id=e.id.replace(o,i)}),u.classList.remove("open"),document.getElementById("frm_notification_settings").append(u),r.length&&(r.forEach(function(e){frmDom.wysiwyg.init(e)}),u.querySelectorAll(".wp-editor-area").forEach(function(e){frmDom.wysiwyg.init(e)})),u.classList.contains("frm_single_on_submit_settings")&&u.querySelector("input.frm-page-search")&&yi(u),ci(),wp.hooks.doAction("frm_after_duplicate_action",u)}}function eo(e){var t=parseInt(e,10)+11;return document.getElementById("frm_form_action_".concat(t))&&(t=eo(++t)),t}function to(){var e,t=jQuery(this).data("actiontype");if(!co(t)){var r=(e=Sr(document.querySelectorAll(".frm_form_action_settings"),"frm_form_action_"),void 0!==document.getElementById("frm_form_action_".concat(e))&&(e+=100),S>=e&&(e=S+1),S=e,e),n=E,o=document.createElement("div");o.classList.add("frm_single_".concat(t,"_settings"));var i=document.getElementById("frm_notification_settings");i.append(o),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_add_form_action",type:t,list_id:r,form_id:n,nonce:frmGlobal.nonce},success:function(e){Po(),o.remove(),document.querySelectorAll(".frm_form_action_settings.open").forEach(function(e){return e.classList.remove("open")});var n=c();n.innerHTML=e;var a=n.querySelector(".widget-top");Array.from(n.children).forEach(function(e){return i.append(e)}),jQuery(".frm_form_action_settings").fadeIn("slow");var l=document.getElementById("frm_form_action_".concat(r));l.classList.add("open"),document.getElementById("post-body-content").scroll({top:l.offsetTop+10,left:0,behavior:"smooth"}),so(t),Xn("#frm_form_action_".concat(r)),ci(),yi(l),a&&jQuery(a).trigger("frm-action-loaded"),frmAdminBuild.hooks.doAction("frm_added_form_action",l)}})}}function ro(){var e=document.getElementById("frm_email_addon_menu").classList,t=document.getElementById("actions-search-input");e.contains("frm-all-actions")?(e.remove("frm-all-actions"),e.add("frm-limited-actions")):(e.add("frm-all-actions"),e.remove("frm-limited-actions")),t.value="",ki(t,"input")}function no(e){e.on("Change",function(){!function(e){(function(){var e=document.querySelector(".frm-single-settings:not(.frm_hidden)");if(!e)return!1;var t=e.querySelector(".wp-editor-wrap");return t&&t.classList.contains("tmce-active")})()&&!tinyMCE.activeEditor.isHidden()&&(e.targetElm.value=e.getContent(),jQuery(e.targetElm).trigger("change"))}(e)})}function oo(e){var t=this;if(e)return this.fragment=document.createDocumentFragment(),this.initOnceInAllInstances=function(){void 0===oo.prototype.endMarker&&(oo.prototype.endMarker=document.getElementById("frm-end-form-marker"))},this.append=function(e){var r=e?e.parentElement.classList:"";e&&(r.contains("frm_field_box")||r.contains("divider_section_only"))&&t.fragment.append(e)},this.moveFields=function(){j.insertBefore(t.fragment,oo.prototype.endMarker)},this.initOnceInAllInstances(),void 0!==e?(this.append(e),void this.moveFields()):{append:this.append,moveFields:this.moveFields}}function io(){var e=jQuery(this).closest(".frm_form_action_settings").data("actionkey"),t=this.getAttribute("data-emailrow");jQuery("#frm_form_action_".concat(e," .frm_").concat(t,"_row")).fadeIn("slow"),jQuery(this).fadeOut("slow")}function ao(){var e=jQuery(this).closest(".frm_form_action_settings"),t=this.getAttribute("data-emailrow"),r=".frm_".concat(t,"_row"),n=".frm_".concat(t,"_button");jQuery(e).find(n).fadeIn("slow"),jQuery(e).find(r).fadeOut("slow",function(){jQuery(e).find("".concat(r," input")).val("")})}function lo(){var e=jQuery(this).closest(".frm_form_action_settings"),t=".frm_from_to_match_row";e.find('input[name$="[post_content][from]"]').val()===e.find('input[name$="[post_content][email_to]"]').val()?jQuery(e).find(t).fadeIn("slow"):jQuery(e).find(t).fadeOut("slow")}function so(e){var t,r,n=document.querySelectorAll(".frm_".concat(e,"_action"));co(e)?(t=n,r=fo(e)>0,t.forEach(function(e){e.classList.remove("frm_active_action"),e.classList.add("frm_inactive_action"),r&&e.classList.add("frm_already_used")})):n.forEach(function(e){e.querySelector(".frm_show_upgrade")||(e.classList.remove("frm_inactive_action","frm_already_used"),e.classList.add("frm_active_action"))})}function co(e){var t=function(e){return jQuery(".frm_single_".concat(e,"_settings")).length}(e)>=fo(e),r={type:e};return wp.hooks.applyFilters("frm_action_at_limit",t,r)}function fo(e){return parseInt(jQuery(".frm_".concat(e,"_action")).data("limit"),10)}function uo(){var e=i.only_one_action,t=this.dataset.limit;void 0!==t&&((t=parseInt(t))>1?e=e.replace(1,t).trim():e+=" ".concat(i.edit_action_text)),M(e)}function mo(){var e=jQuery(this).data("emailkey"),t=jQuery(this).closest(".frm_form_action_settings").find(".frm_action_name").val(),r=document.getElementById("form_id").value,n=document.getElementById("frm_logic_row_".concat(e)),o=Sr(n.querySelectorAll(".frm_logic_row"),"frm_logic_".concat(e,"_")),i=c({id:"frm_logic_".concat(e,"_").concat(o),className:"frm_logic_row frm_hidden"});return n.append(i),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_add_form_logic_row",email_id:e,form_id:r,meta_name:o,type:t,nonce:frmGlobal.nonce},success:function(t){jQuery(document.getElementById("logic_link_".concat(e))).fadeOut("slow",function(){i.insertAdjacentHTML("beforebegin",t),i.remove(),jQuery(n).parent(".frm_logic_rows").fadeIn("slow")})}}),!1}function _o(){var e=jQuery("select.frm_single_post_field");e.css("border-color","");var t=this,r=jQuery(t).val();if(""===r||"checkbox"===r)return!1;e.each(function(){if(jQuery(this).val()===r&&this.name!==t.name)return this.style.borderColor="red",jQuery(t).val(""),M(i.field_already_used),!1})}function po(){var e=jQuery(this).val();""===e?(jQuery(".frm_post_content_opt, select.frm_dyncontent_opt").hide().val(""),jQuery(".frm_dyncontent_opt").hide()):"post_content"===e?(jQuery(".frm_post_content_opt").show(),jQuery(".frm_dyncontent_opt").hide(),jQuery("select.frm_dyncontent_opt").val("")):(jQuery(".frm_post_content_opt").hide().val(""),jQuery("select.frm_dyncontent_opt, .frm_form_field.frm_dyncontent_opt").show())}function go(){var e=jQuery(this).val(),t=jQuery(document.getElementById("frm_dyncontent"));""===e||"new"===e?(t.val(""),jQuery(".frm_dyncontent_opt").show()):jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_display_get_content",id:e,nonce:frmGlobal.nonce},success:function(e){t.val(e),jQuery(".frm_dyncontent_opt").show()}})}function yo(){var e,t,r=document.getElementById("frm_posttax_rows").childNodes,n=document.querySelector(".frm_post_parent_field"),o=document.querySelector(".frm_post_menu_order_field"),i=this.value;jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_replace_posttax_options",post_type:i,nonce:frmGlobal.nonce},success:function(n){for(var o=0;o');var e=jQuery(this).closest(".frm_form_action_settings").find('select[name$="[post_content][post_type]"]').val(),t=jQuery(this).closest(".frm_form_action_settings").data("actionkey"),r=jQuery(this).closest(".frm_posttax_row").attr("id").replace("frm_posttax_",""),n=jQuery(this).val(),o=jQuery(document.getElementById("".concat(r,"_show_exclude"))).is(":checked")?1:0,i=jQuery('select[name$="[post_category]['.concat(r,'][field_id]"]')).val(),a=jQuery('input[name="id"]').val();jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_add_posttax_row",form_id:a,post_type:e,tax_key:r,action_key:t,meta_name:n,field_id:i,show_exclude:o,nonce:frmGlobal.nonce},success:function(e){jQuery(document.getElementById("frm_posttax_".concat(r))).replaceWith(e)}})}}function Qo(){var e=jQuery(this).closest(".frm_postmeta_row"),t=e.find(".frm_cancelnew"),r=e.find(".frm_enternew");return e.find("select.frm_cancelnew").is(":visible")?(t.hide(),r.show()):(t.show(),r.hide()),e.find("input.frm_enternew, select.frm_cancelnew").val(""),!1}function xo(){var e=jQuery(this),t=e.val();"checkbox"===e.attr("type")&&!1===this.checked&&(t="");var r=e.data("toggleclass");""===t?jQuery(".".concat(r)).hide():(jQuery(".".concat(r)).show(),jQuery(".hide_".concat(r,"_").concat(t)).hide())}function Eo(){Un()||($n(this),zn(document.querySelector(".frm_form_settings")))}function ko(e){return e.preventDefault(),Ao(jQuery(this),this.getAttribute("data-code")),!1}function Ao(e,t){var r=!1,n=e;if("object"===a(e)){if(e.hasClass("frm_noallow"))return;void 0===(n=jQuery(e).closest("[data-fills]").attr("data-fills"))&&void 0!==(n=e.closest("div").attr("class"))&&(n=n.split(" ")[1])}if(void 0===n){var o=document.activeElement;"search"===o.type?null===(n=o.id.replace("-search-input","")).match(/\d/gi)&&(n=(o=jQuery(".frm-single-settings:visible .".concat(n))).attr("id")):n=o.id}n&&(r=jQuery("#wp-".concat(n,"-wrap.wp-editor-wrap")).length>0);var i=jQuery(document.getElementById(n));if(void 0===e.attr("data-shortcode")&&(!i.length||void 0===i.attr("data-shortcode"))){var l=e.parents("ul.frm_code_list").attr("data-shortcode");"undefined"!==l&&"no"===l||(t="[".concat(t,"]"))}if(r&&(wpActiveEditor=n),!i.length)return!1;if("[default-html]"===t||"[default-plain]"===t){var s=0;"[default-plain]"===t&&(s=1),jQuery.ajax({type:"POST",url:ajaxurl,data:{action:"frm_get_default_html",form_id:jQuery('input[name="id"]').val(),plain_text:s,nonce:frmGlobal.nonce},elementId:n,success:function(e){if(r){var t=document.createElement("p");t.innerText=e,send_to_editor(t.innerHTML)}else So(i,e)}})}else t=function(e,t,r){return"object"===a(t)&&t instanceof jQuery&&0===r[0].id.indexOf("success_url_")&&(t=t[0]).closest("#frm-insert-fields-box")?(t.parentNode.classList.contains("frm_insert_url")||(e=e.replace("]"," sanitize_url=1]")),e):e}(t,e,i),r?send_to_editor(t):So(i,t);return!1}function So(e,t){if(document.selection)e[0].focus(),document.selection.createRange().text=t;else{var r=e[0],n=r.selectionEnd;t=function(e,t,r,n){var o=e.data("sep");if(void 0===o)return t;var i=e.val();if(!i.trim().length)return t;var a=new RegExp("".concat(o,"\\s*$")),l=new RegExp("^\\s*".concat(o));return i.substr(0,r).trim().length&&!1===a.test(i.substr(0,r))&&(t=o+t),i.substr(n,i.length).trim().length&&!1===l.test(i.substr(n,i.length))&&(t+=o),t}(e,t,r.selectionStart,n),r.value=r.value.substr(0,r.selectionStart)+t+r.value.substr(r.selectionEnd,r.value.length);var o=n+t.length;!function(e,t){if(e.classList.contains("frm_classes")&&Lo(t)){var r=e.value.split(" ").filter(Lo);r.length&&(e.value=function(e,t,r){var n=e.split(" ").filter(function(e){return(e=e.trim()).length&&!t.includes(e)});return n.includes(r)||n.push(r),n.join(" ")}(e.value,r,t.trim()))}}(r,t),r.focus(),r.setSelectionRange(o,o)}Rn(e)}function Lo(e){return["frm_half","frm_third","frm_two_thirds","frm_fourth","frm_three_fourths","frm_fifth","frm_sixth","frm2","frm3","frm4","frm6","frm8","frm9","frm10","frm12"].includes(e.trim())}function Io(){var e=document.getElementById("frm-id-condition"),t=document.getElementById("frm-key-condition");"id"===this.value?(e.classList.remove("frm_hidden"),t.classList.add("frm_hidden"),ki(t,"change")):(e.classList.add("frm_hidden"),t.classList.remove("frm_hidden"),ki(e,"change"))}function Bo(){var e=document.getElementById("frm-id-key-condition-id").checked?"frm-id-condition":"frm-key-condition",t=document.getElementById("frm-is-condition").value,r=document.getElementById("frm-text-condition").value,n=document.getElementById("frm-insert-condition"),o=(e=document.getElementById(e)).options[e.selectedIndex].value,a="if ".concat(o," ").concat(t,'="').concat(r,'"]');n.setAttribute("data-code","".concat(a+i.conditional_text,"[/if ").concat(o)),n.innerHTML="[".concat(a,"[/if ").concat(o,"]")}function qo(e){return e.getAttribute("href")||e.getAttributeNS("http://www.w3.org/1999/xlink","href")}function Co(e){var t;e.parentNode.parentNode.classList.contains("frm_has_shortcodes")&&($o(),"use"===(t=Vo(e)).tagName?qo(t=t.firstElementChild).includes("frm_close_icon")||Do(t,"nofocus"):t.classList.contains("frm_close_icon")||Do(t,"nofocus"))}function No(e){e.preventDefault(),e.stopPropagation(),Do(this)}function To(e){!function(e){var t;if(e.id.startsWith("field_options_type_")){var r=e.id.split("_"),n=r.length&&r[r.length-1];null!==(t=document.querySelector("#frm-single-settings-".concat(n)))&&void 0!==t&&t.classList.contains("frm-type-".concat(e.value))||Oo()}}(e.target)}function Oo(e){var t;void 0===e&&(e=I("You are changing the field type. Not all field settings will appear as expected until you reload the page. Would you like to reload the page now?","formidable")),frmDom.modal.maybeCreateModal("frmSaveAndReloadModal",{title:I("Save and Reload?","formidable"),content:(t=c(e),t.style.padding="var(--gap-md)",t),footer:function(){var e=frmDom.modal.footerButton({text:I("Save and Reload","formidable"),buttonType:"primary"});_(e,function(){var e;(e=document.getElementById("frm_submit_side_top")).classList.contains("frm_submit_ajax")&&e.setAttribute("data-new-addon-installed",!0),e.click()});var t=frmDom.modal.footerButton({text:I("Cancel","formidable"),buttonType:"cancel"});return t.classList.add("dismiss"),frmDom.div({children:[t,e]})}()})}function Fo(e){var t;if(e instanceof Event){var r=document.querySelectorAll(".frm-single-settings .frm-show-box.frmsvg use"),n=Array.from(r).find(function(e){return"#frm_close_icon"===e.getAttribute("href")});if(void 0===n)return;t=n.parentElement}else t=e;var o=t.getBoundingClientRect(),i=document.getElementById("frm_adv_info"),a=i.parentElement.getBoundingClientRect();i.style.top="".concat(o.top-a.top+32,"px"),i.style.left="".concat(o.left-a.left-280,"px")}function Do(e,t){var r=Wo(e),n=document.getElementById("frm_adv_info"),a=e.className;if("svg"===e.tagName&&(e=e.firstElementChild),"use"===e.tagName&&(a=qo(e)),a.includes("frm_close_icon"))$o(n);else{if(Fo(e),jQuery(".frm_code_list a").removeClass("frm_noallow"),r.classList.contains("frm_not_email_to")?jQuery("#frm-insert-fields-box .frm_code_list li:not(.show_frm_not_email_to) a").addClass("frm_noallow"):r.classList.contains("frm_not_email_subject")&&jQuery(".frm_code_list li.hide_frm_not_email_subject a").addClass("frm_noallow"),n.setAttribute("data-fills",r.id),n.style.display="block","use"===e.tagName)if(e.hasAttributeNS("http://www.w3.org/1999/xlink","href"))e.setAttributeNS("http://www.w3.org/1999/xlink","href","#frm_close_icon");else{var l=document.createElementNS("http://www.w3.org/2000/svg","use");l.setAttributeNS("http://www.w3.org/1999/xlink","href","#frm_close_icon"),e.parentNode.replaceChild(l,e)}else e.className=a.replace("frm_more_horiz_solid_icon","frm_close_icon");"nofocus"!==t&&("none"!==r.style.display?r.focus():jQuery(tinymce.get(r.id)).trigger("focus")),function(e){["address","body"].forEach(function(t){!function(e,t){var r,n=i.contextualShortcodes["".concat(t,"Selector")],a=i.contextualShortcodes[t],l=e.matches(n),s=function(e){var t="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!t){if(Array.isArray(e)||(t=o(e))){t&&(e=t);var r=0,n=function(){};return{s:n,n:function(){return r>=e.length?{done:!0}:{done:!1,value:e[r++]}},e:function(e){throw e},f:n}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,l=!1;return{s:function(){t=t.call(e)},n:function(){var e=t.next();return a=e.done,e},e:function(e){l=!0,i=e},f:function(){try{a||null==t.return||t.return()}finally{if(l)throw i}}}}(a);try{for(s.s();!(r=s.n()).done;){var c,d=r.value,f=null===(c=document.querySelector('#frm-adv-info-tab .frm_code_list [data-code="'.concat(d,'"]')))||void 0===c?void 0:c.closest("li");null==f||f.classList.toggle("frm_hidden",!l)}}catch(e){s.e(e)}finally{s.f()}}(e,t)})}(r)}}function Mo(e){return 0===i.contextualShortcodes.length||!function(e){var t=e.querySelector("a");if(!t)return!1;var r=t.dataset.code;return i.contextualShortcodes.address.includes(r)||i.contextualShortcodes.body.includes(r)}(e)||function(e){var t=e.querySelector("a").dataset.code,r=document.getElementById("frm_adv_info").dataset.fills,n=document.getElementById(r),o=i.contextualShortcodes;return o.address.includes(t)?n.matches(o.addressSelector):n.matches(o.bodySelector)}(e)}function Po(){x||(x=1,window.addEventListener("beforeunload",Go))}function Ho(){x=0}function zo(){x=0}function Ro(){x=0}function Go(e){x&&(e.preventDefault(),e.returnValue="")}function Uo(e,t){var r={my:"top",at:"top+".concat(t),of:window};e.dialog("option","position",r)}function Wo(e){if(e.classList.contains("frm-input-icon"))return e.previousElementSibling;for(var t,r=e.nextElementSibling;r&&("INPUT"!==r.tagName&&"TEXTAREA"!==r.tagName||r.classList.contains("frm-token-input-field"));)r=Wo(r);return r||(r=null===(t=e.closest(".frm-field-formula"))||void 0===t?void 0:t.querySelector(".frm-calc-field")),r}function Vo(e){var t;if(null!==(t=e.nextElementSibling)&&void 0!==t&&t.classList.contains("frm-input-icon"))return e.nextElementSibling;for(var r=e.previousElementSibling;null!==r&&"I"!==r.tagName&&"svg"!==r.tagName;)r=Vo(r);return r}function $o(e){if((void 0!==e||(e=document.getElementById("frm_adv_info")))&&null===document.getElementById("frm_dyncontent")){e.style.display="none";for(var t=document.querySelectorAll(".frm-show-box.frm_close_icon"),r=0;r".concat(r.data.name,": ").concat(r.data.msg,"

                    "):'

                    Imported ').concat(r.data.name,"

                    "),e.find(".status").prepend(n),e.find(".status").show(),C.importQueue=jQuery.grep(C.importQueue,function(e){return e!=t}),C.imported++,0===C.importQueue.length?(e.find(".process-count").hide(),e.find(".forms-completed").text(C.imported),e.find(".process-completed").show()):(e.find(".form-current").text(C.imported+1),ei(e)))})}function ti(e){e.preventDefault();var t=!1,r=jQuery('input[name="frm_export_forms[]"]');jQuery('input[name="frm_export_forms[]"]:checked').val()||(r.closest(".frm-table-box").addClass("frm_blank_field"),t="stop");var n=jQuery('input[name="type[]"]');if(jQuery('input[name="type[]"]:checked').val()||"checkbox"!==n.attr("type")||(n.closest("p").addClass("frm_blank_field"),t="stop"),"stop"===t)return!1;e.stopPropagation(),this.submit()}function ri(){var e=jQuery(this).closest(".frm_blank_field");if(void 0!==e){var t=this.name;("type[]"===t&&jQuery('input[name="type[]"]:checked').val()||"frm_export_forms[]"===t&&jQuery(this).val())&&e.removeClass("frm_blank_field")}}function ni(){null!==jQuery(this).val().match(/\.csv$/i)?jQuery(".show_csv").fadeIn():jQuery(".show_csv").fadeOut()}function oi(){var e=document.querySelector('select[name="format"]');return e?e.value:""}function ii(e){var t,r,n=e.target.value;li(n),ai.call(e.target),t=n,r=document.getElementById("frm-export-select-all"),"csv"===t?(r.checked=!1,r.disabled=!0):r.disabled=!1}function ai(){var e=jQuery(this),t=e.find(":selected"),r=t.data("support"),n=r.indexOf("|");jQuery('input[name="type[]"]').each(function(){this.checked=!1,r.includes(this.value)?(this.disabled=!1,-1===n&&(this.checked=!0)):this.disabled=!0}),"csv"===e.val()?(jQuery(".csv_opts").show(),jQuery(".xml_opts").hide()):(jQuery(".csv_opts").hide(),jQuery(".xml_opts").show());var o=t.data("count"),i=jQuery('input[name="frm_export_forms[]"]');"single"===o?(i.prop("multiple",!1),i.prop("checked",!1)):(i.prop("multiple",!0),i.prop("disabled",!1)),e.trigger("change")}function li(e){if(""!==e){var t=document.querySelectorAll(".frm-is-repeater");t.length&&("csv"===e?t.forEach(function(e){e.classList.remove("frm_hidden")}):t.forEach(function(e){e.classList.add("frm_hidden")}),Qi.call(document.querySelector(".frm-auto-search")))}}function si(){var e=jQuery("select[name=format]").find(":selected").data("count"),t=jQuery('input[name="frm_export_forms[]"]');"single"===e&&this.checked?(t.prop("disabled",!0),this.removeAttribute("disabled")):t.prop("disabled",!1)}function ci(){jQuery(".frm_multiselect").hide().each(frmDom.bootstrap.multiselect.init)}function di(e){e.preventDefault(),mi(this,"frm_multiple_addons")}function fi(e){e.preventDefault(),mi(this,"frm_activate_addon")}function ui(e){e.preventDefault(),mi(this,"frm_install_addon")}function mi(e,t){r(1105).toggleAddonState(e,t)}function _i(){gi()}function pi(e){!function(e,t,r){var n=jQuery("#frm_leave_email_error");n.removeClass("frm_hidden").attr("frm-error",r),jQuery("#frm_leave_email").one("keyup",function(){n.addClass("frm_hidden")})}(0,0,e)}function gi(){var e=document.getElementById("frmapi-email-form");jQuery.ajax({dataType:"json",url:e.getAttribute("data-url"),success:function(t){var r=t.renderedHtml;r=r.replace(/]*(formidableforms.css|action=frmpro_css)[^>]*>/gi,""),e.innerHTML=r}})}function yi(e){frmDom.autocomplete.initSelectionAutocomplete(e)}function vi(e){var t=this.parentNode.parentNode,r=t.elements.type.value;e.preventDefault(),this.classList.add("frm_loading_button"),bi(t,r,this)}function hi(e){var t=this.elements.type.value,r=this.querySelector("button");e.preventDefault(),r.classList.add("frm_loading_button"),bi(this,t,r)}function bi(e,t,r){var n=function(e){var t,r,n={},o=e.elements;for(r=0;r .frm-with-line").forEach(function(e){var t=e.nextElementSibling;if(t){var r=t.querySelectorAll(":scope > li.frmbutton"),n=Array.from(r).every(function(e){return e.classList.contains("frm_hidden")});e.classList.toggle("frm_hidden",n)}}),jQuery(this).trigger("frmAfterSearch")}function xi(e,t){return"s"!==t&&"s"!==e[e.length-1]&&"".concat(e,"s").includes(t)}function Ei(e){e.stopPropagation()}function ki(e,t){var r=document.createEvent("HTMLEvents");r.initEvent(t,!1,!0),e.dispatchEvent(r)}function Ai(e,t){var r,n=new XMLHttpRequest,o="string"==typeof e?e:Object.keys(e).map(function(t){return"".concat(encodeURIComponent(t),"=").concat(encodeURIComponent(e[t]))}).join("&");return n.open("post",ajaxurl,!0),n.onreadystatechange=function(){if(n.readyState>3&&200==n.status){r=n.responseText;try{r=JSON.parse(r)}catch(e){}t(r)}},n.setRequestHeader("X-Requested-With","XMLHttpRequest"),n.setRequestHeader("Content-type","application/x-www-form-urlencoded"),n.send(o),n}function Si(e,t){e.classList.add("frm-fade"),setTimeout(t,1e3)}function Li(e){jQuery(e).css("visibility","hidden")}function Ii(e){jQuery(e).css("visibility","visible")}function Bi(e,t){return r(4260).initModal(e,t)}function qi(e,t){if("#"===t){var r=document.getElementById(e),n=r.style.display;r.style.display="none"===n?"block":"none"}else e.is(":visible")?e.hide():e.show()}function Ci(){window.onbeforeunload=null;var e=jQuery(window);e.off("beforeunload.widgets"),e.off("beforeunload.edit-post")}function Ni(){var e=jQuery(this).closest(".frm-single-settings").data("fid"),t=document.getElementById("frm_field_id_".concat(e));if(t&&"form"===t.dataset.type)if(t=jQuery(t),this.options[this.selectedIndex].value){t.find(".frm-not-set")[0].classList.add("frm_hidden");var r=t.find(".frm-embed-message");r.html(r.data("embedmsg")+this.options[this.selectedIndex].text),t.find(".frm-embed-field-placeholder")[0].classList.remove("frm_hidden")}else t.find(".frm-not-set")[0].classList.remove("frm_hidden"),t.find(".frm-embed-field-placeholder")[0].classList.add("frm_hidden")}function Ti(){var e=jQuery(this).closest(".frm-single-settings"),t=e.find(".frmjs_product_choices"),r=e.find(".frm_prod_options_heading"),n=this.options[this.selectedIndex].value;t.removeClass("frm_prod_type_single frm_prod_type_user_def"),r.removeClass("frm_prod_user_def"),"single"===n?t.addClass("frm_prod_type_single"):"user_def"===n&&(t.addClass("frm_prod_type_user_def"),r.addClass("frm_prod_user_def"))}function Oi(e){var t=document.getElementById("frm_field_id_".concat(e));return!!t&&"product"===t.getAttribute("data-type")}function Fi(){var e=function(e,t){return window.frmCachedSubFields=window.frmCachedSubFields||{},window.frmCachedSubFields[e]=window.frmCachedSubFields[e]||{},window.frmCachedSubFields[e][t]},t=function(e,t,r){window.frmCachedSubFields=window.frmCachedSubFields||{},window.frmCachedSubFields[e]=window.frmCachedSubFields[e]||{},window.frmCachedSubFields[e][t]=r},r=[1,2,3,4,5,6,7,8,9,10,11,12].map(function(e){return"frm".concat(e)}),o=["first","middle","last"];document.addEventListener("change",function(i){i.target.matches(".frm_name_layout_dropdown")&&function(i){var a,l=i.target.value.split("_"),s=i.target.dataset.fieldId,c=document.querySelector("#field_".concat(s,"_inner_container .frm_combo_inputs_container")),d=(a=l.length,"frm".concat(parseInt(12/a)));o.forEach(function(e){var o,i=c.querySelector('[data-sub-field-name="'.concat(e,'"]'));i&&(i.classList.add("frm_hidden"),(o=i.classList).remove.apply(o,n(r)),t(s,e,i))}),l.forEach(function(t){var r=e(s,t);r&&(r.classList.remove("frm_hidden"),r.classList.add(d),c.append(r))}),o.forEach(function(e){var r=document.querySelector(".frm_sub_field_options-".concat(e,'[data-field-id="').concat(s,'"]'));r&&(r.classList.add("frm_hidden"),t(s,"".concat(e,"_options"),r))}),l.forEach(function(t){var r=e(s,"".concat(t,"_options"));r&&r.classList.remove("frm_hidden")})}(i)},!1)}function Di(e,t){var r,n,o,i=!1,a=!1;(r=t.newOption?(new DOMParser).parseFromString(t.newOption,"text/html").body.childNodes[0]:t).querySelectorAll("svg").forEach(function(e){(n=e.getElementsByTagNameNS("http://www.w3.org/2000/svg","use")[0])&&("#frm_drag_icon"===(o=qo(n))&&(i=!0),"#frm_save_icon"===o&&(a=!0))}),i||r.prepend(h.drag.cloneNode(!0)),r.querySelector("[id^=field_key_".concat(e,"-]"))&&!a&&r.querySelector("[id^=field_key_".concat(e,"-]")).after(h.save.cloneNode(!0)),t.newOption&&(t.newOption=r)}function Mi(){var e=document.getElementById("frm_leave_email").value.trim();if(""!==e)if(!1!==/^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(e)){var t=jQuery("#frmapi-email-form").find("form"),r=t.find('[type="email"]').not(".frm_verify");if(r.length){if(document.getElementById("frm_empty_inbox")){document.getElementById("frm-add-my-email-address").remove();var n=document.getElementById("frm_leave_email_wrapper");if(n){n.classList.add("frm_hidden");var o=d({className:"frm-wait frm_spinner"});o.style.visibility="visible",o.style.float="none",o.style.width="unset",n.parentElement.insertBefore(o,n.nextElementSibling)}}r.val(e),jQuery.ajax({type:"POST",url:t.attr("action"),data:"".concat(t.serialize(),"&action=frm_forms_preview")}).done(function(e){if(jQuery(e).find(".frm_message").text().trim().includes("Thanks!")){var t=document.getElementById("frmapi-email-form").parentElement.querySelector(".frm_spinner");t&&t.remove(),wp.hooks.applyFilters("frm_thank_you_on_signup",!0)&&document.getElementById("frm_leave_email_wrapper").replaceWith(d(I("Thank you for signing up!","formidable")))}else pi("invalid")})}}else pi("invalid");else pi("empty")}function Pi(e){var t;if(O||e.stopPropagation(),!(e.target.classList.contains("frm-show-box")||null!==(t=e.target.parentElement)&&void 0!==t&&t.classList.contains("frm-show-box"))){var r=document.getElementById("frm_adv_info");r&&(r.dataset.fills===e.target.id&&void 0!==e.target.id||e.target.closest("#frm_adv_info")||"none"===r.style.display||$o(r))}}return{init:function(){var e,t,o,i,a,l,s;!function(){jQuery(document).on("click","#frm-add-my-email-address",function(e){e.preventDefault(),Mi()});var e=document.getElementById("frm_empty_inbox"),t=document.getElementById("frm_leave_email");if(e&&t){var r=document.getElementById("frm-leave-email-modal");r.classList.remove("frm_hidden"),r.querySelector(".frm_modal_footer").classList.add("frm_hidden"),t.addEventListener("keyup",function(e){if("Enter"===e.key){var t=document.getElementById("frm-add-my-email-address");t&&t.click()}})}}(),t=document.querySelector(".frm-admin-footer-links"),o=null!==(e=document.querySelector(".frm_page_container"))&&void 0!==e?e:document.getElementById("wpbody-content"),t&&o&&(o.append(t),t.classList.remove("frm_hidden")),document.addEventListener("show.bs.dropdown",function(){z()}),C={},jQuery(".wp-admin").on("click",function(e){var t=jQuery(e.target),r=jQuery(".dropdown.open");!r.length||t.hasClass("dropdown")||t.closest(".dropdown").length||r.removeClass("open")}),jQuery("#frm_bs_dropdown:not(.open) a").on("click",At),void 0===E&&(E=jQuery(document.getElementById("form_id")).val()),document.querySelectorAll(".frm-warning-dismiss").forEach(function(e){_(e,St)}),frmAdminBuild.inboxBannerInit(),b.length>0?frmAdminBuild.buildInit():null!==document.getElementById("frm_notification_settings")?frmAdminBuild.settingsInit():null!==document.getElementById("frm_styling_form")?frmAdminBuild.styleInit():null!==document.getElementById("form_global_settings")?frmAdminBuild.globalSettingsInit():null!==document.getElementById("frm_export_xml")?frmAdminBuild.exportInit():null!==document.querySelector(".frm-inbox-wrapper")?frmAdminBuild.inboxInit():null!==document.getElementById("frm-welcome")?frmAdminBuild.solutionInit():(function(){if(document.body.classList.contains("frm-admin-page-entries")){var e=document.getElementById("screen-options-wrap");if(e){var t=c({className:"frm_warning_style",text:I("Only 10 columns can be selected at a time.","formidable")});t.style.margin=0;var r=e.querySelector("legend");r.parentNode.insertBefore(t,r.nextElementSibling);var n=Array.from(e.querySelectorAll('input[type="checkbox"]')),o=function(){n.reduce(function(e,t){return t.checked?e+1:e},0)>=10?(t.classList.remove("frm_hidden"),n.forEach(function(e){e.checked||(e.parentNode.classList.add("frm_noallow"),e.disabled=!0)})):t.classList.add("frm_hidden")};o(),n.forEach(function(e){e.addEventListener("change",function(e){e.target.checked?o():(t.classList.add("frm_hidden"),n.forEach(function(e){e.parentNode.classList.remove("frm_noallow"),e.disabled=!1}))})})}}}(),yi(),jQuery("[data-frmprint]").on("click",function(){return window.print(),!1})),jQuery(document).on("change","select[data-toggleclass], input[data-toggleclass]",xo),function(){function e(e){var t=e.options[e.selectedIndex];e.querySelectorAll("option[data-dependency]:not([data-dependency-skip])").forEach(function(e){var r=document.querySelector(e.dataset.dependency);null==r||r.classList.toggle("frm_hidden",t!==e)})}document.querySelectorAll("select.frm_select_with_dependency").forEach(e),frmDom.util.documentOn("change","select.frm_select_with_dependency",function(t){return e(t.target)})}(),(jQuery(document.getElementById("frm_adv_info")).length>0||jQuery(".frm_field_list").length>0)&&frmAdminBuild.panelInit(),i=jQuery(".wrap, .frm_wrap"),a=document.getElementById("frm_confirm_modal"),l=!1,s=!1,jQuery(a).on("click","[data-deletefield]",Qr),jQuery(a).on("click","[data-removeid]",R),jQuery(a).on("click","[data-trashtemplate]",wi),i.on("click",".frm_remove_tag, .frm_remove_form_action",R),i.on("click","a[data-frmverify]",F),i.on("click","a[data-frmtoggle]",P),i.on("click","a[data-frmhide], a[data-frmshow]",H),i.on("change","input[data-frmhide], input[data-frmshow]",H),i.on("click",".widget-top,a.widget-action",G),i.on("mouseenter.frm",".frm_bstooltip, .frm_help",function(){jQuery(this).off("mouseenter.frm"),function(e){var t=arguments.length>1&&void 0!==arguments[1]&&arguments[1],r=e;(r.hasAttribute("data-toggle")||r.hasAttribute("data-bs-toggle"))&&(r.parentElement.setAttribute("title",r.getAttribute("title")),r.removeAttribute("title"),r.classList.remove("frm_bstooltip"),r.parentElement.classList.add("frm_bstooltip"),r=r.parentElement),jQuery(r).tooltip(),t&&(z(),jQuery(r).tooltip("show"))}(this,!0)}),jQuery(document).on("click","#doaction, #doaction2",function(e){var t="doaction"===this.id?"top":"bottom",r=document.getElementById("bulk-action-selector-".concat(t)),n=document.getElementById("confirm-bulk-delete-".concat(t));if(r&&n){if(l=this,!s&&"bulk_delete"===r.value)return e.preventDefault(),D(n),!1}else l=!1}),jQuery(document).on("click","#frm-confirmed-click",function(e){if(!1!==l&&!e.target.classList.contains("frm-btn-inactive"))return"confirm-bulk-delete"===this.getAttribute("href")?(e.preventDefault(),s=!0,l.click(),!1):void 0}),r(4260).initUpgradeModal(),frmDom.util.documentOn("click","[data-modal-title]",Kn);var d=jQuery(document.getElementById("frm_shortcodediv"));d.length>0&&(jQuery("a.edit-frm_shortcode").on("click",function(){return d.is(":hidden")&&(d.slideDown("fast"),this.style.display="none"),!1}),jQuery(".cancel-frm_shortcode","#frm_shortcodediv").on("click",function(){return d.slideUp("fast"),d.siblings("a.edit-frm_shortcode").show(),!1})),jQuery(document).on("click","#frm-nav-tabs a",U),jQuery(".post-type-frm_display .frm-nav-tabs a, .frm-category-tabs a").on("click",function(){var e=this.classList.contains("frm_show_upgrade_tab");if(!this.classList.contains("frm_noallow")||e)return e&&Jn(this),W(this),!1}),W(jQuery(".starttab a"),"auto"),jQuery(document).on("click","#frm-fid-search-menu a",function(){var e=this.id.replace("fid-","");return jQuery('select[name="fid"]').val(e),zn(document.getElementById("posts-filter")),!1}),jQuery(".frm_select_box").on("click focus",function(){this.select()}),jQuery(document).on("input search change",".frm-auto-search:not(#frm-form-templates-page #template-search-input)",Qi),jQuery(document).on("focusin click",".frm-auto-search",Ei);var f=jQuery(".frm-auto-search");""!==f.val()&&f.trigger("keyup"),FrmFormsConnect.init(),jQuery(document).on("click",".frm-install-addon",ui),jQuery(document).on("click",".frm-activate-addon",fi),jQuery(document).on("click",".frm-solution-multiple",di),jQuery("button, input[type=submit]").on("click",Ci),document.addEventListener("click",function(e){if("LABEL"===e.target.nodeName){var t=e.target.getAttribute("for");if(t){var r=document.getElementById(t);if(r&&r.nextElementSibling){var n=r.nextElementSibling.querySelector("button.dropdown-toggle.multiselect");n&&setTimeout(function(){return n.click()},0)}}}}),frmAdminBuild.hooks.addFilter("frm_before_embed_modal",function(e,t){var r,n,o=t.element;if("form"!==t.type)return e;var i=o.closest("tr");if(i)r=parseInt(i.querySelector(".column-id").textContent),n=i.querySelector(".column-form_key").textContent;else{r=document.getElementById("form_id").value;var a=document.getElementById("frm_form_key");if(a)n=a.value;else{var l=document.getElementById("frm-previewDrop");l&&(n=l.nextElementSibling.querySelector(".dropdown-item a").getAttribute("href").split("form=")[1])}}return[r,n]}),document.querySelectorAll("#frm-show-fields > li, .frm_grid_container li").forEach(function(e,t){e.addEventListener("click",function(){var e,t,r;t=(null===(e=this.querySelector("li"))||void 0===e?void 0:e.dataset.fid)||this.dataset.fid,(r=document.querySelectorAll("[id^=frm_delete_field_".concat(t,"-]"))).length<2||n(r).slice(1).forEach(function(e,r){e.classList.contains("frm_other_option")||Di(t,e)})})});var u=document.getElementById("frm_small_screen_proceed_button");u&&_(u,function(){var e;null===(e=document.getElementById("frm_small_device_message_container"))||void 0===e||e.remove(),p("small_screen_proceed",new FormData)});var m=document.getElementById("frm_sale_banner"),g=null==m?void 0:m.querySelector(".dismiss");m&&(_(m,function(e){e.target.closest(".dismiss")||(window.location.href=m.getAttribute("data-url"))}),g&&_(g,function(){m.remove();var e=new FormData;p("sale_banner_dismiss",e)}))},buildInit:function(){jQuery("#frm_builder_page").on("mouseup","*:not(.frm-show-box)",Pi),g=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:100;return frmDom.util.debounce(e,t)}(oe,10),y=document.getElementById("post-body-content"),v=jQuery(y),jQuery(".frm_field_loading").length&&Ee(jQuery(".frm_field_loading").first().attr("id")),V("ul.frm_sorting"),document.querySelectorAll(".field_type_list > li:not(.frm_show_upgrade):not(.frm_show_update)").forEach(X),jQuery("ul.field_type_list, .field_type_list li, ul.frm_code_list, .frm_code_list li, .frm_code_list li a, #frm_adv_info #category-tabs li, #frm_adv_info #category-tabs li a").disableSelection(),jQuery(".frm_submit_ajax").on("click",Hn),jQuery(".frm_submit_no_ajax").on("click",Gn),Wn(),jQuery("a.edit-form-status").on("click",Sn),jQuery(".cancel-form-status").on("click",Ln),jQuery(".save-form-status").on("click",function(){var e=jQuery(document.getElementById("form_change_status")).val();return jQuery('input[name="new_status"]').val(e),jQuery(document.getElementById("form-status-display")).html(e),jQuery(".cancel-form-status").trigger("click"),!1}),jQuery(".frm_form_builder form").first().on("submit",function(){jQuery(".inplace_field").trigger("blur")}),ci(),Fr();var e,t=jQuery(j),r=document.getElementById("frm_form_editor_container");t.on("click",".frm_add_logic_row",Ar),t.on("click",".frm_add_watch_lookup_row",Lr),t.on("change",".frm_get_values_form",Tr),t.on("change",".frm_logic_field_opts",wn),t.on("frm-multiselect-changed",'select[name^="field_options[admin_only_"]',In),jQuery(document.getElementById("frm-insert-fields")).on("click",".frm_add_field",Ae),b.on("click",".frm_clone_field",Be),t.on("blur",'input[id^="frm_calc"]',Je),t.on("change","input.frm_format_opt, input.frm_max_length_opt",lt),t.on("change click","[data-changeme]",it),t.on("click","input.frm_req_field",st),t.on("click",".frm_mark_unique",dt),t.on("change",".frm_repeat_format",Jr),t.on("change",".frm_repeat_limit",Xr),t.on("change",".frm_js_checkbox_limit",Yr),t.on("input",'input[name^="field_options[add_label_"]',function(){Zr(this,"add")}),t.on("input",'input[name^="field_options[remove_label_"]',function(){Zr(this,"remove")}),t.on("change",'select[name^="field_options[data_type_"]',Or),jQuery(r).on("click",".frm-collapse-page",Dr),jQuery(r).on("click",".frm-collapse-section",Hr),t.on("click",".frm-single-settings h3, .frm-single-settings h4.frm-collapsible",zr),t.on("keydown",".frm-single-settings h3, .frm-single-settings h4.frm-collapsible",function(e){"Enter"!==e.key&&" "!==e.key||(e.preventDefault(),zr.call(this,e))}),jQuery(r).on("show.bs.dropdown hide.bs.dropdown",He),t.on("click",".frm_toggle_sep_values",yt),t.on("click",".frm_toggle_image_options",vt),t.on("click",".frm_remove_image_option",Et),t.on("click",".frm_choose_image_box",xt),t.on("change",".frm_hide_image_text",Qt),t.on("change",".frm_field_options_image_size",jt),t.on("click",".frm_multiselect_opt",kt),b.on("mousedown","input, textarea, select",Lt),b.on("click","input[type=radio], input[type=checkbox]",Lt),b.on("click",".frm_delete_field",Nt),b.on("click",".frm_select_field",Tt),jQuery(document).on("click",".frm_delete_field_group",Ot),jQuery(document).on("click",".frm_clone_field_group",Ft),jQuery(document).on("click","#frm_field_group_controls > span:first-child",Dt),jQuery(document).on("click",".frm-row-layout-option",Yt),jQuery(document).on("click",".frm-merge-fields-into-row .frm-row-layout-option",Zt),jQuery(document).on("click",".frm-custom-field-group-layout",tr),jQuery(document).on("click",".frm-merge-fields-into-row .frm-custom-field-group-layout",nr),jQuery(document).on("click",".frm-break-field-group",sr),b.on("click","#frm_field_group_popup .frm_grid_container input",cr),jQuery(document).on("click",".frm-cancel-custom-field-group-layout",dr),jQuery(document).on("click",".frm-save-custom-field-group-layout",ur),b.on("click","ul.frm_sorting",mr),jQuery(document).on("click",".frm-merge-fields-into-row",br),jQuery(document).on("click",".frm-delete-field-groups",wr),b.on("click",'.frm-field-action-icons [data-toggle="dropdown"]',function(){this.closest("li.form-field").classList.add("frm-field-settings-open"),jQuery(document).on("click","#frm_builder_page",Te)}),b.on("mousemove","ul.frm_sorting",Oe),b.on("show.bs.dropdown",".frm-field-action-icons",Me),jQuery(document).on("show.bs.dropdown","#frm_field_group_controls",Pe),t.on("click",".frm_single_option a[data-removeid]",It),t.on("mousedown",".frm_single_option input[type=radio]",Bt),t.on("focusin",".frm_single_option input[type=text]",qt),t.on("click",".frm_add_opt",_t),t.on("change",".frm_single_option input",tn),t.on("change",".frm_image_id",tn),t.on("change",".frm_toggle_mult_sel",pt),b.on("click",".frm_primary_label",Gr),b.on("click",".frm_description",Ur),b.on("click","li.ui-state-default:not(.frm_noallow)",Vr),b.on("dblclick","li.ui-state-default",Kr),t.on("change",".frm_tax_form_select",en),t.on("change","select.conf_field",ft),t.on("change",".frm_get_field_selection",Qn),t.on("click",".frm-show-inline-modal",Cn),t.on("keydown",".frm-show-inline-modal",function(e){var t=e.key;"Enter"!==t&&" "!==t||(e.preventDefault(),Cn.call(this,e))}),t.on("click",".frm-inline-modal .dismiss",Nn),jQuery(document).on("change","[data-frmchange]",On),document.addEventListener("click",Tn),t.on("change",".frm_include_extras_field",et),t.on("change",'select[name^="field_options[form_select_"]',Ni),jQuery(document).on("submit","#frm_js_build_form",Ho),jQuery(document).on("change","#frm_builder_page input:not(.frm-search-input):not(.frm-custom-grid-size-input), #frm_builder_page select, #frm_builder_page textarea",Po),nt(),jQuery(document).on("change",".frmjs_prod_data_type_opt",Ti),jQuery(document).on("focus",'.frm-single-settings ul input[type="text"][name^="field_options[options_"]',Br),jQuery(document).on("blur",'.frm-single-settings ul input[type="text"][name^="field_options[options_"]',Cr),frmDom.util.documentOn("click",".frm-show-field-settings",Vr),frmDom.util.documentOn("change","select.frm_format_dropdown, select.frm_phone_type_dropdown",$r),t.on("keydown",'.frm_single_option input[name^="field_options["], .frm_single_option input[name^="rows_"]',function(e){"Enter"===e.key&&function(e){var t=e.closest(".frm_single_option").parentElement.querySelectorAll('.frm_single_option input[name^="field_options[" ], .frm_single_option input[name^="rows_"]'),r=Array.from(t),n=r.indexOf(e);if(!(n<0)){var o=r.slice(n+1).find(function(e){return null!==e.offsetParent});if(o){o.focus();var i=o.value.length;o.setSelectionRange(i,i)}}}(e.currentTarget)}),!1!==(e=Bi("#frm-bulk-modal","700px"))&&(jQuery(".frm-insert-preset").on("click",mt),jQuery(j).on("click","a.frm-bulk-edit-link",function(t){t.preventDefault();var r="",n=jQuery(this).closest("[data-fid]").data("fid"),o=yn(n),i=Oi(n),a=document.getElementById("frm_field_".concat(n,"_opts"));if(a){var l=a.getElementsByTagName("li");document.getElementById("bulk-field-id").value=n;for(var s=0;s=l.length-1&&(document.getElementById("frm_bulk_options").value=r)}return e.dialog("open"),!1}}),jQuery("#frm-update-bulk-opts").on("click",function(){var t=document.getElementById("bulk-field-id").value;document.getElementById("bulk-option-type").value||(this.classList.add("frm_loading_button"),frmAdminBuild.updateOpts(t,document.getElementById("frm_bulk_options").value,e),Po())})),qn(),document.addEventListener("frm_added_field",qn),Ie(),Fi(),kn(),frmDom.util.documentOn("change",".frm_show_password_setting_input",function(e){var t=e.target.getAttribute("data-fid"),r=document.getElementById("frm_field_id_".concat(t));r&&r.classList.toggle("frm_disabled_show_password",!e.target.checked)}),document.addEventListener("scroll",Fo,!0),document.addEventListener("change",To),document.querySelector(".frm_form_builder").addEventListener("mousedown",function(e){e.shiftKey&&e.preventDefault()}),wp.hooks.addAction("frmShowedFieldSettings","formidableAdmin",function(e,t){t.querySelectorAll(".frm-collapse-me").forEach(Rr)},9999)},settingsInit:function(){var e=jQuery(document.getElementById("frm_notification_settings"));e.on("click",".frm_email_buttons",io),e.on("click",".frm_remove_field",ao),e.on("change",".frm_to_row, .frm_from_row",lo),e.on("change",".frm_tax_selector",wo),e.on("change","select.frm_single_post_field",_o),e.on("change","select.frm_toggle_post_content",po),e.on("change","select.frm_dyncontent_opt",go),e.on("change",".frm_post_type",yo),e.on("click",".frm_add_postmeta_row",bo),e.on("click",".frm_add_posttax_row",ho),e.on("click",".frm_toggle_cf_opts",Qo),e.on("click",".frm_duplicate_form_action",Zn),jQuery(".frm_actions_list").on("click",".frm_active_action",to),jQuery("#frm-show-groups, #frm-hide-groups").on("click",ro),ci(),jQuery("ul.frm_actions_list li").each(function(){so(jQuery(this).children("a").data("actiontype"));var e=jQuery(this).find("i");"none"!==e.css("background-image")&&e.addClass("frm-inverse")}),jQuery(".frm_submit_settings_btn").on("click",Eo),Wn();var t=jQuery(".frm_form_settings");t.on("click",".frm_add_form_logic",mo),t.on("click",".frm_already_used",uo),document.addEventListener("click",function(e){var t=e.target;t.closest(".frm_image_preview_wrapper")&&(t.closest(".frm_choose_image_box")?xt.bind(t)(e):t.closest(".frm_remove_image_option")&&Et.bind(t)(e))}),t.on("mouseup","*:not(.frm-show-box)",Pi),jQuery(document.getElementById("no_save")).on("change",function(){this.checked&&!0!==confirm(i.no_save_warning)&&jQuery(this).attr("checked",!1)}),jQuery('select[name="options[edit_action]"]').on("change",Yn);var r=document.getElementById("logged_in");jQuery(r).on("change",function(){this.checked?Ii(".hide_logged_in"):Li(".hide_logged_in")});var n=jQuery(document.getElementById("frm_cookie_expiration"));jQuery(document.getElementById("frm_single_entry_type")).on("change",function(){"cookie"===this.value?n.fadeIn("slow"):n.fadeOut("slow")});var o=document.getElementById("single_entry");jQuery(o).on("change",function(){this.checked?Ii(".hide_single_entry"):Li(".hide_single_entry"),this.checked&&"cookie"===jQuery(document.getElementById("frm_single_entry_type")).val()?n.fadeIn("slow"):n.fadeOut("slow")}),jQuery(".hide_save_draft").hide();var a=jQuery(document.getElementById("save_draft"));a.on("change",function(){this.checked?jQuery(".hide_save_draft").fadeIn("slow"):jQuery(".hide_save_draft").fadeOut("slow")}),Rn(a);var l=document.getElementById("editable");jQuery(l).on("change",function(){this.checked?(jQuery(".hide_editable").fadeIn("slow"),Rn(document.getElementById("edit_action"))):(jQuery(".hide_editable").fadeOut("slow"),jQuery(".edit_action_message_box").fadeOut("slow"))}),jQuery(document).on("change","#protect_files",function(){this.checked?jQuery(".hide_protect_files").fadeIn("slow"):jQuery(".hide_protect_files").fadeOut("slow")}),jQuery(document).on("frm-multiselect-changed","#protect_files_role",In),jQuery(document).on("submit",".frm_form_settings",zo),jQuery(document).on("change","#form_settings_page input:not(.frm-search-input), #form_settings_page select, #form_settings_page textarea",Po),yi(),jQuery(document).on("frm-action-loaded",Jo),frmDom.util.documentOn("change",'.frm_on_submit_type input[type="radio"]',function(e){if(e.target.checked){var t=e.target.closest(".frm_form_action_settings");t.querySelectorAll(".frm_on_submit_dependent_setting:not(.frm_hidden)").forEach(function(e){e.classList.add("frm_hidden")}),t.querySelectorAll(".frm_on_submit_dependent_setting[data-show-if-".concat(e.target.value,"]")).forEach(function(e){e.classList.remove("frm_hidden")}),t.setAttribute("data-on-submit-type",e.target.value)}}),wp.hooks.addAction("frm_reset_fields_updated","formidableAdmin",Ro)},panelInit:function(){jQuery(".frm_wrap, #postbox-container-1").on("click",".frm_insert_code",ko),jQuery(document).on("change",".frm_insert_val",function(){Ao(jQuery(this).data("target"),jQuery(this).val()),jQuery(this).val("")}),jQuery(document).on("click change",'[name="frm-id-key-condition"]',Io),jQuery(document).on("keyup change",".frm-build-logic",Bo),Xn(),jQuery(document).on("frmElementAdded",function(e,t){Xn(t)}),jQuery(document).on("mousedown",".frm-show-box",No);var e=document.getElementById("form_settings_page"),t=document.body.classList.contains("post-type-frm_display"),r=document.getElementById("frm_insert_fields_tab");(e||t||O)&&jQuery(document).on("focusin","form input, form textarea",function(n){var o,i,a;if(n.stopPropagation(),Co(this),jQuery(this).is(":not(:submit, input[type=button], .frm-search-input, input[type=checkbox])")){if(jQuery(n.target).closest("#frm_adv_info").length)return;if(e||O)o=jQuery("#frm_html_tab"),jQuery(this).closest("#html_settings").length>0?(o.show(),o.siblings().hide(),jQuery("#frm_html_tab a").trigger("click"),void 0===(a=this.id)||a.includes("-search-input")||(jQuery("#frm-adv-info-tab").attr("data-fills",a.trim()),this.classList.contains("field_custom_html")&&(a="field_custom_html"),jQuery.inArray(a,["after_html","before_html","submit_html","field_custom_html"])>=0&&(jQuery(".frm_code_list li:not(.show_".concat(a,")")).addClass("frm_hidden"),jQuery(".frm_code_list li.show_".concat(a)).removeClass("frm_hidden")))):((i=jQuery(".frm-category-tabs li"))[0]&&(i[0].style.display=""),r.click(),o.hide(),o.siblings().show());else if(t){var l=new CustomEvent("frm_legacy_views_handle_field_focus");l.frmData={idAttrValue:this.id},document.dispatchEvent(l)}}}),jQuery(".frm_wrap, #postbox-container-1").on("mousedown","#frm_adv_info a, .frm_field_list a",function(e){e.preventDefault()});var n=jQuery("#frm_adv_info");n.on("click",".subsubsub a.frmids",function(e){Ko("frmids",e)}),n.on("click",".subsubsub a.frmkeys",function(e){Ko("frmkeys",e)})},inboxInit:function(){var e;jQuery(".frm_inbox_dismiss").on("click",function(e){var t=this.parentNode.parentNode,r=t.getAttribute("data-message"),n=this.getAttribute("href"),o=t.cloneNode(!0),i=document.querySelector(".frm-dismissed-inbox-messages");if("free_templates"!==r||this.classList.contains("frm_inbox_dismiss")){e.preventDefault();var a={action:"frm_inbox_dismiss",key:r,nonce:frmGlobal.nonce},l="frm_inbox_slide_in"===t.id;l&&(t.classList.remove("s11-fadein"),t.classList.add("s11-fadeout"),t.addEventListener("animationend",function(){return t.remove()},{once:!0})),Ai(a,function(){if(!l)return"#"!==n?(window.location=n,!0):void Si(t,function(){var e;i&&(o.classList.remove("frm-fade"),null===(e=o.querySelector(".frm-inbox-message-heading .frm_inbox_dismiss"))||void 0===e||e.remove(),i.append(o)),1===t.parentNode.querySelectorAll(".frm-inbox-message-container").length&&(document.getElementById("frm_empty_inbox").classList.remove("frm_hidden"),t.parentNode.closest(".frm-active").classList.add("frm-empty-inbox"),_i()),t.remove()})})}}),!1===(null===(e=document.getElementById("frm_empty_inbox"))||void 0===e?void 0:e.classList.contains("frm_hidden"))&&_i()},solutionInit:function(){jQuery(document).on("submit","#frm-new-template",hi)},styleInit:function(){var e=jQuery(".frm_image_preview_wrapper");e.on("click",".frm_choose_image_box",xt),e.on("click",".frm_remove_image_option",Et),wp.hooks.doAction("frm_style_editor_init")},customCSSInit:function(){console.warn("Calling frmAdminBuild.customCSSInit is deprecated.")},globalSettingsInit:function(){jQuery(document).on("click","[data-frmuninstall]",Xo),ci();var e=document.getElementById("licenses_settings");e&&jQuery(e).on("click",".edd_frm_save_license",Yo),jQuery(document).on("click","#frm-new-template button",vi),jQuery("#frm-dismissable-cta .dismiss").on("click",function(e){e.preventDefault(),jQuery.post(ajaxurl,{action:"frm_lite_settings_upgrade",nonce:frmGlobal.nonce}),jQuery(".settings-lite-cta").remove()});var t=document.getElementById("frm_re_type");t&&t.addEventListener("change",ji),document.querySelector(".frm_captchas").addEventListener("change",function(e){var t,r=null===(t=document.querySelector('.frm_captchas input[checked="checked"]'))||void 0===t?void 0:t.value,n=e.target.value!==r;document.querySelector(".captcha_settings .frm_note_style").classList.toggle("frm_hidden",!n)}),frmDom.util.documentOn("submit",".frm_settings_form",function(){x=0});var r=document.getElementById("manage_styles_settings");r&&r.addEventListener("change",function(e){var t=e.target;"SELECT"===t.nodeName&&t.dataset.name&&!t.getAttribute("name")&&t.setAttribute("name",t.dataset.name)});var n=document.getElementById("payments_settings"),o=null==n?void 0:n.querySelectorAll('[name="frm_payment_section"]');o&&o.forEach(function(e){e.addEventListener("change",function(){if(e.checked){var t=n.querySelector('label[for="'.concat(e.id,'"]'));t&&t.setAttribute("aria-selected","true"),o.forEach(function(t){if(t!==e){var r=n.querySelector('label[for="'.concat(t.id,'"]'));r&&r.setAttribute("aria-selected","false")}})}})})},exportInit:function(){jQuery(".frm_form_importer").on("submit",Zo),jQuery(document.getElementById("frm_export_xml")).on("submit",ti),jQuery("#frm_export_xml input, #frm_export_xml select").on("change",ri),jQuery('input[name="frm_import_file"]').on("change",ni),document.querySelector('select[name="format"]').addEventListener("change",ii),jQuery('input[name="frm_export_forms[]"]').on("click",si),ci(),jQuery(".frm-feature-banner .dismiss").on("click",function(e){e.preventDefault(),jQuery.post(ajaxurl,{action:"frm_dismiss_migrator",plugin:this.id,nonce:frmGlobal.nonce}),this.parentElement.remove()}),li(oi()),document.querySelector("#frm-export-select-all").addEventListener("change",function(e){document.querySelectorAll('[name="frm_export_forms[]"]').forEach(function(t){t.checked=e.target.checked})})},inboxBannerInit:function(){var e=document.getElementById("frm_banner");if(e){var t=e.querySelector(".frm-banner-dismiss");document.addEventListener("click",function(r){r.target===t&&Ai({action:"frm_inbox_dismiss",key:e.dataset.key,nonce:frmGlobal.nonce},function(){jQuery(e).fadeOut(400,function(){e.remove()})})})}},updateOpts:function(e,t,r){var n=yn(e),o=Oi(e)?"frm_bulk_products":"frm_import_options";jQuery.ajax({type:"POST",url:ajaxurl,data:{action:o,field_id:e,opts:t,separate:n,nonce:frmGlobal.nonce},success:function(t){document.getElementById("frm_field_".concat(e,"_opts")).innerHTML=t,wp.hooks.doAction("frm_after_bulk_edit_opts",e),on(e),void 0!==r&&(r.dialog("close"),document.getElementById("frm-update-bulk-opts").classList.remove("frm_loading_button"))}})},triggerRemoveLogic:function(e,t){jQuery("#frm_logic_".concat(e,"_").concat(t," .frm_remove_tag")).trigger("click")},downloadXML:function(e,t,r){var n="".concat(ajaxurl,"?action=frm_").concat(e,"_xml&ids=").concat(t);null!==r&&(n="".concat(n,"&is_template=").concat(r)),location.href=n},hooks:{applyFilters:function(e){for(var t,r=arguments.length,n=new Array(r>1?r-1:0),o=1;o1?r-1:0),o=1;o1&&void 0!==arguments[1]?arguments[1]:{};return new Promise(function(r){var n=E,o=0;"summary"===e&&(o=b.children('li[data-type="break"]').length>0?1:0),jQuery.ajax({type:"POST",url:ajaxurl,data:Object.assign(_e(e,0,n,o),{field_options:t}),success:function(t){r(t),setTimeout(function(){En(),We(t,!0);var r=ye(t);r&&wp.hooks.doAction("frm_after_field_added_in_form_builder",{field:t,fieldId:r,fieldType:e,form_id:n})},10)},error:he})})},confirmLinkClick:D,handleInsertFieldByDraggingResponse:ge,handleAddFieldClickResponse:Le,syncLayoutClasses:ae,moveFieldSettings:oo,maybeCollapseSettings:zr}},window.frmAdminBuild=frmAdminBuildJS(),jQuery(document).ready(function(){var e;frmAdminBuild.init(),document.querySelectorAll(".frm-dropdown-menu").forEach(function(e){e.classList.add("dropdown-menu");var t,r,n=e.querySelector(".frm-dropdown-toggle");n&&(n.hasAttribute("role")||n.setAttribute("role","button"),n.hasAttribute("tabindex")||n.setAttribute("tabindex",0)),"UL"===e.tagName&&(r=(r=(r=(r=(r=(r=(t=e).outerHTML).replace("
                      ","")).replaceAll("
                    • ",'
                    • ",""),t.outerHTML=r)}),null===(e=document.querySelector(".preview.dropdown .frm-dropdown-toggle"))||void 0===e||e.setAttribute("data-bs-toggle","dropdown"),document.querySelectorAll("[data-toggle]").forEach(function(e){return e.setAttribute("data-bs-toggle",e.getAttribute("data-toggle"))})}),window.frm_show_div=function(e,t,r,n){t==r?jQuery(n+e).fadeIn("slow").css("visibility","visible"):jQuery(n+e).fadeOut("slow")},window.frmCheckAll=function(e,t){jQuery('input[name^="'.concat(t,'"]')).prop("checked",Boolean(e))},window.frmCheckAllLevel=function(e,t,r){jQuery(".frm_catlevel_".concat(r)).children(".frm_checkbox").children("label").children('input[name^="'.concat(t,'"]')).prop("checked",Boolean(e))},window.frmGetFieldValues=function(e,t,r,n,o,i){e&&jQuery.ajax({type:"POST",url:ajaxurl,data:"action=frm_get_field_values¤t_field=".concat(t,"&field_id=").concat(e,"&name=").concat(o,"&t=").concat(n,"&form_action=").concat(jQuery('input[name="frm_action"]').val(),"&nonce=").concat(frmGlobal.nonce),success:function(e){document.getElementById("frm_show_selected_values_".concat(t,"_").concat(r)).innerHTML=e,"function"==typeof i&&i()}})},window.frmImportCsv=function(e){var t="";"undefined"!=typeof __FRMURLVARS&&(t=__FRMURLVARS),jQuery.ajax({type:"POST",url:ajaxurl,data:"action=frm_import_csv&nonce=".concat(frmGlobal.nonce,"&frm_skip_cookie=1").concat(t),success:function(t){var r=jQuery(".frm_admin_progress_bar").attr("aria-valuemax"),n=r-t,o=n/r*100;jQuery(".frm_admin_progress_bar").css("width","".concat(o,"%")).attr("aria-valuenow",n),parseInt(t,10)>0?(jQuery(".frm_csv_remaining").html(t),frmImportCsv(e)):(jQuery(document.getElementById("frm_import_message")).html(frm_admin_js.import_complete),setTimeout(function(){location.href="?page=formidable-entries&frm_action=list&form=".concat(e,"&import-message=1")},2e3))}})}})(); \ No newline at end of file diff --git a/js/formidable_blocks.js b/js/formidable_blocks.js index 8b0da523ad..726527dba6 100644 --- a/js/formidable_blocks.js +++ b/js/formidable_blocks.js @@ -1,2715 +1 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./js/src/api/class-addon-api.js": -/*!***************************************!*\ - !*** ./js/src/api/class-addon-api.js ***! - \***************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAddonAPI: () => (/* binding */ frmAddonAPI) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAddonAPI = /*#__PURE__*/function () { - function frmAddonAPI() { - _classCallCheck(this, frmAddonAPI); - } - return _createClass(frmAddonAPI, null, [{ - key: "toggleAddonState", - value: - /** - * A function designed to toggle different addon states. - * - * @param {'frm_install_addon'|'frm_activate_addon'|'frm_multiple_addons'} action The addon state action type. - * @param {string} addon The addon path. Ex: formidable-views/formidable-views.php - * - * @return {Promise} The response from the server. - */ - function toggleAddonState(action, addon) { - return fetch(ajaxurl, { - method: 'POST', - headers: { - 'Content-Type': 'application/x-www-form-urlencoded' - }, - body: new URLSearchParams({ - action: action, - nonce: frmGlobal.nonce, - plugin: addon - }) - }).then(function (response) { - return response.json(); - }); - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/api/index.js": -/*!*****************************!*\ - !*** ./js/src/api/index.js ***! - \*****************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAddonAPI: () => (/* reexport safe */ _class_addon_api__WEBPACK_IMPORTED_MODULE_0__.frmAddonAPI) -/* harmony export */ }); -/* harmony import */ var _class_addon_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./class-addon-api */ "./js/src/api/class-addon-api.js"); - - -/***/ }), - -/***/ "./js/src/common/components/icon.js": -/*!******************************************!*\ - !*** ./js/src/common/components/icon.js ***! - \******************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ FormidableIcon) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -/** - * Formidable Forms icon - */ -var Component = wp.element.Component; -var Dashicon = wp.components.Dashicon; -var FormidableIcon = /*#__PURE__*/function (_Component) { - function FormidableIcon() { - _classCallCheck(this, FormidableIcon); - return _callSuper(this, FormidableIcon, arguments); - } - _inherits(FormidableIcon, _Component); - return _createClass(FormidableIcon, [{ - key: "loadCustomSvgIcon", - value: function loadCustomSvgIcon() { - var _formidable_form_sele = formidable_form_selector, - icon = _formidable_form_sele.icon; - if (icon.match(/frm_white_label_icon/)) { - return wp.element.createElement("svg", { - xmlns: "http://www.w3.org/2000/svg", - viewBox: "0 0 20 20", - width: "120", - height: "120" - }, wp.element.createElement("path", { - d: "M18.1 1.3H2C.9 1.3 0 2 0 3V17c0 1 .8 1.9 1.9 1.9H18c1 0 1.9-.9 1.9-2V3.2c0-1-.8-1.9-1.9-1.9zM18 16.9H2a.2.2 0 0 1-.2-.3V3.4c0-.2 0-.3.2-.3H18c.1 0 .2.1.2.3v13.2c0 .2 0 .3-.2.3zm-1.6-3.6v1c0 .2-.3.4-.5.4H8a.5.5 0 0 1-.5-.5v-1c0-.2.2-.4.5-.4h7.8c.2 0 .4.2.4.5zm0-3.8v1c0 .2-.3.4-.5.4H8a.5.5 0 0 1-.5-.4v-1c0-.2.2-.4.5-.4h7.8c.2 0 .4.2.4.4zm0-3.7v1c0 .2-.3.4-.5.4H8a.5.5 0 0 1-.5-.5v-1c0-.2.2-.4.5-.4h7.8c.2 0 .4.2.4.5zm-9.9.5a1.4 1.4 0 1 1-2.8 0 1.4 1.4 0 0 1 2.8 0zm0 3.7a1.4 1.4 0 1 1-2.8 0 1.4 1.4 0 0 1 2.8 0zm0 3.8a1.4 1.4 0 1 1-2.8 0 1.4 1.4 0 0 1 2.8 0z" - })); - } - return false; - } - }, { - key: "render", - value: function render() { - if (false !== this.loadCustomSvgIcon()) { - return this.loadCustomSvgIcon(); - } - if (formidable_form_selector.icon !== 'svg') { - return wp.element.createElement(Dashicon, { - icon: formidable_form_selector.icon - }); - } - return wp.element.createElement("svg", { - xmlns: "http://www.w3.org/2000/svg", - viewBox: "0 0 599.68 601.37", - width: "120", - height: "120" - }, wp.element.createElement("path", { - className: "cls-1 orange", - d: "M289.6 384h140v76h-140z" - }), wp.element.createElement("path", { - className: "cls-1", - d: "M400.2 147h-200c-17 0-30.6 12.2-30.6 29.3V218h260v-71zM397.9 264H169.6v196h75V340H398a32.2 32.2 0 0 0 30.1-21.4 24.3 24.3 0 0 0 1.7-8.7V264z" - }), wp.element.createElement("path", { - className: "cls-1", - d: "M299.8 601.4A300.3 300.3 0 0 1 0 300.7a299.8 299.8 0 1 1 511.9 212.6 297.4 297.4 0 0 1-212 88zm0-563A262 262 0 0 0 38.3 300.7a261.6 261.6 0 1 0 446.5-185.5 259.5 259.5 0 0 0-185-76.8z" - })); - } - }]); -}(Component); - - -/***/ }), - -/***/ "./js/src/common/components/itemselect.js": -/*!************************************************!*\ - !*** ./js/src/common/components/itemselect.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ ItemSelect) -/* harmony export */ }); -/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! prop-types */ "./node_modules/prop-types/index.js"); -/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_0__); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); } -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); } -function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -var _wp$i18n = wp.i18n, - __ = _wp$i18n.__, - sprintf = _wp$i18n.sprintf; - -var Component = wp.element.Component; -var SelectControl = wp.components.SelectControl; - -/** - * Displays a Select control with the specified items as options - * - */ -var ItemSelect = /*#__PURE__*/function (_Component) { - function ItemSelect() { - _classCallCheck(this, ItemSelect); - return _callSuper(this, ItemSelect, arguments); - } - _inherits(ItemSelect, _Component); - return _createClass(ItemSelect, [{ - key: "createOptions", - value: function createOptions(items, itemName) { - var options = items.map(function (item) { - return { - label: item.label, - value: item.value - }; - }); - return [{ - // translators: %s is the name of the item - label: sprintf(__('Select a %s', 'formidable'), itemName), - value: '' - }].concat(_toConsumableArray(options)); - } - }, { - key: "render", - value: function render() { - var _this$props = this.props, - selected = _this$props.selected, - items = _this$props.items, - onChange = _this$props.onChange, - itemName = _this$props.itemName, - itemNamePlural = _this$props.itemNamePlural, - label = _this$props.label, - help = _this$props.help; - if (!items || items.length === 0) { - return wp.element.createElement("p", { - className: "frm-block-select-no-items" - }, sprintf( - // translators: %s is the name of the item - __('Currently, there are no %s', 'formidable'), itemNamePlural)); - } - return wp.element.createElement(SelectControl, { - value: selected, - options: this.createOptions(items, itemName), - label: label, - help: help, - onChange: onChange, - __next40pxDefaultSize: true, - __nextHasNoMarginBottom: true - }); - } - }]); -}(Component); - -ItemSelect.defaultProps = { - itemName: 'item', - itemNamePlural: 'items' -}; -ItemSelect.propTypes = { - selected: prop_types__WEBPACK_IMPORTED_MODULE_0___default().oneOfType([(prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), (prop_types__WEBPACK_IMPORTED_MODULE_0___default().number)]), - //selected item - items: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().array), - //list of possible items - onChange: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().func), - itemName: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), - //name for item in select label - itemNamePlural: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), - //plural of items, used in some labels - label: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string), - help: (prop_types__WEBPACK_IMPORTED_MODULE_0___default().string) -}; - -/***/ }), - -/***/ "./js/src/common/utilities/values.js": -/*!*******************************************!*\ - !*** ./js/src/common/utilities/values.js ***! - \*******************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ cssHideAdvancedSettings: () => (/* binding */ cssHideAdvancedSettings), -/* harmony export */ getSubDir: () => (/* binding */ getSubDir), -/* harmony export */ setTextAttribute: () => (/* binding */ setTextAttribute), -/* harmony export */ updateAttribute: () => (/* binding */ updateAttribute) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Updates an attribute with the specified new value - * - * @param {string} attributeName Name of block attribute to be updated - * @param {*} attributeValue Value of block attribute to be updated - * @param {Function} setAttributes Function to set the block attribute to be updated - */ -function updateAttribute(attributeName, attributeValue, setAttributes) { - setAttributes(_defineProperty({}, attributeName, attributeValue)); -} - -/** - * Sets text attribute for a shortcode from a key value pair - * - * @param {*} value Value of text attribute to be set - * @param {string} attributeName Name of text attribute to be set - * @return {string} String of the text attribute in the format " id=10" - */ -function setTextAttribute(value, attributeName) { - if (value) { - return " ".concat(attributeName, "=\"").concat(value, "\""); - } - return ''; -} - -/** - * Gets subdirectory of current site, if the site isn't on the top level of the domain - * - * @return {string} The subdirectory of the current site - */ -function getSubDir() { - var page = window.location.pathname; - var index = page.indexOf('wp-admin'); - var subDir = '/'; - if (index > -1) { - subDir = page.substr(0, index); - } - return subDir; -} -var cssHideAdvancedSettings = "\n .components-panel__body.editor-block-inspector__advanced {\n display:none;\n }\n"; - -/***/ }), - -/***/ "./js/src/form/block.js": -/*!******************************!*\ - !*** ./js/src/form/block.js ***! - \******************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _formshortcode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./formshortcode */ "./js/src/form/formshortcode.js"); -/* harmony import */ var _inspector__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./inspector */ "./js/src/form/inspector.js"); -/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); -/* harmony import */ var _formselect__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./formselect */ "./js/src/form/formselect.js"); -/* harmony import */ var _common_utilities_values__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common/utilities/values */ "./js/src/common/utilities/values.js"); -/** - * BLOCK: formidable/simple-form - * - * Block to display selected Formidable form with limited setting options - */ - - - - - -var useBlockProps = wp.blockEditor.useBlockProps; -var Fragment = wp.element.Fragment; -var __ = wp.i18n.__; -var registerBlockType = wp.blocks.registerBlockType; -var Notice = wp.components.Notice; -var _wp = wp, - ServerSideRender = _wp.serverSideRender; -function Edit(_ref) { - var setAttributes = _ref.setAttributes, - attributes = _ref.attributes, - isSelected = _ref.isSelected; - var formId = attributes.formId; - var _formidable_form_sele = formidable_form_selector, - forms = _formidable_form_sele.forms; - var blockProps = useBlockProps(); - if (forms.length === 0) { - return wp.element.createElement("div", blockProps, wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, __('This site does not have any forms.', 'formidable'))); - } - if (!formId) { - return wp.element.createElement("div", blockProps, wp.element.createElement("div", { - className: "frm-block-intro-screen" - }, wp.element.createElement("div", { - className: "frm-block-intro-content" - }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_2__["default"], null), wp.element.createElement("div", { - className: "frm-block-title" - }, formidable_form_selector.name), wp.element.createElement("div", { - className: "frm-block-selector-screen" - }, wp.element.createElement(_formselect__WEBPACK_IMPORTED_MODULE_3__["default"], { - formId: formId, - setAttributes: setAttributes, - forms: forms - }))))); - } - return wp.element.createElement("div", blockProps, wp.element.createElement(_inspector__WEBPACK_IMPORTED_MODULE_1__["default"], { - attributes: attributes, - setAttributes: setAttributes, - forms: forms - }), isSelected && wp.element.createElement("style", null, _common_utilities_values__WEBPACK_IMPORTED_MODULE_4__.cssHideAdvancedSettings), wp.element.createElement(ServerSideRender, { - block: "formidable/simple-form", - attributes: attributes - })); -} -registerBlockType('formidable/simple-form', { - apiVersion: 3, - title: formidable_form_selector.name, - description: __('Display a Form', 'formidable'), - icon: _common_components_icon__WEBPACK_IMPORTED_MODULE_2__["default"], - category: 'widgets', - keywords: [__('contact forms', 'formidable'), 'formidable'], - edit: Edit, - save: function save(props) { - var attributes = props.attributes; - var formId = attributes.formId; - return formId === undefined ? '' : wp.element.createElement(Fragment, null, wp.element.createElement(_formshortcode__WEBPACK_IMPORTED_MODULE_0__["default"], attributes)); - } -}); - -/***/ }), - -/***/ "./js/src/form/calculator.js": -/*!***********************************!*\ - !*** ./js/src/form/calculator.js ***! - \***********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); -/** - * BLOCK: formidable/calculator - * - * Block to display selected Formidable calculator form - */ - -var __ = wp.i18n.__; -var registerBlockType = wp.blocks.registerBlockType; -var Notice = wp.components.Notice; -var useBlockProps = wp.blockEditor.useBlockProps; -function Edit(_ref) { - var setAttributes = _ref.setAttributes, - attributes = _ref.attributes; - var _formidable_form_sele = formidable_form_selector, - forms = _formidable_form_sele.forms; - var blockProps = useBlockProps(); - if (forms.length === 0) { - return wp.element.createElement("div", blockProps, wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, __('This site does not have any forms.', 'formidable'))); - } - return wp.element.createElement("div", blockProps, wp.element.createElement("div", { - className: "frm-block-intro-screen" - }, wp.element.createElement("div", { - className: "frm-block-intro-content" - }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { - className: "frm-block-title" - }, __('Calculator Form', 'formidable')), wp.element.createElement("div", { - className: "frm-block-selector-screen frm_pro_tip" - }, wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, __('This site does not have any calculator forms.', 'formidable'), wp.element.createElement("br", null), wp.element.createElement("a", { - href: formidable_form_selector.link, - target: "_blank" - }, __('Upgrade Formidable Forms.', 'formidable'))), wp.element.createElement("img", { - src: "".concat(formidable_form_selector.url, "/images/conversion-calc.jpg"), - alt: __('Calculator Form', 'formidable') - }))))); -} -var FrmCalcIcon = wp.element.createElement('svg', { - width: 20, - height: 20 -}, wp.element.createElement('path', { - d: 'M16.9 0H3a2 2 0 0 0-1.9 1.9V18a2 2 0 0 0 2 1.9h13.7a2 2 0 0 0 1.9-1.9V2a2 2 0 0 0-2-1.9zm0 18.1H3v-10H17v10zm0-11.9H3V2H17v4.3zM5.5 12.6H7c.3 0 .5-.3.5-.5v-1.5c0-.3-.3-.5-.5-.5H5.5c-.3 0-.5.3-.5.5V12c0 .3.3.5.5.5zm7.5 3.8h1.5c.3 0 .5-.3.5-.6v-5.2c0-.3-.3-.5-.5-.5H13c-.3 0-.5.3-.5.5v5.3c0 .2.3.4.5.4zm-7.5 0H7c.3 0 .5-.3.5-.6v-1.4c0-.3-.3-.6-.5-.6H5.5c-.3 0-.5.3-.5.6v1.4c0 .3.3.6.5.6zm3.8-3.8h1.4c.3 0 .6-.3.6-.5v-1.5c0-.3-.3-.5-.6-.5H9.3c-.3 0-.6.3-.6.5V12c0 .3.3.5.6.5zm0 3.8h1.4c.3 0 .6-.3.6-.6v-1.4c0-.3-.3-.6-.6-.6H9.3c-.3 0-.6.3-.6.6v1.4c0 .3.3.6.6.6z' -})); -registerBlockType('formidable/calculator', { - apiVersion: 3, - title: __('Calculator Form', 'formidable'), - description: __('Display a Calculator Form', 'formidable'), - icon: FrmCalcIcon, - category: 'widgets', - keywords: ['calculation', 'formidable'], - edit: Edit -}); - -/***/ }), - -/***/ "./js/src/form/formselect.js": -/*!***********************************!*\ - !*** ./js/src/form/formselect.js ***! - \***********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ FormSelect) -/* harmony export */ }); -/* harmony import */ var _common_components_itemselect__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/itemselect */ "./js/src/common/components/itemselect.js"); -/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! prop-types */ "./node_modules/prop-types/index.js"); -/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -/** - * Form selector - */ - - -var __ = wp.i18n.__; -var Component = wp.element.Component; -var FormSelect = /*#__PURE__*/function (_Component) { - function FormSelect() { - _classCallCheck(this, FormSelect); - return _callSuper(this, FormSelect, arguments); - } - _inherits(FormSelect, _Component); - return _createClass(FormSelect, [{ - key: "render", - value: function render() { - var _this$props = this.props, - formId = _this$props.formId, - setAttributes = _this$props.setAttributes, - forms = _this$props.forms; - return wp.element.createElement(_common_components_itemselect__WEBPACK_IMPORTED_MODULE_0__["default"], { - selected: formId, - itemName: __('form', 'formidable'), - itemNamePlural: __('forms', 'formidable'), - items: forms, - onChange: function onChange(newFormId) { - setAttributes({ - formId: newFormId - }); - } - }); - } - }]); -}(Component); - -FormSelect.propTypes = { - formId: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string), - //current formId - setAttributes: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().func).isRequired //setAttributes of block -}; - -/***/ }), - -/***/ "./js/src/form/formshortcode.js": -/*!**************************************!*\ - !*** ./js/src/form/formshortcode.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ FormShortcode) -/* harmony export */ }); -/* harmony import */ var _common_utilities_values__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/utilities/values */ "./js/src/common/utilities/values.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -/** - * Form shortcode of current form - */ -var Component = wp.element.Component; - -function createParamsText(atts) { - var formId = atts.formId, - title = atts.title, - description = atts.description, - minimize = atts.minimize; - var paramsText = ''; - paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(formId, 'id'); - paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(title, 'title'); - paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(description, 'description'); - paramsText += (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_0__.setTextAttribute)(minimize, 'minimize'); - return paramsText; -} -var FormShortcode = /*#__PURE__*/function (_Component) { - function FormShortcode() { - _classCallCheck(this, FormShortcode); - return _callSuper(this, FormShortcode, arguments); - } - _inherits(FormShortcode, _Component); - return _createClass(FormShortcode, [{ - key: "render", - value: function render() { - return wp.element.createElement("div", null, "[formidable", createParamsText(this.props), "]"); - } - }]); -}(Component); - - -/***/ }), - -/***/ "./js/src/form/graph.js": -/*!******************************!*\ - !*** ./js/src/form/graph.js ***! - \******************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); - -(function () { - 'use strict'; - - if (formidable_form_selector.chartsAddon.installed) { - return; - } - var __ = wp.i18n.__; - var registerBlockType = wp.blocks.registerBlockType; - var Notice = wp.components.Notice; - var useBlockProps = wp.blockEditor.useBlockProps; - var UpgradeNotice = function UpgradeNotice(_ref) { - var text = _ref.text, - buttonText = _ref.buttonText, - link = _ref.link; - return wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, text, wp.element.createElement("br", null), wp.element.createElement("a", { - href: link, - target: "_blank" - }, buttonText)); - }; - var blockName = __('Formidable Chart', 'formidable'); - function Edit() { - var imageWrapperStyles = { - padding: '38px', - margin: '0 auto', - maxWidth: '600px' - }; - var blockProps = useBlockProps(); - return wp.element.createElement("div", blockProps, wp.element.createElement("div", { - className: "frm-block-intro-screen" - }, wp.element.createElement("div", { - className: "frm-block-intro-content" - }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { - className: "frm-block-title" - }, blockName), wp.element.createElement("div", { - className: "frm-block-selector-screen frm_pro_tip", - style: { - alignSelf: 'stretch' - } - }, formidable_form_selector.chartsAddon.hasAccess ? wp.element.createElement(UpgradeNotice, { - text: __('This site does not have Formidable Charts active.', 'formidable'), - buttonText: __('Install Formidable Charts', 'formidable'), - link: formidable_form_selector.chartsAddon.link - }) : wp.element.createElement(UpgradeNotice, { - text: __('This site does not have Formidable Charts installed.', 'formidable'), - buttonText: __('Upgrade Formidable Forms', 'formidable'), - link: formidable_form_selector.link - }), wp.element.createElement("div", { - style: imageWrapperStyles - }, wp.element.createElement("img", { - src: "".concat(formidable_form_selector.url, "/images/demo-graph.svg"), - alt: blockName - })))))); - } - registerBlockType('frm-charts/graph', { - apiVersion: 3, - title: blockName, - description: __('Display a chart or graph', 'formidable'), - icon: wp.element.createElement("svg", { - xmlns: "http://www.w3.org/2000/svg", - fill: "none", - viewBox: "0 0 25 23" - }, wp.element.createElement("path", { - stroke: "currentColor", - strokeLinecap: "round", - strokeWidth: "2.5", - d: "M23 2v19m-7-7.5V21M9 10.8V21m-7-2.9V21" - })), - category: 'design', - edit: Edit - }); -})(); - -/***/ }), - -/***/ "./js/src/form/inspector.js": -/*!**********************************!*\ - !*** ./js/src/form/inspector.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Inspector) -/* harmony export */ }); -/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! prop-types */ "./node_modules/prop-types/index.js"); -/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_3__); -/* harmony import */ var _formselect__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./formselect */ "./js/src/form/formselect.js"); -/* harmony import */ var _formshortcode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./formshortcode */ "./js/src/form/formshortcode.js"); -/* harmony import */ var _common_utilities_values__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../common/utilities/values */ "./js/src/common/utilities/values.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); } -function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); } -function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; } -function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } -function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); } -function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); } -function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); } -/** - * Inspector controls for Formidable Simple Form block - */ - -var __ = wp.i18n.__; -var Component = wp.element.Component; -var InspectorControls = wp.blockEditor.InspectorControls; -var _wp$components = wp.components, - PanelBody = _wp$components.PanelBody, - PanelRow = _wp$components.PanelRow, - ToggleControl = _wp$components.ToggleControl, - ExternalLink = _wp$components.ExternalLink; - - - - -var Inspector = /*#__PURE__*/function (_Component) { - function Inspector() { - _classCallCheck(this, Inspector); - return _callSuper(this, Inspector, arguments); - } - _inherits(Inspector, _Component); - return _createClass(Inspector, [{ - key: "render", - value: function render() { - var _this$props = this.props, - setAttributes = _this$props.setAttributes, - attributes = _this$props.attributes, - forms = _this$props.forms; - var formId = attributes.formId, - title = attributes.title, - description = attributes.description, - minimize = attributes.minimize; - return wp.element.createElement(InspectorControls, null, wp.element.createElement(PanelBody, { - title: __('Select Form', 'formidable'), - initialOpen: true - }, wp.element.createElement(PanelRow, null, wp.element.createElement(_formselect__WEBPACK_IMPORTED_MODULE_0__["default"], { - formId: formId, - setAttributes: setAttributes, - forms: forms - })), formId && wp.element.createElement(PanelRow, null, wp.element.createElement(ExternalLink, { - href: "".concat((0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.getSubDir)(), "wp-admin/admin.php?page=formidable&frm_action=edit&id=").concat(formId) - }, __('Go to form', 'formidable')))), wp.element.createElement(PanelBody, { - title: __('Options', 'formidable'), - initialOpen: false - }, wp.element.createElement(ToggleControl, { - label: __('Show Form Title', 'formidable'), - checked: title, - onChange: function onChange(response) { - (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.updateAttribute)('title', response ? '1' : '', setAttributes); - } - }), wp.element.createElement(ToggleControl, { - label: __('Show Form Description', 'formidable'), - checked: description, - onChange: function onChange(response) { - (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.updateAttribute)('description', response ? '1' : '', setAttributes); - } - }), wp.element.createElement(ToggleControl, { - label: __('Minimize HTML', 'formidable'), - checked: minimize, - onChange: function onChange(response) { - (0,_common_utilities_values__WEBPACK_IMPORTED_MODULE_2__.updateAttribute)('minimize', response ? '1' : '', setAttributes); - } - })), wp.element.createElement(PanelBody, { - title: __('Shortcode', 'formidable'), - initialOpen: false - }, wp.element.createElement(PanelRow, null, wp.element.createElement(_formshortcode__WEBPACK_IMPORTED_MODULE_1__["default"], this.props.attributes)))); - } - }]); -}(Component); - -Inspector.propTypes = { - attributes: (prop_types__WEBPACK_IMPORTED_MODULE_3___default().object), - //block attributes - setAttributes: (prop_types__WEBPACK_IMPORTED_MODULE_3___default().func) //setAttributes of block -}; - -/***/ }), - -/***/ "./js/src/form/modal.js": -/*!******************************!*\ - !*** ./js/src/form/modal.js ***! - \******************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); - -var __ = wp.i18n.__; -var registerBlockType = wp.blocks.registerBlockType; -var Notice = wp.components.Notice; -var useBlockProps = wp.blockEditor.useBlockProps; -var UpgradeNotice = function UpgradeNotice(_ref) { - var text = _ref.text, - buttonText = _ref.buttonText, - link = _ref.link; - return wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, text, wp.element.createElement("br", null), wp.element.createElement("a", { - href: link, - target: "_blank" - }, buttonText)); -}; -function Edit(_ref2) { - var setAttributes = _ref2.setAttributes, - attributes = _ref2.attributes; - var blockName = __('Bootstrap modal popup', 'formidable'); - var imageStyles = { - maxWidth: '504px', - height: 'auto', - borderRadius: '12px' - }; - var imageWrapperStyles = { - padding: '38px', - textAlign: 'center', - backgroundColor: '#f2f4f7', - marginTop: '24px' - }; - var blockProps = useBlockProps(); - return wp.element.createElement("div", blockProps, wp.element.createElement("div", { - className: "frm-block-intro-screen" - }, wp.element.createElement("div", { - className: "frm-block-intro-content" - }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { - className: "frm-block-title" - }, blockName), wp.element.createElement("div", { - className: "frm-block-selector-screen frm_pro_tip", - style: { - alignSelf: 'stretch' - } - }, formidable_form_selector.modalAddon.hasAccess ? wp.element.createElement(UpgradeNotice, { - text: __('This site does not have popup modals active.', 'formidable'), - buttonText: __('Install Formidable Modals', 'formidable'), - link: formidable_form_selector.modalAddon.link - }) : wp.element.createElement(UpgradeNotice, { - text: __('This site does not have popup modals.', 'formidable'), - buttonText: __('Upgrade Formidable Forms', 'formidable'), - link: formidable_form_selector.link - }), wp.element.createElement("div", { - style: imageWrapperStyles - }, wp.element.createElement("img", { - src: "".concat(formidable_form_selector.url, "/images/modal.png"), - alt: blockName, - style: imageStyles - })))))); -} -registerBlockType('frm-modal/modal', { - apiVersion: 3, - title: "".concat(formidable_form_selector.name, " ").concat(__('Modal', 'formidable')), - description: __('Display a modal', 'formidable'), - icon: _common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], - category: 'widgets', - keywords: ['modal', 'formidable'], - edit: Edit -}); - -/***/ }), - -/***/ "./js/src/form/views.js": -/*!******************************!*\ - !*** ./js/src/form/views.js ***! - \******************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _common_components_icon__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../common/components/icon */ "./js/src/common/components/icon.js"); -/* harmony import */ var _api_index__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../api/index */ "./js/src/api/index.js"); -/* harmony import */ var _css_button_module_css__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./css/button.module.css */ "./js/src/form/css/button.module.css"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } -function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } - - - -var __ = wp.i18n.__; -var registerBlockType = wp.blocks.registerBlockType; -var Notice = wp.components.Notice; -var useState = wp.element.useState; -var useBlockProps = wp.blockEditor.useBlockProps; -var blockData = formidable_form_selector; -var upgradeLink = blockData.viewsAddon.hasAccess ? blockData.viewsAddon.link : blockData.link; -function Edit() { - var _useState = useState({ - defaultClassname: 'frm-activate-addon frm-button-primary button button-primary', - loadingClassname: 'frm-loading', - classnames: 'frm-activate-addon frm-button-primary button button-primary', - label: !blockData.viewsAddon.installed && blockData.viewsAddon.hasAccess ? __('Install', 'formidable') : __('Activate', 'formidable'), - isLoading: false - }), - _useState2 = _slicedToArray(_useState, 2), - addonActivateButton = _useState2[0], - updateAddonActivateButton = _useState2[1]; - var activateViewsAddon = function activateViewsAddon() { - if (true === addonActivateButton.isLoading) { - return; - } - updateAddonActivateButton(_objectSpread(_objectSpread({}, addonActivateButton), {}, { - isLoading: true, - classnames: "".concat(addonActivateButton.defaultClassname, " ").concat(addonActivateButton.loadingClassname) - })); - if (!blockData.viewsAddon.installed && blockData.viewsAddon.hasAccess) { - _api_index__WEBPACK_IMPORTED_MODULE_1__.frmAddonAPI.toggleAddonState('frm_install_addon', blockData.viewsAddon.url).then(function () { - window.location.reload(); - }); - return; - } - _api_index__WEBPACK_IMPORTED_MODULE_1__.frmAddonAPI.toggleAddonState('frm_activate_addon', 'formidable-views/formidable-views.php').then(function () { - window.location.reload(); - }); - }; - var blockName = __('Formidable Views', 'formidable'); - var imageStyles = { - maxWidth: '504px', - height: 'auto', - borderRadius: '12px' - }; - var imageWrapperStyles = { - padding: '38px', - textAlign: 'center', - backgroundColor: '#f2f4f7', - marginTop: '24px' - }; - var blockProps = useBlockProps(); - return wp.element.createElement("div", blockProps, wp.element.createElement("div", { - className: "frm-block-intro-screen" - }, wp.element.createElement("div", { - className: "frm-block-intro-content" - }, wp.element.createElement(_common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], null), wp.element.createElement("div", { - className: "frm-block-title" - }, blockName), wp.element.createElement("div", { - className: "frm-block-selector-screen frm_pro_tip", - style: { - alignSelf: 'stretch' - } - }, !blockData.viewsAddon.hasAccess && wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, wp.element.createElement("div", { - style: { - maxWidth: '500px', - margin: 'auto' - } - }, __('Effortlessly transform form data into webpages with Views, the only integrated form & application builder.', 'formidable')), wp.element.createElement("br", null), wp.element.createElement("a", { - href: upgradeLink, - rel: "noreferrer", - target: "_blank" - }, __('Upgrade Formidable Forms', 'formidable'))), blockData.viewsAddon.hasAccess && wp.element.createElement(Notice, { - status: "warning", - isDismissible: false - }, wp.element.createElement("div", { - style: { - maxWidth: '500px', - margin: 'auto' - } - }, __('Effortlessly transform form data into webpages with Views, the only integrated form & application builder.', 'formidable')), wp.element.createElement("br", null), wp.element.createElement("button", { - className: addonActivateButton.classnames, - onClick: activateViewsAddon, - type: "button" - }, " ", addonActivateButton.label, " ")), wp.element.createElement("div", { - style: imageWrapperStyles - }, wp.element.createElement("img", { - src: "".concat(blockData.url, "/images/blocks/views-block-placeholder.jpg"), - alt: blockName, - style: imageStyles - })))))); -} -registerBlockType('formidable/simple-view', { - apiVersion: 3, - title: __('Formidable Views', 'formidable'), - description: __('Display a Visual View', 'formidable'), - icon: _common_components_icon__WEBPACK_IMPORTED_MODULE_0__["default"], - category: 'widgets', - keywords: ['views', 'formidable'], - edit: Edit -}); - -/***/ }), - -/***/ "./node_modules/css-loader/dist/cjs.js!./js/src/form/css/button.module.css": -/*!*********************************************************************************!*\ - !*** ./node_modules/css-loader/dist/cjs.js!./js/src/form/css/button.module.css ***! - \*********************************************************************************/ -/***/ ((module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/cssWithMappingToString.js */ "./node_modules/css-loader/dist/runtime/cssWithMappingToString.js"); -/* harmony import */ var _node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js"); -/* harmony import */ var _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1__); -// Imports - - -var ___CSS_LOADER_EXPORT___ = _node_modules_css_loader_dist_runtime_api_js__WEBPACK_IMPORTED_MODULE_1___default()((_node_modules_css_loader_dist_runtime_cssWithMappingToString_js__WEBPACK_IMPORTED_MODULE_0___default())); -// Module -___CSS_LOADER_EXPORT___.push([module.id, "button.X_GKlxRFRHSOWckGcSPJ {\n\tcursor: progress;\n\topacity: 0.7;\n\tposition: relative;\n\ttext-indent: -999px;\n\tmin-width: 70px;\n\toverflow: hidden;\n}\n\nbutton.X_GKlxRFRHSOWckGcSPJ::before {\n\tcontent: \"\";\n\tdisplay: inline-block;\n\tposition: absolute;\n\tbackground: transparent;\n\tborder: 1px solid #fff;\n\tborder-top-color: transparent;\n\tborder-left-color: transparent;\n\tborder-radius: 50%;\n\n\tbox-sizing: border-box;\n\ttop: 50%;\n\tleft: 50%;\n\tmargin-top: -10px;\n\tmargin-left: -10px;\n\twidth: 20px;\n\theight: 20px;\n\n\tanimation: _3ywaXb1_tykjJGTtxpG 2s linear infinite;\n}\n", "",{"version":3,"sources":["webpack://./js/src/form/css/button.module.css"],"names":[],"mappings":"AAAA;CACC,gBAAgB;CAChB,YAAY;CACZ,kBAAkB;CAClB,mBAAmB;CACnB,eAAe;CACf,gBAAgB;AACjB;;AAEA;CACC,WAAW;CACX,qBAAqB;CACrB,kBAAkB;CAClB,uBAAuB;CACvB,sBAAsB;CACtB,6BAA6B;CAC7B,8BAA8B;CAC9B,kBAAkB;;CAElB,sBAAsB;CACtB,QAAQ;CACR,SAAS;CACT,iBAAiB;CACjB,kBAAkB;CAClB,WAAW;CACX,YAAY;;CAEZ,kDAAkC;AACnC","sourcesContent":["button.frm-loading {\n\tcursor: progress;\n\topacity: 0.7;\n\tposition: relative;\n\ttext-indent: -999px;\n\tmin-width: 70px;\n\toverflow: hidden;\n}\n\nbutton.frm-loading::before {\n\tcontent: \"\";\n\tdisplay: inline-block;\n\tposition: absolute;\n\tbackground: transparent;\n\tborder: 1px solid #fff;\n\tborder-top-color: transparent;\n\tborder-left-color: transparent;\n\tborder-radius: 50%;\n\n\tbox-sizing: border-box;\n\ttop: 50%;\n\tleft: 50%;\n\tmargin-top: -10px;\n\tmargin-left: -10px;\n\twidth: 20px;\n\theight: 20px;\n\n\tanimation: spin 2s linear infinite;\n}\n"],"sourceRoot":""}]); -// Exports -___CSS_LOADER_EXPORT___.locals = { - "frm-loading": "X_GKlxRFRHSOWckGcSPJ", - "spin": "_3ywaXb1_tykjJGTtxpG" -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (___CSS_LOADER_EXPORT___); - - -/***/ }), - -/***/ "./node_modules/css-loader/dist/runtime/api.js": -/*!*****************************************************!*\ - !*** ./node_modules/css-loader/dist/runtime/api.js ***! - \*****************************************************/ -/***/ ((module) => { - -"use strict"; - - -/* - MIT License http://www.opensource.org/licenses/mit-license.php - Author Tobias Koppers @sokra -*/ -// css base code, injected by the css-loader -// eslint-disable-next-line func-names -module.exports = function (cssWithMappingToString) { - var list = []; // return the list of modules as css string - - list.toString = function toString() { - return this.map(function (item) { - var content = cssWithMappingToString(item); - - if (item[2]) { - return "@media ".concat(item[2], " {").concat(content, "}"); - } - - return content; - }).join(""); - }; // import a list of modules into the list - // eslint-disable-next-line func-names - - - list.i = function (modules, mediaQuery, dedupe) { - if (typeof modules === "string") { - // eslint-disable-next-line no-param-reassign - modules = [[null, modules, ""]]; - } - - var alreadyImportedModules = {}; - - if (dedupe) { - for (var i = 0; i < this.length; i++) { - // eslint-disable-next-line prefer-destructuring - var id = this[i][0]; - - if (id != null) { - alreadyImportedModules[id] = true; - } - } - } - - for (var _i = 0; _i < modules.length; _i++) { - var item = [].concat(modules[_i]); - - if (dedupe && alreadyImportedModules[item[0]]) { - // eslint-disable-next-line no-continue - continue; - } - - if (mediaQuery) { - if (!item[2]) { - item[2] = mediaQuery; - } else { - item[2] = "".concat(mediaQuery, " and ").concat(item[2]); - } - } - - list.push(item); - } - }; - - return list; -}; - -/***/ }), - -/***/ "./node_modules/css-loader/dist/runtime/cssWithMappingToString.js": -/*!************************************************************************!*\ - !*** ./node_modules/css-loader/dist/runtime/cssWithMappingToString.js ***! - \************************************************************************/ -/***/ ((module) => { - -"use strict"; - - -function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } - -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } - -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } - -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } - -function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } - -function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } - -module.exports = function cssWithMappingToString(item) { - var _item = _slicedToArray(item, 4), - content = _item[1], - cssMapping = _item[3]; - - if (!cssMapping) { - return content; - } - - if (typeof btoa === "function") { - // eslint-disable-next-line no-undef - var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping)))); - var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64); - var sourceMapping = "/*# ".concat(data, " */"); - var sourceURLs = cssMapping.sources.map(function (source) { - return "/*# sourceURL=".concat(cssMapping.sourceRoot || "").concat(source, " */"); - }); - return [content].concat(sourceURLs).concat([sourceMapping]).join("\n"); - } - - return [content].join("\n"); -}; - -/***/ }), - -/***/ "./node_modules/object-assign/index.js": -/*!*********************************************!*\ - !*** ./node_modules/object-assign/index.js ***! - \*********************************************/ -/***/ ((module) => { - -"use strict"; -/* -object-assign -(c) Sindre Sorhus -@license MIT -*/ - - -/* eslint-disable no-unused-vars */ -var getOwnPropertySymbols = Object.getOwnPropertySymbols; -var hasOwnProperty = Object.prototype.hasOwnProperty; -var propIsEnumerable = Object.prototype.propertyIsEnumerable; - -function toObject(val) { - if (val === null || val === undefined) { - throw new TypeError('Object.assign cannot be called with null or undefined'); - } - - return Object(val); -} - -function shouldUseNative() { - try { - if (!Object.assign) { - return false; - } - - // Detect buggy property enumeration order in older V8 versions. - - // https://bugs.chromium.org/p/v8/issues/detail?id=4118 - var test1 = new String('abc'); // eslint-disable-line no-new-wrappers - test1[5] = 'de'; - if (Object.getOwnPropertyNames(test1)[0] === '5') { - return false; - } - - // https://bugs.chromium.org/p/v8/issues/detail?id=3056 - var test2 = {}; - for (var i = 0; i < 10; i++) { - test2['_' + String.fromCharCode(i)] = i; - } - var order2 = Object.getOwnPropertyNames(test2).map(function (n) { - return test2[n]; - }); - if (order2.join('') !== '0123456789') { - return false; - } - - // https://bugs.chromium.org/p/v8/issues/detail?id=3056 - var test3 = {}; - 'abcdefghijklmnopqrst'.split('').forEach(function (letter) { - test3[letter] = letter; - }); - if (Object.keys(Object.assign({}, test3)).join('') !== - 'abcdefghijklmnopqrst') { - return false; - } - - return true; - } catch (err) { - // We don't expect any of the above to throw, but better to be safe. - return false; - } -} - -module.exports = shouldUseNative() ? Object.assign : function (target, source) { - var from; - var to = toObject(target); - var symbols; - - for (var s = 1; s < arguments.length; s++) { - from = Object(arguments[s]); - - for (var key in from) { - if (hasOwnProperty.call(from, key)) { - to[key] = from[key]; - } - } - - if (getOwnPropertySymbols) { - symbols = getOwnPropertySymbols(from); - for (var i = 0; i < symbols.length; i++) { - if (propIsEnumerable.call(from, symbols[i])) { - to[symbols[i]] = from[symbols[i]]; - } - } - } - } - - return to; -}; - - -/***/ }), - -/***/ "./node_modules/prop-types/checkPropTypes.js": -/*!***************************************************!*\ - !*** ./node_modules/prop-types/checkPropTypes.js ***! - \***************************************************/ -/***/ ((module, __unused_webpack_exports, __webpack_require__) => { - -"use strict"; -/** - * Copyright (c) 2013-present, Facebook, Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - - - -var printWarning = function() {}; - -if (true) { - var ReactPropTypesSecret = __webpack_require__(/*! ./lib/ReactPropTypesSecret */ "./node_modules/prop-types/lib/ReactPropTypesSecret.js"); - var loggedTypeFailures = {}; - var has = __webpack_require__(/*! ./lib/has */ "./node_modules/prop-types/lib/has.js"); - - printWarning = function(text) { - var message = 'Warning: ' + text; - if (typeof console !== 'undefined') { - console.error(message); - } - try { - // --- Welcome to debugging React --- - // This error was thrown as a convenience so that you can use this stack - // to find the callsite that caused this warning to fire. - throw new Error(message); - } catch (x) { /**/ } - }; -} - -/** - * Assert that the values match with the type specs. - * Error messages are memorized and will only be shown once. - * - * @param {object} typeSpecs Map of name to a ReactPropType - * @param {object} values Runtime values that need to be type-checked - * @param {string} location e.g. "prop", "context", "child context" - * @param {string} componentName Name of the component for error messages. - * @param {?Function} getStack Returns the component stack. - * @private - */ -function checkPropTypes(typeSpecs, values, location, componentName, getStack) { - if (true) { - for (var typeSpecName in typeSpecs) { - if (has(typeSpecs, typeSpecName)) { - var error; - // Prop type validation may throw. In case they do, we don't want to - // fail the render phase where it didn't fail before. So we log it. - // After these have been cleaned up, we'll let them throw. - try { - // This is intentionally an invariant that gets caught. It's the same - // behavior as without this statement except with a better message. - if (typeof typeSpecs[typeSpecName] !== 'function') { - var err = Error( - (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + - 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + - 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.' - ); - err.name = 'Invariant Violation'; - throw err; - } - error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret); - } catch (ex) { - error = ex; - } - if (error && !(error instanceof Error)) { - printWarning( - (componentName || 'React class') + ': type specification of ' + - location + ' `' + typeSpecName + '` is invalid; the type checker ' + - 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' + - 'You may have forgotten to pass an argument to the type checker ' + - 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + - 'shape all require an argument).' - ); - } - if (error instanceof Error && !(error.message in loggedTypeFailures)) { - // Only monitor this failure once because there tends to be a lot of the - // same error. - loggedTypeFailures[error.message] = true; - - var stack = getStack ? getStack() : ''; - - printWarning( - 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '') - ); - } - } - } - } -} - -/** - * Resets warning cache when testing. - * - * @private - */ -checkPropTypes.resetWarningCache = function() { - if (true) { - loggedTypeFailures = {}; - } -} - -module.exports = checkPropTypes; - - -/***/ }), - -/***/ "./node_modules/prop-types/factoryWithTypeCheckers.js": -/*!************************************************************!*\ - !*** ./node_modules/prop-types/factoryWithTypeCheckers.js ***! - \************************************************************/ -/***/ ((module, __unused_webpack_exports, __webpack_require__) => { - -"use strict"; -/** - * Copyright (c) 2013-present, Facebook, Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - - - -var ReactIs = __webpack_require__(/*! react-is */ "./node_modules/prop-types/node_modules/react-is/index.js"); -var assign = __webpack_require__(/*! object-assign */ "./node_modules/object-assign/index.js"); - -var ReactPropTypesSecret = __webpack_require__(/*! ./lib/ReactPropTypesSecret */ "./node_modules/prop-types/lib/ReactPropTypesSecret.js"); -var has = __webpack_require__(/*! ./lib/has */ "./node_modules/prop-types/lib/has.js"); -var checkPropTypes = __webpack_require__(/*! ./checkPropTypes */ "./node_modules/prop-types/checkPropTypes.js"); - -var printWarning = function() {}; - -if (true) { - printWarning = function(text) { - var message = 'Warning: ' + text; - if (typeof console !== 'undefined') { - console.error(message); - } - try { - // --- Welcome to debugging React --- - // This error was thrown as a convenience so that you can use this stack - // to find the callsite that caused this warning to fire. - throw new Error(message); - } catch (x) {} - }; -} - -function emptyFunctionThatReturnsNull() { - return null; -} - -module.exports = function(isValidElement, throwOnDirectAccess) { - /* global Symbol */ - var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator; - var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec. - - /** - * Returns the iterator method function contained on the iterable object. - * - * Be sure to invoke the function with the iterable as context: - * - * var iteratorFn = getIteratorFn(myIterable); - * if (iteratorFn) { - * var iterator = iteratorFn.call(myIterable); - * ... - * } - * - * @param {?object} maybeIterable - * @return {?function} - */ - function getIteratorFn(maybeIterable) { - var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]); - if (typeof iteratorFn === 'function') { - return iteratorFn; - } - } - - /** - * Collection of methods that allow declaration and validation of props that are - * supplied to React components. Example usage: - * - * var Props = require('ReactPropTypes'); - * var MyArticle = React.createClass({ - * propTypes: { - * // An optional string prop named "description". - * description: Props.string, - * - * // A required enum prop named "category". - * category: Props.oneOf(['News','Photos']).isRequired, - * - * // A prop named "dialog" that requires an instance of Dialog. - * dialog: Props.instanceOf(Dialog).isRequired - * }, - * render: function() { ... } - * }); - * - * A more formal specification of how these methods are used: - * - * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...) - * decl := ReactPropTypes.{type}(.isRequired)? - * - * Each and every declaration produces a function with the same signature. This - * allows the creation of custom validation functions. For example: - * - * var MyLink = React.createClass({ - * propTypes: { - * // An optional string or URI prop named "href". - * href: function(props, propName, componentName) { - * var propValue = props[propName]; - * if (propValue != null && typeof propValue !== 'string' && - * !(propValue instanceof URI)) { - * return new Error( - * 'Expected a string or an URI for ' + propName + ' in ' + - * componentName - * ); - * } - * } - * }, - * render: function() {...} - * }); - * - * @internal - */ - - var ANONYMOUS = '<>'; - - // Important! - // Keep this list in sync with production version in `./factoryWithThrowingShims.js`. - var ReactPropTypes = { - array: createPrimitiveTypeChecker('array'), - bigint: createPrimitiveTypeChecker('bigint'), - bool: createPrimitiveTypeChecker('boolean'), - func: createPrimitiveTypeChecker('function'), - number: createPrimitiveTypeChecker('number'), - object: createPrimitiveTypeChecker('object'), - string: createPrimitiveTypeChecker('string'), - symbol: createPrimitiveTypeChecker('symbol'), - - any: createAnyTypeChecker(), - arrayOf: createArrayOfTypeChecker, - element: createElementTypeChecker(), - elementType: createElementTypeTypeChecker(), - instanceOf: createInstanceTypeChecker, - node: createNodeChecker(), - objectOf: createObjectOfTypeChecker, - oneOf: createEnumTypeChecker, - oneOfType: createUnionTypeChecker, - shape: createShapeTypeChecker, - exact: createStrictShapeTypeChecker, - }; - - /** - * inlined Object.is polyfill to avoid requiring consumers ship their own - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is - */ - /*eslint-disable no-self-compare*/ - function is(x, y) { - // SameValue algorithm - if (x === y) { - // Steps 1-5, 7-10 - // Steps 6.b-6.e: +0 != -0 - return x !== 0 || 1 / x === 1 / y; - } else { - // Step 6.a: NaN == NaN - return x !== x && y !== y; - } - } - /*eslint-enable no-self-compare*/ - - /** - * We use an Error-like object for backward compatibility as people may call - * PropTypes directly and inspect their output. However, we don't use real - * Errors anymore. We don't inspect their stack anyway, and creating them - * is prohibitively expensive if they are created too often, such as what - * happens in oneOfType() for any type before the one that matched. - */ - function PropTypeError(message, data) { - this.message = message; - this.data = data && typeof data === 'object' ? data: {}; - this.stack = ''; - } - // Make `instanceof Error` still work for returned errors. - PropTypeError.prototype = Error.prototype; - - function createChainableTypeChecker(validate) { - if (true) { - var manualPropTypeCallCache = {}; - var manualPropTypeWarningCount = 0; - } - function checkType(isRequired, props, propName, componentName, location, propFullName, secret) { - componentName = componentName || ANONYMOUS; - propFullName = propFullName || propName; - - if (secret !== ReactPropTypesSecret) { - if (throwOnDirectAccess) { - // New behavior only for users of `prop-types` package - var err = new Error( - 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' + - 'Use `PropTypes.checkPropTypes()` to call them. ' + - 'Read more at http://fb.me/use-check-prop-types' - ); - err.name = 'Invariant Violation'; - throw err; - } else if ( true && typeof console !== 'undefined') { - // Old behavior for people using React.PropTypes - var cacheKey = componentName + ':' + propName; - if ( - !manualPropTypeCallCache[cacheKey] && - // Avoid spamming the console because they are often not actionable except for lib authors - manualPropTypeWarningCount < 3 - ) { - printWarning( - 'You are manually calling a React.PropTypes validation ' + - 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' + - 'and will throw in the standalone `prop-types` package. ' + - 'You may be seeing this warning due to a third-party PropTypes ' + - 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.' - ); - manualPropTypeCallCache[cacheKey] = true; - manualPropTypeWarningCount++; - } - } - } - if (props[propName] == null) { - if (isRequired) { - if (props[propName] === null) { - return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.')); - } - return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.')); - } - return null; - } else { - return validate(props, propName, componentName, location, propFullName); - } - } - - var chainedCheckType = checkType.bind(null, false); - chainedCheckType.isRequired = checkType.bind(null, true); - - return chainedCheckType; - } - - function createPrimitiveTypeChecker(expectedType) { - function validate(props, propName, componentName, location, propFullName, secret) { - var propValue = props[propName]; - var propType = getPropType(propValue); - if (propType !== expectedType) { - // `propValue` being instance of, say, date/regexp, pass the 'object' - // check, but we can offer a more precise error message here rather than - // 'of type `object`'. - var preciseType = getPreciseType(propValue); - - return new PropTypeError( - 'Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'), - {expectedType: expectedType} - ); - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createAnyTypeChecker() { - return createChainableTypeChecker(emptyFunctionThatReturnsNull); - } - - function createArrayOfTypeChecker(typeChecker) { - function validate(props, propName, componentName, location, propFullName) { - if (typeof typeChecker !== 'function') { - return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.'); - } - var propValue = props[propName]; - if (!Array.isArray(propValue)) { - var propType = getPropType(propValue); - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.')); - } - for (var i = 0; i < propValue.length; i++) { - var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret); - if (error instanceof Error) { - return error; - } - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createElementTypeChecker() { - function validate(props, propName, componentName, location, propFullName) { - var propValue = props[propName]; - if (!isValidElement(propValue)) { - var propType = getPropType(propValue); - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.')); - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createElementTypeTypeChecker() { - function validate(props, propName, componentName, location, propFullName) { - var propValue = props[propName]; - if (!ReactIs.isValidElementType(propValue)) { - var propType = getPropType(propValue); - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.')); - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createInstanceTypeChecker(expectedClass) { - function validate(props, propName, componentName, location, propFullName) { - if (!(props[propName] instanceof expectedClass)) { - var expectedClassName = expectedClass.name || ANONYMOUS; - var actualClassName = getClassName(props[propName]); - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.')); - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createEnumTypeChecker(expectedValues) { - if (!Array.isArray(expectedValues)) { - if (true) { - if (arguments.length > 1) { - printWarning( - 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' + - 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).' - ); - } else { - printWarning('Invalid argument supplied to oneOf, expected an array.'); - } - } - return emptyFunctionThatReturnsNull; - } - - function validate(props, propName, componentName, location, propFullName) { - var propValue = props[propName]; - for (var i = 0; i < expectedValues.length; i++) { - if (is(propValue, expectedValues[i])) { - return null; - } - } - - var valuesString = JSON.stringify(expectedValues, function replacer(key, value) { - var type = getPreciseType(value); - if (type === 'symbol') { - return String(value); - } - return value; - }); - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.')); - } - return createChainableTypeChecker(validate); - } - - function createObjectOfTypeChecker(typeChecker) { - function validate(props, propName, componentName, location, propFullName) { - if (typeof typeChecker !== 'function') { - return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.'); - } - var propValue = props[propName]; - var propType = getPropType(propValue); - if (propType !== 'object') { - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.')); - } - for (var key in propValue) { - if (has(propValue, key)) { - var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); - if (error instanceof Error) { - return error; - } - } - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createUnionTypeChecker(arrayOfTypeCheckers) { - if (!Array.isArray(arrayOfTypeCheckers)) { - true ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : 0; - return emptyFunctionThatReturnsNull; - } - - for (var i = 0; i < arrayOfTypeCheckers.length; i++) { - var checker = arrayOfTypeCheckers[i]; - if (typeof checker !== 'function') { - printWarning( - 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' + - 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.' - ); - return emptyFunctionThatReturnsNull; - } - } - - function validate(props, propName, componentName, location, propFullName) { - var expectedTypes = []; - for (var i = 0; i < arrayOfTypeCheckers.length; i++) { - var checker = arrayOfTypeCheckers[i]; - var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret); - if (checkerResult == null) { - return null; - } - if (checkerResult.data && has(checkerResult.data, 'expectedType')) { - expectedTypes.push(checkerResult.data.expectedType); - } - } - var expectedTypesMessage = (expectedTypes.length > 0) ? ', expected one of type [' + expectedTypes.join(', ') + ']': ''; - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.')); - } - return createChainableTypeChecker(validate); - } - - function createNodeChecker() { - function validate(props, propName, componentName, location, propFullName) { - if (!isNode(props[propName])) { - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.')); - } - return null; - } - return createChainableTypeChecker(validate); - } - - function invalidValidatorError(componentName, location, propFullName, key, type) { - return new PropTypeError( - (componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' + - 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.' - ); - } - - function createShapeTypeChecker(shapeTypes) { - function validate(props, propName, componentName, location, propFullName) { - var propValue = props[propName]; - var propType = getPropType(propValue); - if (propType !== 'object') { - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); - } - for (var key in shapeTypes) { - var checker = shapeTypes[key]; - if (typeof checker !== 'function') { - return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker)); - } - var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); - if (error) { - return error; - } - } - return null; - } - return createChainableTypeChecker(validate); - } - - function createStrictShapeTypeChecker(shapeTypes) { - function validate(props, propName, componentName, location, propFullName) { - var propValue = props[propName]; - var propType = getPropType(propValue); - if (propType !== 'object') { - return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); - } - // We need to check all keys in case some are required but missing from props. - var allKeys = assign({}, props[propName], shapeTypes); - for (var key in allKeys) { - var checker = shapeTypes[key]; - if (has(shapeTypes, key) && typeof checker !== 'function') { - return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker)); - } - if (!checker) { - return new PropTypeError( - 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' + - '\nBad object: ' + JSON.stringify(props[propName], null, ' ') + - '\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ') - ); - } - var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); - if (error) { - return error; - } - } - return null; - } - - return createChainableTypeChecker(validate); - } - - function isNode(propValue) { - switch (typeof propValue) { - case 'number': - case 'string': - case 'undefined': - return true; - case 'boolean': - return !propValue; - case 'object': - if (Array.isArray(propValue)) { - return propValue.every(isNode); - } - if (propValue === null || isValidElement(propValue)) { - return true; - } - - var iteratorFn = getIteratorFn(propValue); - if (iteratorFn) { - var iterator = iteratorFn.call(propValue); - var step; - if (iteratorFn !== propValue.entries) { - while (!(step = iterator.next()).done) { - if (!isNode(step.value)) { - return false; - } - } - } else { - // Iterator will provide entry [k,v] tuples rather than values. - while (!(step = iterator.next()).done) { - var entry = step.value; - if (entry) { - if (!isNode(entry[1])) { - return false; - } - } - } - } - } else { - return false; - } - - return true; - default: - return false; - } - } - - function isSymbol(propType, propValue) { - // Native Symbol. - if (propType === 'symbol') { - return true; - } - - // falsy value can't be a Symbol - if (!propValue) { - return false; - } - - // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol' - if (propValue['@@toStringTag'] === 'Symbol') { - return true; - } - - // Fallback for non-spec compliant Symbols which are polyfilled. - if (typeof Symbol === 'function' && propValue instanceof Symbol) { - return true; - } - - return false; - } - - // Equivalent of `typeof` but with special handling for array and regexp. - function getPropType(propValue) { - var propType = typeof propValue; - if (Array.isArray(propValue)) { - return 'array'; - } - if (propValue instanceof RegExp) { - // Old webkits (at least until Android 4.0) return 'function' rather than - // 'object' for typeof a RegExp. We'll normalize this here so that /bla/ - // passes PropTypes.object. - return 'object'; - } - if (isSymbol(propType, propValue)) { - return 'symbol'; - } - return propType; - } - - // This handles more types than `getPropType`. Only used for error messages. - // See `createPrimitiveTypeChecker`. - function getPreciseType(propValue) { - if (typeof propValue === 'undefined' || propValue === null) { - return '' + propValue; - } - var propType = getPropType(propValue); - if (propType === 'object') { - if (propValue instanceof Date) { - return 'date'; - } else if (propValue instanceof RegExp) { - return 'regexp'; - } - } - return propType; - } - - // Returns a string that is postfixed to a warning about an invalid type. - // For example, "undefined" or "of type array" - function getPostfixForTypeWarning(value) { - var type = getPreciseType(value); - switch (type) { - case 'array': - case 'object': - return 'an ' + type; - case 'boolean': - case 'date': - case 'regexp': - return 'a ' + type; - default: - return type; - } - } - - // Returns class name of the object, if any. - function getClassName(propValue) { - if (!propValue.constructor || !propValue.constructor.name) { - return ANONYMOUS; - } - return propValue.constructor.name; - } - - ReactPropTypes.checkPropTypes = checkPropTypes; - ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache; - ReactPropTypes.PropTypes = ReactPropTypes; - - return ReactPropTypes; -}; - - -/***/ }), - -/***/ "./node_modules/prop-types/index.js": -/*!******************************************!*\ - !*** ./node_modules/prop-types/index.js ***! - \******************************************/ -/***/ ((module, __unused_webpack_exports, __webpack_require__) => { - -/** - * Copyright (c) 2013-present, Facebook, Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -if (true) { - var ReactIs = __webpack_require__(/*! react-is */ "./node_modules/prop-types/node_modules/react-is/index.js"); - - // By explicitly using `prop-types` you are opting into new development behavior. - // http://fb.me/prop-types-in-prod - var throwOnDirectAccess = true; - module.exports = __webpack_require__(/*! ./factoryWithTypeCheckers */ "./node_modules/prop-types/factoryWithTypeCheckers.js")(ReactIs.isElement, throwOnDirectAccess); -} else {} - - -/***/ }), - -/***/ "./node_modules/prop-types/lib/ReactPropTypesSecret.js": -/*!*************************************************************!*\ - !*** ./node_modules/prop-types/lib/ReactPropTypesSecret.js ***! - \*************************************************************/ -/***/ ((module) => { - -"use strict"; -/** - * Copyright (c) 2013-present, Facebook, Inc. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - - - -var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED'; - -module.exports = ReactPropTypesSecret; - - -/***/ }), - -/***/ "./node_modules/prop-types/lib/has.js": -/*!********************************************!*\ - !*** ./node_modules/prop-types/lib/has.js ***! - \********************************************/ -/***/ ((module) => { - -module.exports = Function.call.bind(Object.prototype.hasOwnProperty); - - -/***/ }), - -/***/ "./node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js": -/*!***********************************************************************************!*\ - !*** ./node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js ***! - \***********************************************************************************/ -/***/ ((__unused_webpack_module, exports) => { - -"use strict"; -/** @license React v16.13.1 - * react-is.development.js - * - * Copyright (c) Facebook, Inc. and its affiliates. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - - - - - -if (true) { - (function() { -'use strict'; - -// The Symbol used to tag the ReactElement-like types. If there is no native Symbol -// nor polyfill, then a plain number is used for performance. -var hasSymbol = typeof Symbol === 'function' && Symbol.for; -var REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7; -var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca; -var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb; -var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc; -var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2; -var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd; -var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary -// (unstable) APIs that have been removed. Can we remove the symbols? - -var REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf; -var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf; -var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0; -var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1; -var REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8; -var REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3; -var REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4; -var REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9; -var REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5; -var REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6; -var REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7; - -function isValidElementType(type) { - return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill. - type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE); -} - -function typeOf(object) { - if (typeof object === 'object' && object !== null) { - var $$typeof = object.$$typeof; - - switch ($$typeof) { - case REACT_ELEMENT_TYPE: - var type = object.type; - - switch (type) { - case REACT_ASYNC_MODE_TYPE: - case REACT_CONCURRENT_MODE_TYPE: - case REACT_FRAGMENT_TYPE: - case REACT_PROFILER_TYPE: - case REACT_STRICT_MODE_TYPE: - case REACT_SUSPENSE_TYPE: - return type; - - default: - var $$typeofType = type && type.$$typeof; - - switch ($$typeofType) { - case REACT_CONTEXT_TYPE: - case REACT_FORWARD_REF_TYPE: - case REACT_LAZY_TYPE: - case REACT_MEMO_TYPE: - case REACT_PROVIDER_TYPE: - return $$typeofType; - - default: - return $$typeof; - } - - } - - case REACT_PORTAL_TYPE: - return $$typeof; - } - } - - return undefined; -} // AsyncMode is deprecated along with isAsyncMode - -var AsyncMode = REACT_ASYNC_MODE_TYPE; -var ConcurrentMode = REACT_CONCURRENT_MODE_TYPE; -var ContextConsumer = REACT_CONTEXT_TYPE; -var ContextProvider = REACT_PROVIDER_TYPE; -var Element = REACT_ELEMENT_TYPE; -var ForwardRef = REACT_FORWARD_REF_TYPE; -var Fragment = REACT_FRAGMENT_TYPE; -var Lazy = REACT_LAZY_TYPE; -var Memo = REACT_MEMO_TYPE; -var Portal = REACT_PORTAL_TYPE; -var Profiler = REACT_PROFILER_TYPE; -var StrictMode = REACT_STRICT_MODE_TYPE; -var Suspense = REACT_SUSPENSE_TYPE; -var hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated - -function isAsyncMode(object) { - { - if (!hasWarnedAboutDeprecatedIsAsyncMode) { - hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint - - console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.'); - } - } - - return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE; -} -function isConcurrentMode(object) { - return typeOf(object) === REACT_CONCURRENT_MODE_TYPE; -} -function isContextConsumer(object) { - return typeOf(object) === REACT_CONTEXT_TYPE; -} -function isContextProvider(object) { - return typeOf(object) === REACT_PROVIDER_TYPE; -} -function isElement(object) { - return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE; -} -function isForwardRef(object) { - return typeOf(object) === REACT_FORWARD_REF_TYPE; -} -function isFragment(object) { - return typeOf(object) === REACT_FRAGMENT_TYPE; -} -function isLazy(object) { - return typeOf(object) === REACT_LAZY_TYPE; -} -function isMemo(object) { - return typeOf(object) === REACT_MEMO_TYPE; -} -function isPortal(object) { - return typeOf(object) === REACT_PORTAL_TYPE; -} -function isProfiler(object) { - return typeOf(object) === REACT_PROFILER_TYPE; -} -function isStrictMode(object) { - return typeOf(object) === REACT_STRICT_MODE_TYPE; -} -function isSuspense(object) { - return typeOf(object) === REACT_SUSPENSE_TYPE; -} - -exports.AsyncMode = AsyncMode; -exports.ConcurrentMode = ConcurrentMode; -exports.ContextConsumer = ContextConsumer; -exports.ContextProvider = ContextProvider; -exports.Element = Element; -exports.ForwardRef = ForwardRef; -exports.Fragment = Fragment; -exports.Lazy = Lazy; -exports.Memo = Memo; -exports.Portal = Portal; -exports.Profiler = Profiler; -exports.StrictMode = StrictMode; -exports.Suspense = Suspense; -exports.isAsyncMode = isAsyncMode; -exports.isConcurrentMode = isConcurrentMode; -exports.isContextConsumer = isContextConsumer; -exports.isContextProvider = isContextProvider; -exports.isElement = isElement; -exports.isForwardRef = isForwardRef; -exports.isFragment = isFragment; -exports.isLazy = isLazy; -exports.isMemo = isMemo; -exports.isPortal = isPortal; -exports.isProfiler = isProfiler; -exports.isStrictMode = isStrictMode; -exports.isSuspense = isSuspense; -exports.isValidElementType = isValidElementType; -exports.typeOf = typeOf; - })(); -} - - -/***/ }), - -/***/ "./node_modules/prop-types/node_modules/react-is/index.js": -/*!****************************************************************!*\ - !*** ./node_modules/prop-types/node_modules/react-is/index.js ***! - \****************************************************************/ -/***/ ((module, __unused_webpack_exports, __webpack_require__) => { - -"use strict"; - - -if (false) {} else { - module.exports = __webpack_require__(/*! ./cjs/react-is.development.js */ "./node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js"); -} - - -/***/ }), - -/***/ "./js/src/form/css/button.module.css": -/*!*******************************************!*\ - !*** ./js/src/form/css/button.module.css ***! - \*******************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js"); -/* harmony import */ var _node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var _node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js */ "./node_modules/style-loader/dist/runtime/styleDomAPI.js"); -/* harmony import */ var _node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1__); -/* harmony import */ var _node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/insertBySelector.js */ "./node_modules/style-loader/dist/runtime/insertBySelector.js"); -/* harmony import */ var _node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2__); -/* harmony import */ var _node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js */ "./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js"); -/* harmony import */ var _node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3__); -/* harmony import */ var _node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js */ "./node_modules/style-loader/dist/runtime/insertStyleElement.js"); -/* harmony import */ var _node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4__); -/* harmony import */ var _node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! !../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js */ "./node_modules/style-loader/dist/runtime/styleTagTransform.js"); -/* harmony import */ var _node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5__); -/* harmony import */ var _node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! !!../../../../node_modules/css-loader/dist/cjs.js!./button.module.css */ "./node_modules/css-loader/dist/cjs.js!./js/src/form/css/button.module.css"); - - - - - - - - - - - -var options = {}; - -options.styleTagTransform = (_node_modules_style_loader_dist_runtime_styleTagTransform_js__WEBPACK_IMPORTED_MODULE_5___default()); -options.setAttributes = (_node_modules_style_loader_dist_runtime_setAttributesWithoutAttributes_js__WEBPACK_IMPORTED_MODULE_3___default()); - - options.insert = _node_modules_style_loader_dist_runtime_insertBySelector_js__WEBPACK_IMPORTED_MODULE_2___default().bind(null, "head"); - -options.domAPI = (_node_modules_style_loader_dist_runtime_styleDomAPI_js__WEBPACK_IMPORTED_MODULE_1___default()); -options.insertStyleElement = (_node_modules_style_loader_dist_runtime_insertStyleElement_js__WEBPACK_IMPORTED_MODULE_4___default()); - -var update = _node_modules_style_loader_dist_runtime_injectStylesIntoStyleTag_js__WEBPACK_IMPORTED_MODULE_0___default()(_node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"], options); - - - - - /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"] && _node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"].locals ? _node_modules_css_loader_dist_cjs_js_button_module_css__WEBPACK_IMPORTED_MODULE_6__["default"].locals : undefined); - - -/***/ }), - -/***/ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js": -/*!****************************************************************************!*\ - !*** ./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js ***! - \****************************************************************************/ -/***/ ((module) => { - -"use strict"; - - -var stylesInDom = []; - -function getIndexByIdentifier(identifier) { - var result = -1; - - for (var i = 0; i < stylesInDom.length; i++) { - if (stylesInDom[i].identifier === identifier) { - result = i; - break; - } - } - - return result; -} - -function modulesToDom(list, options) { - var idCountMap = {}; - var identifiers = []; - - for (var i = 0; i < list.length; i++) { - var item = list[i]; - var id = options.base ? item[0] + options.base : item[0]; - var count = idCountMap[id] || 0; - var identifier = "".concat(id, " ").concat(count); - idCountMap[id] = count + 1; - var index = getIndexByIdentifier(identifier); - var obj = { - css: item[1], - media: item[2], - sourceMap: item[3] - }; - - if (index !== -1) { - stylesInDom[index].references++; - stylesInDom[index].updater(obj); - } else { - stylesInDom.push({ - identifier: identifier, - updater: addStyle(obj, options), - references: 1 - }); - } - - identifiers.push(identifier); - } - - return identifiers; -} - -function addStyle(obj, options) { - var api = options.domAPI(options); - api.update(obj); - return function updateStyle(newObj) { - if (newObj) { - if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) { - return; - } - - api.update(obj = newObj); - } else { - api.remove(); - } - }; -} - -module.exports = function (list, options) { - options = options || {}; - list = list || []; - var lastIdentifiers = modulesToDom(list, options); - return function update(newList) { - newList = newList || []; - - for (var i = 0; i < lastIdentifiers.length; i++) { - var identifier = lastIdentifiers[i]; - var index = getIndexByIdentifier(identifier); - stylesInDom[index].references--; - } - - var newLastIdentifiers = modulesToDom(newList, options); - - for (var _i = 0; _i < lastIdentifiers.length; _i++) { - var _identifier = lastIdentifiers[_i]; - - var _index = getIndexByIdentifier(_identifier); - - if (stylesInDom[_index].references === 0) { - stylesInDom[_index].updater(); - - stylesInDom.splice(_index, 1); - } - } - - lastIdentifiers = newLastIdentifiers; - }; -}; - -/***/ }), - -/***/ "./node_modules/style-loader/dist/runtime/insertBySelector.js": -/*!********************************************************************!*\ - !*** ./node_modules/style-loader/dist/runtime/insertBySelector.js ***! - \********************************************************************/ -/***/ ((module) => { - -"use strict"; - - -var memo = {}; -/* istanbul ignore next */ - -function getTarget(target) { - if (typeof memo[target] === "undefined") { - var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself - - if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) { - try { - // This will throw an exception if access to iframe is blocked - // due to cross-origin restrictions - styleTarget = styleTarget.contentDocument.head; - } catch (e) { - // istanbul ignore next - styleTarget = null; - } - } - - memo[target] = styleTarget; - } - - return memo[target]; -} -/* istanbul ignore next */ - - -function insertBySelector(insert, style) { - var target = getTarget(insert); - - if (!target) { - throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid."); - } - - target.appendChild(style); -} - -module.exports = insertBySelector; - -/***/ }), - -/***/ "./node_modules/style-loader/dist/runtime/insertStyleElement.js": -/*!**********************************************************************!*\ - !*** ./node_modules/style-loader/dist/runtime/insertStyleElement.js ***! - \**********************************************************************/ -/***/ ((module) => { - -"use strict"; - - -/* istanbul ignore next */ -function insertStyleElement(options) { - var style = document.createElement("style"); - options.setAttributes(style, options.attributes); - options.insert(style); - return style; -} - -module.exports = insertStyleElement; - -/***/ }), - -/***/ "./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js": -/*!**********************************************************************************!*\ - !*** ./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js ***! - \**********************************************************************************/ -/***/ ((module, __unused_webpack_exports, __webpack_require__) => { - -"use strict"; - - -/* istanbul ignore next */ -function setAttributesWithoutAttributes(style) { - var nonce = true ? __webpack_require__.nc : 0; - - if (nonce) { - style.setAttribute("nonce", nonce); - } -} - -module.exports = setAttributesWithoutAttributes; - -/***/ }), - -/***/ "./node_modules/style-loader/dist/runtime/styleDomAPI.js": -/*!***************************************************************!*\ - !*** ./node_modules/style-loader/dist/runtime/styleDomAPI.js ***! - \***************************************************************/ -/***/ ((module) => { - -"use strict"; - - -/* istanbul ignore next */ -function apply(style, options, obj) { - var css = obj.css; - var media = obj.media; - var sourceMap = obj.sourceMap; - - if (media) { - style.setAttribute("media", media); - } else { - style.removeAttribute("media"); - } - - if (sourceMap && typeof btoa !== "undefined") { - css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */"); - } // For old IE - - /* istanbul ignore if */ - - - options.styleTagTransform(css, style); -} - -function removeStyleElement(style) { - // istanbul ignore if - if (style.parentNode === null) { - return false; - } - - style.parentNode.removeChild(style); -} -/* istanbul ignore next */ - - -function domAPI(options) { - var style = options.insertStyleElement(options); - return { - update: function update(obj) { - apply(style, options, obj); - }, - remove: function remove() { - removeStyleElement(style); - } - }; -} - -module.exports = domAPI; - -/***/ }), - -/***/ "./node_modules/style-loader/dist/runtime/styleTagTransform.js": -/*!*********************************************************************!*\ - !*** ./node_modules/style-loader/dist/runtime/styleTagTransform.js ***! - \*********************************************************************/ -/***/ ((module) => { - -"use strict"; - - -/* istanbul ignore next */ -function styleTagTransform(css, style) { - if (style.styleSheet) { - style.styleSheet.cssText = css; - } else { - while (style.firstChild) { - style.removeChild(style.firstChild); - } - - style.appendChild(document.createTextNode(css)); - } -} - -module.exports = styleTagTransform; - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ id: moduleId, -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/nonce */ -/******/ (() => { -/******/ __webpack_require__.nc = undefined; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. -(() => { -"use strict"; -/*!**************************!*\ - !*** ./js/src/blocks.js ***! - \**************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _form_block__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./form/block */ "./js/src/form/block.js"); -/* harmony import */ var _form_calculator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./form/calculator */ "./js/src/form/calculator.js"); -/* harmony import */ var _form_modal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./form/modal */ "./js/src/form/modal.js"); -/* harmony import */ var _form_graph__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./form/graph */ "./js/src/form/graph.js"); -/* harmony import */ var _form_views__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./form/views */ "./js/src/form/views.js"); -/** - * Formidable Simple Blocks - * - */ - - - - - - -})(); - -/******/ })() -; -//# sourceMappingURL=formidable_blocks.js.map \ No newline at end of file +(()=>{var e={2532:(e,t,r)=>{"use strict";r.d(t,{A:()=>i});var n=r(6314),o=r.n(n)()(function(e){return e[1]});o.push([e.id,'button.X_GKlxRFRHSOWckGcSPJ {\n\tcursor: progress;\n\topacity: 0.7;\n\tposition: relative;\n\ttext-indent: -999px;\n\tmin-width: 70px;\n\toverflow: hidden;\n}\n\nbutton.X_GKlxRFRHSOWckGcSPJ::before {\n\tcontent: "";\n\tdisplay: inline-block;\n\tposition: absolute;\n\tbackground: transparent;\n\tborder: 1px solid #fff;\n\tborder-top-color: transparent;\n\tborder-left-color: transparent;\n\tborder-radius: 50%;\n\n\tbox-sizing: border-box;\n\ttop: 50%;\n\tleft: 50%;\n\tmargin-top: -10px;\n\tmargin-left: -10px;\n\twidth: 20px;\n\theight: 20px;\n\n\tanimation: _3ywaXb1_tykjJGTtxpG 2s linear infinite;\n}\n',""]),o.locals={"frm-loading":"X_GKlxRFRHSOWckGcSPJ",spin:"_3ywaXb1_tykjJGTtxpG"};const i=o},6314:e=>{"use strict";e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var r=e(t);return t[2]?"@media ".concat(t[2]," {").concat(r,"}"):r}).join("")},t.i=function(e,r,n){"string"==typeof e&&(e=[[null,e,""]]);var o={};if(n)for(var i=0;i{"use strict";var n=r(6925);function o(){}function i(){}i.resetWarningCache=o,e.exports=function(){function e(e,t,r,o,i,l){if(l!==n){var a=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw a.name="Invariant Violation",a}}function t(){return e}e.isRequired=e;var r={array:e,bigint:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:i,resetWarningCache:o};return r.PropTypes=r,r}},5556:(e,t,r)=>{e.exports=r(2694)()},6925:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},5072:e=>{"use strict";var t=[];function r(e){for(var r=-1,n=0;n{"use strict";var t={};e.exports=function(e,r){var n=function(e){if(void 0===t[e]){var r=document.querySelector(e);if(window.HTMLIFrameElement&&r instanceof window.HTMLIFrameElement)try{r=r.contentDocument.head}catch(e){r=null}t[e]=r}return t[e]}(e);if(!n)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");n.appendChild(r)}},540:e=>{"use strict";e.exports=function(e){var t=document.createElement("style");return e.setAttributes(t,e.attributes),e.insert(t),t}},5056:(e,t,r)=>{"use strict";e.exports=function(e){var t=r.nc;t&&e.setAttribute("nonce",t)}},7825:e=>{"use strict";e.exports=function(e){var t=e.insertStyleElement(e);return{update:function(r){!function(e,t,r){var n=r.css,o=r.media,i=r.sourceMap;o?e.setAttribute("media",o):e.removeAttribute("media"),i&&"undefined"!=typeof btoa&&(n+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(i))))," */")),t.styleTagTransform(n,e)}(t,e,r)},remove:function(){!function(e){if(null===e.parentNode)return!1;e.parentNode.removeChild(e)}(t)}}}},1113:e=>{"use strict";e.exports=function(e,t){if(t.styleSheet)t.styleSheet.cssText=e;else{for(;t.firstChild;)t.removeChild(t.firstChild);t.appendChild(document.createTextNode(e))}}}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var i=t[n]={id:n,exports:{}};return e[n](i,i.exports,r),i.exports}r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.nc=void 0,(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(t,r,n){var o,i,l;n((o={},l=r,(i=function(t){var r=function(t){if("object"!=e(t)||!t)return t;var r=t[Symbol.toPrimitive];if(void 0!==r){var n=r.call(t,"string");if("object"!=e(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==e(r)?r:r+""}(i=t))in o?Object.defineProperty(o,i,{value:l,enumerable:!0,configurable:!0,writable:!0}):o[i]=l,o))}function n(e,t){return e?" ".concat(t,'="').concat(e,'"'):""}function o(e){return o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},o(e)}function i(e,t){for(var r=0;re.length)&&(t=e.length);for(var r=0,n=Array(t);r-1&&(n=e.substr(0,r)),n),"wp-admin/admin.php?page=formidable&frm_action=edit&id=").concat(c)},V("Go to form","formidable")))),wp.element.createElement(W,{title:V("Options","formidable"),initialOpen:!1},wp.element.createElement(J,{label:V("Show Form Title","formidable"),checked:s,onChange:function(e){t("title",e?"1":"",i)}}),wp.element.createElement(J,{label:V("Show Form Description","formidable"),checked:m,onChange:function(e){t("description",e?"1":"",i)}}),wp.element.createElement(J,{label:V("Minimize HTML","formidable"),checked:f,onChange:function(e){t("minimize",e?"1":"",i)}})),wp.element.createElement(W,{title:V("Shortcode","formidable"),initialOpen:!1},wp.element.createElement(U,null,wp.element.createElement(u,this.props.attributes))))}}])&&F(n.prototype,o),Object.defineProperty(n,"prototype",{writable:!1}),n;var n,o}(M);function K(e){return K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},K(e)}function $(e,t){for(var r=0;re.length)&&(t=e.length);for(var r=0,n=Array(t);r { // webpackBootstrap -/******/ "use strict"; -/******/ var __webpack_modules__ = ({ - -/***/ "./js/src/components/class-counter.js": -/*!********************************************!*\ - !*** ./js/src/components/class-counter.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmCounter: () => (/* binding */ frmCounter) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmCounter = /*#__PURE__*/function () { - /** - * Init frmCounter - * - * @param {Element} element - * @param {Object} options - * @param {number} options.timetoFinish Max time in mileseconds for counter to complete the animation. - */ - function frmCounter(element, options) { - _classCallCheck(this, frmCounter); - if (!(element instanceof Element) || !element.dataset.counter) { - return; - } - this.template = element.dataset.type || 'default'; - this.element = element; - this.value = parseInt(element.dataset.counter, 10); - this.activeCounter = 0; - this.locale = element.dataset.locale ? element.dataset.locale.replace('_', '-') : 'en-US'; - this.timeoutInterval = 50; - this.timeToFinish = options !== undefined && options.timetoFinish !== undefined ? options.timetoFinish : 1400; - this.valueStep = this.value / Math.ceil(this.timeToFinish / this.timeoutInterval); - if (0 === this.value) { - return; - } - this.animate(); - } - return _createClass(frmCounter, [{ - key: "formatNumber", - value: function formatNumber(number) { - if ('currency' === this.template) { - return number.toLocaleString(this.locale, { - minimumFractionDigits: 2 - }); - } - return number; - } - }, { - key: "animate", - value: function animate() { - if (Math.round(this.activeCounter) < this.value) { - this.activeCounter += this.valueStep; - this.element.innerText = this.formatNumber(Math.round(this.activeCounter)); - setTimeout(this.animate.bind(this), this.timeoutInterval); - } else { - this.element.innerText = this.formatNumber(this.value); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/components/class-tabs-navigator.js": -/*!***************************************************!*\ - !*** ./js/src/components/class-tabs-navigator.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmTabsNavigator: () => (/* binding */ frmTabsNavigator) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmTabsNavigator = /*#__PURE__*/function () { - function frmTabsNavigator(wrapper) { - _classCallCheck(this, frmTabsNavigator); - if (wrapper === undefined) { - return; - } - this.wrapper = wrapper instanceof Element ? wrapper : document.querySelector(wrapper); - if (null === this.wrapper) { - return; - } - this.flexboxSlidesGap = '16px'; - this.navs = this.wrapper.querySelectorAll('.frm-tabs-navs ul > li'); - this.slideTrackLine = this.wrapper.querySelector('.frm-tabs-active-underline'); - this.slideTrack = this.wrapper.querySelector('.frm-tabs-slide-track'); - this.slides = this.wrapper.querySelectorAll('.frm-tabs-slide-track > div'); - this.isRTL = document.documentElement.dir === 'rtl' || document.body.dir === 'rtl'; - this.resizeObserver = null; - this.init(); - } - return _createClass(frmTabsNavigator, [{ - key: "init", - value: function init() { - var _this = this; - if (null === this.wrapper || !this.navs.length || null === this.slideTrackLine || null === this.slideTrack || !this.slides.length) { - return; - } - this.navs.forEach(function (nav, index) { - nav.addEventListener('click', function (event) { - return _this.onNavClick(event, index); - }); - if (nav.classList.contains('frm-active')) { - _this.initSlideTrackUnderline(nav); - } - }); - this.slideTrackLine.style.display = 'block'; - this.setupScrollbarObserver(); - // Cleanup observers when page unloads to prevent memory leaks - window.addEventListener('beforeunload', this.cleanupObservers); - } - }, { - key: "onNavClick", - value: function onNavClick(event, index) { - var navItem = event.currentTarget; - event.preventDefault(); - this.removeActiveClassnameFromNavs(); - navItem.classList.add('frm-active'); - this.initSlideTrackUnderline(navItem); - this.changeSlide(index); - - // Handle special case for frm_insert_fields_tab - var navLink = navItem.querySelector('a'); - if (navLink && navLink.id === 'frm_insert_fields_tab' && !navLink.closest('#frm_adv_info')) { - var _window$frmAdminBuild, _window$frmAdminBuild2; - (_window$frmAdminBuild = window.frmAdminBuild) === null || _window$frmAdminBuild === void 0 || (_window$frmAdminBuild2 = _window$frmAdminBuild.clearSettingsBox) === null || _window$frmAdminBuild2 === void 0 || _window$frmAdminBuild2.call(_window$frmAdminBuild); - } - } - }, { - key: "initSlideTrackUnderline", - value: function initSlideTrackUnderline(nav) { - var activeNav = nav !== undefined ? nav : this.navs.filter(function (nav) { - return nav.classList.contains('frm-active'); - }); - this.positionUnderlineIndicator(activeNav); - } - - /** - * Sets up a ResizeObserver to watch for scrollbar changes in the parent container. - * Automatically repositions the underline indicator when layout changes occur. - */ - }, { - key: "setupScrollbarObserver", - value: function setupScrollbarObserver() { - var _this2 = this; - var resizeObserverTarget = document.querySelector('.frm-scrollbar-wrapper, .styling_settings') || document.body; - if (!resizeObserverTarget || !('ResizeObserver' in window)) { - return; - } - this.resizeObserver = new ResizeObserver(function () { - var activeNav = _this2.wrapper.querySelector('.frm-tabs-navs ul > li.frm-active'); - if (activeNav) { - _this2.positionUnderlineIndicator(activeNav); - } - }); - this.resizeObserver.observe(resizeObserverTarget); - } - - /** - * Cleans up observers to prevent memory leaks. - */ - }, { - key: "cleanupObservers", - value: function cleanupObservers() { - if (this.resizeObserver) { - this.resizeObserver.disconnect(); - this.resizeObserver = null; - } - } - - /** - * Positions the underline indicator based on the active navigation element. - * - * @param {HTMLElement} activeNav The active navigation element to position the underline under - */ - }, { - key: "positionUnderlineIndicator", - value: function positionUnderlineIndicator(activeNav) { - var _this3 = this; - requestAnimationFrame(function () { - var position = _this3.isRTL ? -(activeNav.parentElement.offsetWidth - activeNav.offsetLeft - activeNav.offsetWidth) : activeNav.offsetLeft; - _this3.slideTrackLine.style.transform = "translateX(".concat(position, "px)"); - _this3.slideTrackLine.style.width = "".concat(activeNav.clientWidth, "px"); - }); - } - }, { - key: "changeSlide", - value: function changeSlide(index) { - this.removeActiveClassnameFromSlides(); - var translate = index == 0 ? '0px' : "calc( ( ".concat(index * 100, "% + ").concat(parseInt(this.flexboxSlidesGap, 10) * index, "px ) * ").concat(this.isRTL ? 1 : -1, " )"); - if ('0px' !== translate) { - this.slideTrack.style.transform = "translateX(".concat(translate, ")"); - } else { - this.slideTrack.style.removeProperty('transform'); - } - if (index in this.slides) { - this.slides[index].classList.add('frm-active'); - } - } - }, { - key: "removeActiveClassnameFromSlides", - value: function removeActiveClassnameFromSlides() { - this.slides.forEach(function (slide) { - return slide.classList.remove('frm-active'); - }); - } - }, { - key: "removeActiveClassnameFromNavs", - value: function removeActiveClassnameFromNavs() { - this.navs.forEach(function (nav) { - return nav.classList.remove('frm-active'); - }); - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. -(() => { -/*!*****************************!*\ - !*** ./js/src/dashboard.js ***! - \*****************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/class-tabs-navigator */ "./js/src/components/class-tabs-navigator.js"); -/* harmony import */ var _components_class_counter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/class-counter */ "./js/src/components/class-counter.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * External dependencies - */ - - - -var frmDashboard = /*#__PURE__*/function () { - function frmDashboard() { - _classCallCheck(this, frmDashboard); - this.options = { - ajax: { - action: 'dashboard_ajax_action', - dashboardActions: { - welcomeBanner: 'welcome-banner-has-closed', - checkEmailIfSubscribed: 'email-has-subscribed', - saveSubscribedEmail: 'save-subscribed-email' - } - } - }; - this.widgetsAnimate = new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(document.querySelectorAll('.frm-dashboard-widget'), 'cascade'); - } - return _createClass(frmDashboard, [{ - key: "init", - value: function init() { - this.initInbox(); - this.initCounters(); - this.initCloseWelcomeBanner(); - this.widgetsAnimate.cascadeFadeIn(); - } - }, { - key: "initInbox", - value: function initInbox() { - var _this = this; - new _components_class_tabs_navigator__WEBPACK_IMPORTED_MODULE_1__.frmTabsNavigator('.frm-inbox-wrapper'); - var userEmailInput = document.querySelector('#frm_leave_email'); - var subscribeButton = document.querySelector('#frm-add-my-email-address'); - subscribeButton.addEventListener('click', function () { - _this.saveSubscribedEmail(userEmailInput.value).then(); - }); - } - }, { - key: "initCounters", - value: function initCounters() { - var counters = document.querySelectorAll('.frm-counter'); - counters.forEach(function (counter) { - return new _components_class_counter__WEBPACK_IMPORTED_MODULE_2__.frmCounter(counter); - }); - } - }, { - key: "initCloseWelcomeBanner", - value: function initCloseWelcomeBanner() { - var _this2 = this; - var closeButton = document.querySelector('.frm-dashboard-banner-close'); - var dashboardBanner = document.querySelector('.frm-dashboard-banner'); - if (!closeButton || !dashboardBanner) { - return; - } - closeButton.addEventListener('click', function () { - _this2.closeWelcomeBannerSaveCookieRequest().then(function (data) { - if (true === data.success) { - dashboardBanner.remove(); - } - }); - }); - } - }, { - key: "saveSubscribedEmail", - value: function saveSubscribedEmail(email) { - return fetch(window.ajaxurl, { - method: 'POST', - headers: { - 'Content-Type': 'application/x-www-form-urlencoded' - }, - body: new URLSearchParams({ - action: this.options.ajax.action, - dashboard_action: this.options.ajax.dashboardActions.saveSubscribedEmail, - email: email - }) - }).then(function (result) { - return result.json(); - }); - } - }, { - key: "closeWelcomeBannerSaveCookieRequest", - value: function closeWelcomeBannerSaveCookieRequest() { - return fetch(window.ajaxurl, { - method: 'POST', - headers: { - 'Content-Type': 'application/x-www-form-urlencoded' - }, - body: new URLSearchParams({ - action: this.options.ajax.action, - dashboard_action: this.options.ajax.dashboardActions.welcomeBanner, - banner_has_closed: 1 - }) - }).then(function (result) { - return result.json(); - }); - } - }]); -}(); -var frmDashboardClass = new frmDashboard(); -document.addEventListener('DOMContentLoaded', function () { - frmDashboardClass.init(); -}); -})(); - -/******/ })() -; -//# sourceMappingURL=formidable_dashboard.js.map \ No newline at end of file +(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(e,t){for(var i=0;i1&&void 0!==arguments[1]?arguments[1]:"default";!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.elements=t,this.type=n,this.prepareElements()},n=[{key:"fadeIn",value:function(){var e=this;this.applyStyleToElements(function(t){t.classList.add("frm-fadein-up"),t.addEventListener("animationend",function(){e.resetOpacity(),t.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){e.applyStyleToElements(function(e,n){e.classList.remove("frm-animate"),e.style.transitionDelay="".concat((n+1)*t,"s")})},200)}},{key:"prepareElements",value:function(){var e=this;this.applyStyleToElements(function(t){"default"===e.type&&(t.style.opacity="0.0"),"cascade"===e.type&&t.classList.add("frm-init-cascade-animation"),"cascade-3d"===e.type&&t.classList.add("frm-init-fadein-3d"),t.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(e){return e.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(e){this.elements instanceof Element?e(this.elements,0):0 li"),this.slideTrackLine=this.wrapper.querySelector(".frm-tabs-active-underline"),this.slideTrack=this.wrapper.querySelector(".frm-tabs-slide-track"),this.slides=this.wrapper.querySelectorAll(".frm-tabs-slide-track > div"),this.isRTL="rtl"===document.documentElement.dir||"rtl"===document.body.dir,this.resizeObserver=null,this.init()))},(t=[{key:"init",value:function(){var e=this;null!==this.wrapper&&this.navs.length&&null!==this.slideTrackLine&&null!==this.slideTrack&&this.slides.length&&(this.navs.forEach(function(t,n){t.addEventListener("click",function(t){return e.onNavClick(t,n)}),t.classList.contains("frm-active")&&e.initSlideTrackUnderline(t)}),this.slideTrackLine.style.display="block",this.setupScrollbarObserver(),window.addEventListener("beforeunload",this.cleanupObservers))}},{key:"onNavClick",value:function(e,t){var n=e.currentTarget;e.preventDefault(),this.removeActiveClassnameFromNavs(),n.classList.add("frm-active"),this.initSlideTrackUnderline(n),this.changeSlide(t);var i,r,o=n.querySelector("a");o&&"frm_insert_fields_tab"===o.id&&!o.closest("#frm_adv_info")&&(null===(i=window.frmAdminBuild)||void 0===i||null===(r=i.clearSettingsBox)||void 0===r||r.call(i))}},{key:"initSlideTrackUnderline",value:function(e){var t=void 0!==e?e:this.navs.filter(function(e){return e.classList.contains("frm-active")});this.positionUnderlineIndicator(t)}},{key:"setupScrollbarObserver",value:function(){var e=this,t=document.querySelector(".frm-scrollbar-wrapper, .styling_settings")||document.body;t&&"ResizeObserver"in window&&(this.resizeObserver=new ResizeObserver(function(){var t=e.wrapper.querySelector(".frm-tabs-navs ul > li.frm-active");t&&e.positionUnderlineIndicator(t)}),this.resizeObserver.observe(t))}},{key:"cleanupObservers",value:function(){this.resizeObserver&&(this.resizeObserver.disconnect(),this.resizeObserver=null)}},{key:"positionUnderlineIndicator",value:function(e){var t=this;requestAnimationFrame(function(){var n=t.isRTL?-(e.parentElement.offsetWidth-e.offsetLeft-e.offsetWidth):e.offsetLeft;t.slideTrackLine.style.transform="translateX(".concat(n,"px)"),t.slideTrackLine.style.width="".concat(e.clientWidth,"px")})}},{key:"changeSlide",value:function(e){this.removeActiveClassnameFromSlides();var t=0==e?"0px":"calc( ( ".concat(100*e,"% + ").concat(parseInt(this.flexboxSlidesGap,10)*e,"px ) * ").concat(this.isRTL?1:-1," )");"0px"!==t?this.slideTrack.style.transform="translateX(".concat(t,")"):this.slideTrack.style.removeProperty("transform"),e in this.slides&&this.slides[e].classList.add("frm-active")}},{key:"removeActiveClassnameFromSlides",value:function(){this.slides.forEach(function(e){return e.classList.remove("frm-active")})}},{key:"removeActiveClassnameFromNavs",value:function(){this.navs.forEach(function(e){return e.classList.remove("frm-active")})}}])&&c(e.prototype,t),Object.defineProperty(e,"prototype",{writable:!1}),e;var e,t}();function m(e){return m="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},m(e)}function d(e,t){for(var n=0;n { // webpackBootstrap -/******/ "use strict"; -/******/ var __webpack_modules__ = ({ - -/***/ "./js/src/components/class-overlay.js": -/*!********************************************!*\ - !*** ./js/src/components/class-overlay.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmOverlay: () => (/* binding */ frmOverlay) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * External dependencies - */ - -var frmOverlay = /*#__PURE__*/function () { - function frmOverlay() { - _classCallCheck(this, frmOverlay); - this.body = document.body; - } - - /** - * Open overlay - * - * @param {Object} overlayData An object containing data for the overlay. - * @param {string} overlayData.hero_image URL of the hero image. - * @param {string} overlayData.heading Heading of the overlay. - * @param {string} overlayData.copy Copy/content of the overlay. - * @param {Array} overlayData.buttons Array of button objects. - * @param {string} overlayData.buttons[].url URL for the button. - * @param {string} overlayData.buttons[].target Target attribute for the button link. - * @param {string} overlayData.buttons[].label Label/text of the button. - */ - return _createClass(frmOverlay, [{ - key: "open", - value: function open(overlayData) { - this.overlayData = { - hero_image: null, - heading: null, - copy: null, - buttons: [] - }; - this.overlayData = _objectSpread(_objectSpread({}, this.overlayData), overlayData); - this.bodyAddOverflowHidden(); - this.body.insertBefore(this.buildOverlay(), this.body.firstChild); - this.initCloseButton(); - this.initOverlayIntroAnimation(200); - } - }, { - key: "bodyAddOverflowHidden", - value: function bodyAddOverflowHidden() { - this.body.classList.add('frm-hidden-overflow'); - setTimeout(function () { - document.body.scrollTop = 0; - document.documentElement.scrollTop = 0; - }, 80); - } - }, { - key: "close", - value: function close() { - var overlayWrapper = document.querySelector('.frm-overlay--wrapper'); - if (overlayWrapper) { - document.body.classList.remove('frm-hidden-overflow'); - overlayWrapper.remove(); - } - } - }, { - key: "initCloseButton", - value: function initCloseButton() { - var overlayWrapper = document.querySelector('.frm-overlay--wrapper'); - if (overlayWrapper) { - var closeButton = document.createElement('span'); - closeButton.classList.add('frm-overlay--close'); - closeButton.addEventListener('click', this.close); - overlayWrapper.prepend(closeButton); - } - } - }, { - key: "getHeroImage", - value: function getHeroImage() { - if (this.overlayData.hero_image) { - return frmDom.img({ - src: this.overlayData.hero_image - }); - } - return ''; - } - }, { - key: "getButtons", - value: function getButtons() { - var buttons = this.overlayData.buttons.map(function (button, index) { - if (!button.url) { - return ''; - } - var buttonTypeClassname = 1 === index ? 'frm-button-primary' : 'frm-button-secondary'; - var options = { - href: button.url, - text: button.label, - className: "button frm_animate_bg ".concat(buttonTypeClassname) - }; - if (button.target) { - options.target = button.target; - } - return frmDom.a(options); - }); - if (buttons) { - var buttonsWrapperElementOptions = { - className: 'frm-overlay--cta frm-flex-box', - children: buttons - }; - return frmDom.div(buttonsWrapperElementOptions); - } - return ''; - } - }, { - key: "getHeading", - value: function getHeading() { - if (this.overlayData.heading) { - return frmDom.tag('h2', { - className: 'frm-overlay--heading frm-text-xl', - text: this.overlayData.heading - }); - } - return ''; - } - }, { - key: "getCopy", - value: function getCopy() { - if (this.overlayData.copy) { - var copy = frmDom.tag('div'); - copy.innerHTML = this.overlayData.copy; - return frmDom.div({ - className: 'frm-overlay--copy', - child: copy - }); - } - return ''; - } - }, { - key: "initOverlayIntroAnimation", - value: function initOverlayIntroAnimation(delay) { - setTimeout(function () { - var elements = document.querySelectorAll('.frm-overlay--hero-image, .frm-overlay--heading, .frm-overlay--copy, .frm-overlay--cta a'); - new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(elements, 'cascade-3d').cascadeFadeIn(0.07); - }, delay); - } - }, { - key: "buildOverlay", - value: function buildOverlay() { - var container = frmDom.div({ - className: 'frm-overlay--container', - children: [frmDom.div({ - className: 'frm-overlay--hero-image frm-mb-md', - children: [this.getHeroImage()] - }), this.getHeading(), this.getCopy(), this.getButtons()] - }); - return frmDom.div({ - className: 'frm-overlay--wrapper frm_wrap', - children: [container] - }); - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. -(() => { -/*!***************************!*\ - !*** ./js/src/overlay.js ***! - \***************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _components_class_overlay__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./components/class-overlay */ "./js/src/components/class-overlay.js"); - -window.frmOverlay = new _components_class_overlay__WEBPACK_IMPORTED_MODULE_0__.frmOverlay(); -})(); - -/******/ })() -; -//# sourceMappingURL=formidable_overlay.js.map \ No newline at end of file +(()=>{"use strict";function e(t){return e="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e(t)}function t(e,t){for(var n=0;n1&&void 0!==arguments[1]?arguments[1]:"default";!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.elements=t,this.type=r,this.prepareElements()},r=[{key:"fadeIn",value:function(){var e=this;this.applyStyleToElements(function(t){t.classList.add("frm-fadein-up"),t.addEventListener("animationend",function(){e.resetOpacity(),t.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){e.applyStyleToElements(function(e,r){e.classList.remove("frm-animate"),e.style.transitionDelay="".concat((r+1)*t,"s")})},200)}},{key:"prepareElements",value:function(){var e=this;this.applyStyleToElements(function(t){"default"===e.type&&(t.style.opacity="0.0"),"cascade"===e.type&&t.classList.add("frm-init-cascade-animation"),"cascade-3d"===e.type&&t.classList.add("frm-init-fadein-3d"),t.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(e){return e.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(e){this.elements instanceof Element?e(this.elements,0):0 { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/admin/components/dependent-updater-component.js": -/*!****************************************************************!*\ - !*** ./js/src/admin/components/dependent-updater-component.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ frmStyleDependentUpdaterComponent) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * This component updates the dependent style element's values and triggers a custom change event for each style element, initiating the style preview. - * The names of the elements that will be updated are specified using the "will-change" attribute. - * It is primarily used in components from Style/Quick Settings. - * For instance, when the "FrmPrimaryColorStyleComponent" is changed, it simultaneously updates various style elements like border color, text color, and button backgrounds. - */ -var frmStyleDependentUpdaterComponent = /*#__PURE__*/function () { - /** - * Creates an instance of frmStyleDependentUpdaterComponent. - * - * @param {HTMLElement} component - The component element. - */ - function frmStyleDependentUpdaterComponent(component) { - _classCallCheck(this, frmStyleDependentUpdaterComponent); - this.component = component; - try { - var willChangeData = JSON.parse(this.component.dataset.willChange); - this.data = { - propagateInputs: this.initPropagationList(willChangeData), - changeEvent: new Event('change', { - bubbles: true - }) - }; - } catch (error) { - console.error('Error parsing JSON data from "will-change" attribute.', error); - } - } - - /** - * Initializes the list of inputs to propagate changes to. - * The selection is made by provided input's names list in "will-change" attribute. - * - * @param {string[]} inputNames - The names of the inputs to propagate changes to. - * @return {HTMLElement[]} - The list of inputs to propagate changes to. - */ - return _createClass(frmStyleDependentUpdaterComponent, [{ - key: "initPropagationList", - value: function initPropagationList(inputNames) { - var list = []; - inputNames.forEach(function (name) { - var input = document.querySelector("input[name=\"".concat(name, "\"]")); - if (input) { - list.push(input); - } - }); - return list; - } - - /** - * Updates all dependent elements with the given value. - * - * @param {string} value - The value to update the dependent elements with. - */ - }, { - key: "updateAllDependentElements", - value: function updateAllDependentElements(value) { - this.data.propagateInputs.forEach(function (input) { - input.value = value; - }); - this.data.propagateInputs[0].dispatchEvent(this.data.changeEvent); - } - }]); -}(); - - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. -(() => { -"use strict"; -/*!********************************!*\ - !*** ./js/src/admin/styles.js ***! - \********************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var _components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/dependent-updater-component */ "./js/src/admin/components/dependent-updater-component.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } - - - -/** - * Represents the frmStyleOptions class. - * - * @class - */ -var frmStyleOptions = /*#__PURE__*/function () { - function frmStyleOptions() { - _classCallCheck(this, frmStyleOptions); - this.success = frmDom.success; - this.cssEditorInstance = null; - this.cssInlineStyleElement = null; - this.cssEditorOptions = { - retryLimit: 5, - // Stop after 5 retries. - retryInterval: 500, - // Retry every 500ms. - retryCount: 0 // Count the number of retries. - }; - this.init(); - this.initHover(); - this.initCustomCSSEditorInstance(); - } - - /** - * Init the dependent - */ - return _createClass(frmStyleOptions, [{ - key: "init", - value: function init() { - this.initColorPickerDependentUpdaterComponents(); - this.initStyleClassCopyToClipboard((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('The class name has been copied.', 'formidable')); - this.toggleVisibilityOfCustomCSSEditor(); - } - - /** - * Initialize the custom CSS editor instance. - * - * @return {void} - */ - }, { - key: "initCustomCSSEditorInstance", - value: function initCustomCSSEditorInstance() { - var _this = this; - if (null !== this.cssEditorInstance || this.cssEditorOptions.retryCount >= this.cssEditorOptions.retryLimit) { - return; - } - if (window.frm_single_style_custom_css_wp_editor === undefined || window.frm_single_style_custom_css_wp_editor.codemirror === undefined) { - setTimeout(function () { - _this.cssEditorOptions.retryCount++; - _this.initCustomCSSEditorInstance(); - }, 500); - return; - } - this.cssEditorInstance = window.frm_single_style_custom_css_wp_editor.codemirror; - this.onCssEditorReady(); - } - - /** - * Get the inline style element. - * - * @return {HTMLElement} The inline style element. - */ - }, { - key: "getInlineStyleElement", - value: function getInlineStyleElement() { - if (null !== this.cssInlineStyleElement) { - return this.cssInlineStyleElement; - } - this.cssInlineStyleElement = document.createElement('style'); - document.head.append(this.cssInlineStyleElement); - return this.cssInlineStyleElement; - } - - /** - * On the CSS editor ready, add an event listener to the editor to update the inline style element. - * - * @return {void} - */ - }, { - key: "onCssEditorReady", - value: function onCssEditorReady() { - var _document$getElementB, - _this2 = this; - var cssScope = (_document$getElementB = document.getElementById('frm_style_class_custom_css')) === null || _document$getElementB === void 0 || (_document$getElementB = _document$getElementB.dataset) === null || _document$getElementB === void 0 ? void 0 : _document$getElementB.cssScope; - if (null === cssScope) { - return; - } - var sanitizedCssScope = CSS.escape(cssScope); - this.cssEditorInstance.on('change', function (editor) { - var value = editor.getValue().replace(/<[^>]*>/g, '').trim(); - _this2.getInlineStyleElement().textContent = ".".concat(sanitizedCssScope, " { ").concat(value, " }"); - }); - } - - /** - * Initializes the color picker dependent updater components. - * Retrieves the components and elements, and adds them to the elements array. - * Adds an action hook for the frm_style_options_color_change event. - */ - }, { - key: "initColorPickerDependentUpdaterComponents", - value: function initColorPickerDependentUpdaterComponents() { - var components = document.querySelectorAll('.frm-style-dependent-updater-component.frm-colorpicker'); - var elements = []; - components.forEach(function (component) { - var element = component.querySelector('input.hex'); - var id = element !== undefined ? element.getAttribute('id') : null; - if (null !== id) { - elements.push({ - id: id, - dependentUpdaterClass: new _components_dependent_updater_component__WEBPACK_IMPORTED_MODULE_1__["default"](component, 'colorpicker') - }); - } - }); - wp.hooks.addAction('frm_style_options_color_change', 'formidable', function (_ref) { - var event = _ref.event, - value = _ref.value; - var container = event.target.closest('.wp-picker-container'); - var id = event.target.getAttribute('id'); - container.querySelector('.wp-color-result-text').innerText = value; - elements.forEach(function (element) { - if (element.id === id) { - element.dependentUpdaterClass.updateAllDependentElements(value); - } - }); - }); - } - - /** - * Initializes the hover functionality for the style options. - * Creates a hover element and appends it to the settingsWrapper. - * Adds event listeners for mouseover and click events. - */ - }, { - key: "initHover", - value: function initHover() { - var settingsWrapper = document.querySelector('.frm-right-panel .styling_settings .accordion-container'); - if (!settingsWrapper) { - return; - } - var hoverElement = document.createElement('div'); - hoverElement.classList.add('frm_hidden'); - hoverElement.classList.add('frm-style-settings-hover'); - settingsWrapper.append(hoverElement); - var styleOptionsMenu = settingsWrapper.querySelector(':scope > ul'); - styleOptionsMenu.querySelectorAll(':scope > li').forEach(function (item) { - item.querySelector('h3').addEventListener('mouseover', function (event) { - hoverElement.style.transform = "translateY(".concat(event.target.closest('li').offsetTop, "px)"); - hoverElement.classList.add('frm-animating'); - hoverElement.classList.remove('frm_hidden'); - setTimeout(function () { - hoverElement.classList.remove('frm-animating'); - }, 250); - }); - }); - var accordionitems = document.querySelectorAll('#frm_style_sidebar .accordion-section h3'); - accordionitems.forEach(function (item) { - item.addEventListener('click', function () { - hoverElement.classList.add('frm_hidden'); - }); - }); - } - - /** - * Initializes the copy to clipboard functionality for style classes. - * Adds a click event listener to the copyLabel element. - * Copies the class name to the clipboard and displays a success message. - * - * @param {string} successMessage The success message to display. - * @return {void} Initializes the copy to clipboard functionality for style classes. - */ - }, { - key: "initStyleClassCopyToClipboard", - value: function initStyleClassCopyToClipboard(successMessage) { - var _this3 = this; - var labels = document.querySelectorAll('.frm-copy-text'); - labels.forEach(function (label) { - label.addEventListener('click', function (event) { - var className = event.currentTarget.innerText; - if (!navigator.clipboard || !navigator.clipboard.writeText) { - if (true === _this3.fallbackCopyToClipboard(className, event.currentTarget)) { - _this3.success(successMessage); - } - return; - } - navigator.clipboard.writeText(className).then(function () { - _this3.success(successMessage); - }); - }); - }); - } - - /** - * Toggle the visibility of the custom CSS editor. - * - * @return {void} - */ - }, { - key: "toggleVisibilityOfCustomCSSEditor", - value: function toggleVisibilityOfCustomCSSEditor() { - var toggle = document.getElementById('frm_enable_single_style_custom_css'); - var editor = document.getElementById('frm_single_style_custom_css_editor'); - if (!toggle || !editor) { - return; - } - toggle.addEventListener('change', function (event) { - editor.classList.toggle('frm_hidden', !event.target.checked); - }); - } - - /** - * Copy to clipboard if the Clipboard API is not available. - * - * @param {string} couponCode The string being copied to the clipboard. - * @param {HTMLElement} copyButton Used to position the temporary input element. - * @return {boolean} True if the copy was successful, false otherwise. - */ - }, { - key: "fallbackCopyToClipboard", - value: function fallbackCopyToClipboard(couponCode, copyButton) { - if ('function' !== typeof document.execCommand) { - return false; - } - var copySuccess; - var temp = document.createElement('input'); - temp.setAttribute('type', 'text'); - temp.value = couponCode; - copyButton.parentElement.append(temp); - temp.focus(); - temp.select(); - temp.setSelectionRange(0, 99999); - - // Hide the input so it doesn't show up in the UI. - temp.style.position = 'absolute'; - temp.style.left = '-9999px'; - temp.style.top = '-9999px'; - try { - copySuccess = document.execCommand('copy'); - } catch (error) { - copySuccess = false; - } - temp.remove(); - return copySuccess; - } - }]); -}(); -new frmStyleOptions(); -})(); - -/******/ })() -; -//# sourceMappingURL=formidable_styles.js.map \ No newline at end of file +(()=>{var t={8616:t=>{t.exports=function(t,e){var n,r,i=0;function o(){var o,s,a=n,c=arguments.length;t:for(;a;){if(a.args.length===arguments.length){for(s=0;s{var r;!function(){"use strict";var i={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function o(t){return function(t,e){var n,r,s,a,c,l,u,f,p,d=1,h=t.length,y="";for(r=0;r=0),a.type){case"b":n=parseInt(n,10).toString(2);break;case"c":n=String.fromCharCode(parseInt(n,10));break;case"d":case"i":n=parseInt(n,10);break;case"j":n=JSON.stringify(n,null,a.width?parseInt(a.width):0);break;case"e":n=a.precision?parseFloat(n).toExponential(a.precision):parseFloat(n).toExponential();break;case"f":n=a.precision?parseFloat(n).toFixed(a.precision):parseFloat(n);break;case"g":n=a.precision?String(Number(n.toPrecision(a.precision))):parseFloat(n);break;case"o":n=(parseInt(n,10)>>>0).toString(8);break;case"s":n=String(n),n=a.precision?n.substring(0,a.precision):n;break;case"t":n=String(!!n),n=a.precision?n.substring(0,a.precision):n;break;case"T":n=Object.prototype.toString.call(n).slice(8,-1).toLowerCase(),n=a.precision?n.substring(0,a.precision):n;break;case"u":n=parseInt(n,10)>>>0;break;case"v":n=n.valueOf(),n=a.precision?n.substring(0,a.precision):n;break;case"x":n=(parseInt(n,10)>>>0).toString(16);break;case"X":n=(parseInt(n,10)>>>0).toString(16).toUpperCase()}i.json.test(a.type)?y+=n:(!i.number.test(a.type)||f&&!a.sign?p="":(p=f?"+":"-",n=n.toString().replace(i.sign,"")),l=a.pad_char?"0"===a.pad_char?"0":a.pad_char.charAt(1):" ",u=a.width-(p+n).length,c=a.width&&u>0?l.repeat(u):"",y+=a.align?p+n+c:"0"===l?p+c+n:c+p+n)}return y}(function(t){if(a[t])return a[t];for(var e,n=t,r=[],o=0;n;){if(null!==(e=i.text.exec(n)))r.push(e[0]);else if(null!==(e=i.modulo.exec(n)))r.push("%");else{if(null===(e=i.placeholder.exec(n)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){o|=1;var s=[],c=e[2],l=[];if(null===(l=i.key.exec(c)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(s.push(l[1]);""!==(c=c.substring(l[0].length));)if(null!==(l=i.key_access.exec(c)))s.push(l[1]);else{if(null===(l=i.index_access.exec(c)))throw new SyntaxError("[sprintf] failed to parse named argument key");s.push(l[1])}e[2]=s}else o|=2;if(3===o)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");r.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}n=n.substring(e[0].length)}return a[t]=r}(t),arguments)}function s(t,e){return o.apply(null,[t].concat(e||[]))}var a=Object.create(null);"undefined"!=typeof window&&(window.sprintf=o,window.vsprintf=s,void 0===(r=function(){return{sprintf:o,vsprintf:s}}.call(e,n,e,t))||(t.exports=r))}()}},e={};function n(r){var i=e[r];if(void 0!==i)return i.exports;var o=e[r]={exports:{}};return t[r](o,o.exports,n),o.exports}n.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return n.d(e,{a:e}),e},n.d=(t,e)=>{for(var r in e)n.o(e,r)&&!n.o(t,r)&&Object.defineProperty(t,r,{enumerable:!0,get:e[r]})},n.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";var t,e,r,i,o=n(8616),s=n.n(o);function a(t){return a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},a(t)}function c(t){var e=function(t){if("object"!=a(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=a(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==a(e)?e:e+""}n(7604),s()(console.error),t={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},e=["(","?"],r={")":["("],":":["?","?:"]},i=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var l={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,n){if(t)throw e;return n}};var u={contextDelimiter:"",onMissingKey:null};function f(t,e){var n;for(n in this.data=t,this.pluralForms={},this.options={},u)this.options[n]=void 0!==e&&n in e?e[n]:u[n]}function p(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function d(t){for(var e=1;e=0||t[c]3&&void 0!==arguments[3]?arguments[3]:10,s=t[e];if(v(n)&&m(r))if("function"==typeof i)if("number"==typeof o){var a={callback:i,priority:o,namespace:r};if(s[n]){var c,l=s[n].handlers;for(c=l.length;c>0&&!(o>=l[c-1].priority);c--);c===l.length?l[c]=a:l.splice(c,0,a),s.__current.forEach(function(t){t.name===n&&t.currentIndex>=c&&t.currentIndex++})}else s[n]={handlers:[a],runs:0};"hookAdded"!==n&&t.doAction("hookAdded",n,r,i,o)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},b=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r,i){var o=t[e];if(v(r)&&(n||m(i))){if(!o[r])return 0;var s=0;if(n)s=o[r].handlers.length,o[r]={runs:o[r].runs,handlers:[]};else for(var a=o[r].handlers,c=function(t){a[t].namespace===i&&(a.splice(t,1),s++,o.__current.forEach(function(e){e.name===r&&e.currentIndex>=t&&e.currentIndex--}))},l=a.length-1;l>=0;l--)c(l);return"hookRemoved"!==r&&t.doAction("hookRemoved",r,i),s}}},_=function(t,e){return function(n,r){var i=t[e];return void 0!==r?n in i&&i[n].handlers.some(function(t){return t.namespace===r}):n in i}},x=function(t,e){var n=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(r){var i=t[e];i[r]||(i[r]={handlers:[],runs:0}),i[r].runs++;for(var o=i[r].handlers,s=arguments.length,a=new Array(s>1?s-1:0),c=1;c1&&void 0!==arguments[1]?arguments[1]:"default";r.data[e]=d(d(d({},h),r.data[e]),t),r.data[e][""]=d(d({},h[""]),r.data[e][""])},a=function(t,e){s(t,e),o()},c=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,n=arguments.length>2?arguments[2]:void 0,i=arguments.length>3?arguments[3]:void 0,o=arguments.length>4?arguments[4]:void 0;return r.data[t]||s(void 0,t),r.dcnpgettext(t,e,n,i,o)},l=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},u=function(t,e,r){var i=c(r,e,t);return n?(i=n.applyFilters("i18n.gettext_with_context",i,t,e,r),n.applyFilters("i18n.gettext_with_context_"+l(r),i,t,e,r)):i};if(n){var p=function(t){y.test(t)&&o()};n.addAction("hookAdded","core/i18n",p),n.addAction("hookRemoved","core/i18n",p)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return r.data[t]},setLocaleData:a,resetLocaleData:function(t,e){r.data={},r.pluralForms={},a(t,e)},subscribe:function(t){return i.add(t),function(){return i.delete(t)}},__:function(t,e){var r=c(e,void 0,t);return n?(r=n.applyFilters("i18n.gettext",r,t,e),n.applyFilters("i18n.gettext_"+l(e),r,t,e)):r},_x:u,_n:function(t,e,r,i){var o=c(i,void 0,t,e,r);return n?(o=n.applyFilters("i18n.ngettext",o,t,e,r,i),n.applyFilters("i18n.ngettext_"+l(i),o,t,e,r,i)):o},_nx:function(t,e,r,i,o){var s=c(o,i,t,e,r);return n?(s=n.applyFilters("i18n.ngettext_with_context",s,t,e,r,i,o),n.applyFilters("i18n.ngettext_with_context_"+l(o),s,t,e,r,i,o)):s},isRTL:function(){return"rtl"===u("ltr","text direction")},hasTranslation:function(t,e,i){var o,s,a=e?e+""+t:t,c=!(null===(o=r.data)||void 0===o||null===(s=o[null!=i?i:"default"])||void 0===s||!s[a]);return n&&(c=n.applyFilters("i18n.has_translation",c,t,e,i),c=n.applyFilters("i18n.has_translation_"+l(i),c,t,e,i)),c}}}(0,0,E));A.getLocaleData.bind(A),A.setLocaleData.bind(A),A.resetLocaleData.bind(A),A.subscribe.bind(A);var C=A.__.bind(A);function O(t){return O="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},O(t)}function F(t,e){for(var n=0;n=this.cssEditorOptions.retryLimit||(void 0!==window.frm_single_style_custom_css_wp_editor&&void 0!==window.frm_single_style_custom_css_wp_editor.codemirror?(this.cssEditorInstance=window.frm_single_style_custom_css_wp_editor.codemirror,this.onCssEditorReady()):setTimeout(function(){t.cssEditorOptions.retryCount++,t.initCustomCSSEditorInstance()},500))}},{key:"getInlineStyleElement",value:function(){return null!==this.cssInlineStyleElement||(this.cssInlineStyleElement=document.createElement("style"),document.head.append(this.cssInlineStyleElement)),this.cssInlineStyleElement}},{key:"onCssEditorReady",value:function(){var t,e=this,n=null===(t=document.getElementById("frm_style_class_custom_css"))||void 0===t||null===(t=t.dataset)||void 0===t?void 0:t.cssScope;if(null!==n){var r=CSS.escape(n);this.cssEditorInstance.on("change",function(t){var n=t.getValue().replace(/<[^>]*>/g,"").trim();e.getInlineStyleElement().textContent=".".concat(r," { ").concat(n," }")})}}},{key:"initColorPickerDependentUpdaterComponents",value:function(){var t=document.querySelectorAll(".frm-style-dependent-updater-component.frm-colorpicker"),e=[];t.forEach(function(t){var n=t.querySelector("input.hex"),r=void 0!==n?n.getAttribute("id"):null;null!==r&&e.push({id:r,dependentUpdaterClass:new j(t,"colorpicker")})}),wp.hooks.addAction("frm_style_options_color_change","formidable",function(t){var n=t.event,r=t.value,i=n.target.closest(".wp-picker-container"),o=n.target.getAttribute("id");i.querySelector(".wp-color-result-text").innerText=r,e.forEach(function(t){t.id===o&&t.dependentUpdaterClass.updateAllDependentElements(r)})})}},{key:"initHover",value:function(){var t=document.querySelector(".frm-right-panel .styling_settings .accordion-container");if(t){var e=document.createElement("div");e.classList.add("frm_hidden"),e.classList.add("frm-style-settings-hover"),t.append(e),t.querySelector(":scope > ul").querySelectorAll(":scope > li").forEach(function(t){t.querySelector("h3").addEventListener("mouseover",function(t){e.style.transform="translateY(".concat(t.target.closest("li").offsetTop,"px)"),e.classList.add("frm-animating"),e.classList.remove("frm_hidden"),setTimeout(function(){e.classList.remove("frm-animating")},250)})}),document.querySelectorAll("#frm_style_sidebar .accordion-section h3").forEach(function(t){t.addEventListener("click",function(){e.classList.add("frm_hidden")})})}}},{key:"initStyleClassCopyToClipboard",value:function(t){var e=this;document.querySelectorAll(".frm-copy-text").forEach(function(n){n.addEventListener("click",function(n){var r=n.currentTarget.innerText;navigator.clipboard&&navigator.clipboard.writeText?navigator.clipboard.writeText(r).then(function(){e.success(t)}):!0===e.fallbackCopyToClipboard(r,n.currentTarget)&&e.success(t)})})}},{key:"toggleVisibilityOfCustomCSSEditor",value:function(){var t=document.getElementById("frm_enable_single_style_custom_css"),e=document.getElementById("frm_single_style_custom_css_editor");t&&e&&t.addEventListener("change",function(t){e.classList.toggle("frm_hidden",!t.target.checked)})}},{key:"fallbackCopyToClipboard",value:function(t,e){if("function"!=typeof document.execCommand)return!1;var n,r=document.createElement("input");r.setAttribute("type","text"),r.value=t,e.parentElement.append(r),r.focus(),r.select(),r.setSelectionRange(0,99999),r.style.position="absolute",r.style.left="-9999px",r.style.top="-9999px";try{n=document.execCommand("copy")}catch(t){n=!1}return r.remove(),n}}])&&P(t.prototype,e),Object.defineProperty(t,"prototype",{writable:!1}),t;var t,e}())})()})(); \ No newline at end of file diff --git a/js/frm_testing_mode.js b/js/frm_testing_mode.js index 485b5f52a7..33b94e6693 100644 --- a/js/frm_testing_mode.js +++ b/js/frm_testing_mode.js @@ -1,3485 +1,2 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/admin/addon-state.js": -/*!*************************************!*\ - !*** ./js/src/admin/addon-state.js ***! - \*************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addonError: () => (/* binding */ addonError), -/* harmony export */ afterAddonInstall: () => (/* binding */ afterAddonInstall), -/* harmony export */ extractErrorFromAddOnResponse: () => (/* binding */ extractErrorFromAddOnResponse), -/* harmony export */ toggleAddonState: () => (/* binding */ toggleAddonState) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } -function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } - -var _frmDom = frmDom, - div = _frmDom.div, - svg = _frmDom.svg; - -/** - * Toggles the state of an add-on (ie. enable or disable an add-on). - * - * @param {Element} clicked - * @param {string} action - */ -function toggleAddonState(clicked, action) { - var _window$ajaxurl; - var ajaxurl = (_window$ajaxurl = window.ajaxurl) !== null && _window$ajaxurl !== void 0 ? _window$ajaxurl : frm_js.ajax_url; - - // Remove any leftover error messages, output an icon and get the plugin basename that needs to be activated. - jQuery('.frm-addon-error').remove(); - var button = jQuery(clicked); - var plugin = button.attr('rel'); - var el = button.parent(); - var message = el.parent().find('.addon-status-label'); - button.addClass('frm_loading_button'); - - // Process the Ajax to perform the activation. - jQuery.ajax({ - url: ajaxurl, - type: 'POST', - async: true, - cache: false, - dataType: 'json', - data: { - action: action, - nonce: frmGlobal.nonce, - plugin: plugin - }, - success: function success(response) { - var _response$data, _response; - response = (_response$data = (_response = response) === null || _response === void 0 ? void 0 : _response.data) !== null && _response$data !== void 0 ? _response$data : response; - var saveAndReload; - if ('string' !== typeof response && 'string' === typeof response.message) { - if (response.saveAndReload !== undefined) { - saveAndReload = response.saveAndReload; - } - response = response.message; - } - var error = extractErrorFromAddOnResponse(response); - if (error) { - addonError(error, el, button); - return; - } - afterAddonInstall(response, button, message, el, saveAndReload, action); - - /** - * Trigger an action after successfully toggling the addon state. - * - * @param {Object} response - */ - wp.hooks.doAction('frm_update_addon_state', response); - }, - error: function error() { - button.removeClass('frm_loading_button'); - } - }); -} -function extractErrorFromAddOnResponse(response) { - if (typeof response !== 'string') { - if (response.success) { - return false; - } - if (response.form) { - if (jQuery(response.form).is('#message')) { - return { - message: jQuery(response.form).find('p').html() - }; - } - } - return response; - } - return false; -} -function afterAddonInstall(response, button, message, el, saveAndReload) { - var action = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 'frm_activate_addon'; - var frmAdminJs = frm_admin_js; - var addonStatuses = document.querySelectorAll('.frm-addon-status'); - addonStatuses.forEach(function (addonStatus) { - addonStatus.textContent = response; - addonStatus.style.display = 'block'; - }); - - // The Ajax request was successful, so let's update the output. - button.css({ - opacity: '0' - }); - document.querySelectorAll('.frm-oneclick').forEach(function (oneClick) { - oneClick.style.display = 'none'; - }); - showUpgradeModalSuccess(); - - // Proceed with CSS changes - var actionMap = { - frm_activate_addon: { - class: 'frm-addon-active', - message: frmAdminJs.active - }, - frm_deactivate_addon: { - class: 'frm-addon-installed', - message: frmAdminJs.installed - }, - frm_uninstall_addon: { - class: 'frm-addon-not-installed', - message: frmAdminJs.not_installed - } - }; - actionMap.frm_install_addon = actionMap.frm_activate_addon; - var _message = _slicedToArray(message, 1), - messageElement = _message[0]; - if (messageElement) { - messageElement.textContent = actionMap[action].message; - } - var _el = _slicedToArray(el, 1), - parentElement = _el[0].parentElement; - parentElement.classList.remove('frm-addon-not-installed', 'frm-addon-installed', 'frm-addon-active'); - parentElement.classList.add(actionMap[action].class); - var _button = _slicedToArray(button, 1), - buttonElement = _button[0]; - buttonElement.classList.remove('frm_loading_button'); - - // Maybe refresh import and SMTP pages - var refreshPage = document.querySelectorAll('.frm-admin-page-import, #frm-admin-smtp, #frm-welcome'); - if (refreshPage.length > 0) { - window.location.reload(); - return; - } - if (['settings', 'form_builder'].includes(saveAndReload)) { - addonStatuses.forEach(function (addonStatus) { - var inModal = null !== addonStatus.closest('#frm_upgrade_modal'); - addonStatus.append(getSaveAndReloadSettingsOptions(saveAndReload, inModal)); - }); - } -} -function addonError(response, el, button) { - if (response.form) { - jQuery('.frm-inline-error').remove(); - button.closest('.frm-card').html(response.form).css({ - padding: 5 - }).find('#upgrade').attr('rel', button.attr('rel')).on('click', installAddonWithCreds); - } else { - el.append("

                      ".concat(response.message, "

                      ")); - button.removeClass('frm_loading_button'); - jQuery('.frm-addon-error').delay(4000).fadeOut(); - } -} -function getSaveAndReloadSettingsOptions(saveAndReload, inModal) { - var className = 'frm-save-and-reload-options'; - var children = [saveAndReloadSettingsButton(saveAndReload)]; - if (inModal) { - children.push(closePopupButton()); - } - return div({ - className: className, - children: children - }); -} -function saveAndReloadSettingsButton(saveAndReload) { - var button = document.createElement('button'); - button.classList.add('frm-save-and-reload', 'button', 'button-primary', 'frm-button-primary'); - button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Save and Reload', 'formidable'); - button.addEventListener('click', function () { - if (saveAndReload === 'form_builder') { - saveAndReloadFormBuilder(); - } else if (saveAndReload === 'settings') { - saveAndReloadSettings(); - } - }); - return button; -} -function saveAndReloadSettings() { - var page = document.getElementById('form_settings_page'); - if (page) { - var form = page.querySelector('form.frm_form_settings'); - if (null !== form) { - wp.hooks.doAction('frm_reset_fields_updated'); - form.submit(); - } - } -} -function closePopupButton() { - var a = document.createElement('a'); - a.setAttribute('href', '#'); - a.classList.add('button', 'button-secondary', 'frm-button-secondary', 'dismiss'); - a.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Not Now', 'formidable'); - return a; -} -function saveAndReloadFormBuilder() { - var submitButton = document.getElementById('frm_submit_side_top'); - if (submitButton.classList.contains('frm_submit_ajax')) { - submitButton.setAttribute('data-new-addon-installed', true); - } - submitButton.click(); -} - -/** - * Updates the upgrade modal to show successful addon installation state. - * - * @private - * @return {void} - */ -function showUpgradeModalSuccess() { - var upgradeModal = document.getElementById('frm_upgrade_modal'); - if (!upgradeModal) { - return; - } - upgradeModal.classList.add('frm-success'); - var upgradeMessage = upgradeModal.querySelector('.frm-upgrade-message'); - if (upgradeMessage) { - var image = upgradeMessage.querySelector('img'); - upgradeMessage.replaceChildren((0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Great! Everything\'s ready to go!', 'formidable'), document.createElement('br'), (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('You just need to refresh the builder so the new field becomes available.', 'formidable')); - if (image) { - upgradeMessage.append(image); - } - } - var frmAddonStatus = document.querySelector('.frm-addon-status'); - if (frmAddonStatus) { - frmAddonStatus.textContent = ''; - } - var circledIcon = upgradeModal.querySelector('.frm-circled-icon'); - if (circledIcon) { - var _circledIcon$querySel; - circledIcon.classList.add('frm-circled-icon-green'); - (_circledIcon$querySel = circledIcon.querySelector('svg')) === null || _circledIcon$querySel === void 0 || _circledIcon$querySel.replaceWith(svg({ - href: '#frm_checkmark_icon' - })); - } -} -function installAddonWithCreds(e) { - // Prevent the default action, let the user know we are attempting to install again and go with it. - e.preventDefault(); - - // Now let's make another Ajax request once the user has submitted their credentials. - var proceed = jQuery(this); - var el = proceed.parent().parent(); - var plugin = proceed.attr('rel'); - proceed.addClass('frm_loading_button'); - jQuery.ajax({ - url: ajaxurl, - type: 'POST', - async: true, - cache: false, - dataType: 'json', - data: { - action: 'frm_install_addon', - nonce: frmAdminJs.nonce, - plugin: plugin, - hostname: el.find('#hostname').val(), - username: el.find('#username').val(), - password: el.find('#password').val() - }, - success: function success(response) { - var _response$data2, _response2; - response = (_response$data2 = (_response2 = response) === null || _response2 === void 0 ? void 0 : _response2.data) !== null && _response$data2 !== void 0 ? _response$data2 : response; - var error = extractErrorFromAddOnResponse(response); - if (error) { - addonError(error, el, proceed); - return; - } - afterAddonInstall(response, proceed, message, el); - }, - error: function error() { - proceed.removeClass('frm_loading_button'); - } - }); -} - -/***/ }), - -/***/ "./js/src/admin/upgrade-popup.js": -/*!***************************************!*\ - !*** ./js/src/admin/upgrade-popup.js ***! - \***************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addOneClick: () => (/* binding */ addOneClick), -/* harmony export */ initModal: () => (/* binding */ initModal), -/* harmony export */ initUpgradeModal: () => (/* binding */ initUpgradeModal) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); - -var _frmDom = frmDom, - svg = _frmDom.svg; -function getShowLinkHrefValue(link, showLink) { - var customLink = link.getAttribute('data-link'); - if (customLink === null || customLink === undefined || customLink === '') { - customLink = showLink.getAttribute('data-default'); - } - return customLink; -} - -/** - * Allow addons to be installed from the upgrade modal. - * - * @param {Element} link - * @param {string} context Either 'modal' or 'tab'. - * @param {string|undefined} upgradeLabel - */ -function addOneClick(link, context, upgradeLabel) { - var container; - if ('modal' === context) { - container = document.getElementById('frm_upgrade_modal'); - } else if ('tab' === context) { - container = document.getElementById(link.getAttribute('href').substr(1)); - } else { - return; - } - var oneclickMessage = container.querySelector('.frm-oneclick'); - var upgradeMessage = container.querySelector('.frm-upgrade-message'); - var showLink = container.querySelector('.frm-upgrade-link'); - var button = container.querySelector('.frm-oneclick-button'); - var addonStatus = container.querySelector('.frm-addon-status'); - var oneclick = link.getAttribute('data-oneclick'); - var newMessage = link.getAttribute('data-message'); - var showIt = 'block'; - var showMsg = 'block'; - var hideIt = 'none'; - var modalIconWrapper = container.querySelector('.frm-circled-icon'); - if (modalIconWrapper) { - var _modalIconWrapper$que; - modalIconWrapper.classList.remove('frm-circled-icon-green'); - (_modalIconWrapper$que = modalIconWrapper.querySelector('svg')) === null || _modalIconWrapper$que === void 0 || _modalIconWrapper$que.replaceWith(svg({ - href: '#frm_filled_lock_icon' - })); - } - var learnMoreLink = container.querySelector('.frm-learn-more'); - if (learnMoreLink) { - learnMoreLink.href = link.dataset.learnMore; - } - - // If one click upgrade, hide other content. - if (oneclickMessage !== null && button !== null && oneclick !== undefined && oneclick) { - if (newMessage === null) { - showMsg = 'none'; - } - showIt = 'none'; - hideIt = 'block'; - oneclick = JSON.parse(oneclick); - button.className = button.className.replace(' frm-install-addon', '').replace(' frm-activate-addon', ''); - button.className = "".concat(button.className, " ").concat(oneclick.class); - button.rel = oneclick.url; - oneclickMessage.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('This plugin is not activated. Would you like to activate it now?', 'formidable'); - button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Activate', 'formidable'); - var linkIcon = link.querySelector('use'); - if (linkIcon) { - modalIconWrapper === null || modalIconWrapper === void 0 || modalIconWrapper.querySelector('svg').replaceWith(svg({ - href: linkIcon.getAttribute('href') || linkIcon.getAttribute('xlink:href'), - // Get the icon from xlink:href if it has not been updated to use href - classList: ['frm_svg32'] - })); - } - } - if (!newMessage) { - newMessage = upgradeMessage.getAttribute('data-default'); - } - if (undefined !== upgradeLabel) { - newMessage = newMessage.replace('', upgradeLabel); - } - upgradeMessage.innerHTML = newMessage; - if (link.dataset.upsellImage) { - upgradeMessage.append(frmDom.img({ - src: link.dataset.upsellImage, - alt: link.dataset.upgrade - })); - } - - // Either set the link or use the default. - showLink.href = getShowLinkHrefValue(link, showLink); - addonStatus.style.display = 'none'; - if (oneclickMessage) { - oneclickMessage.style.display = hideIt; - } - if (button) { - button.style.display = hideIt === 'block' ? 'inline-block' : hideIt; - } - upgradeMessage.style.display = showMsg; - showLink.style.display = showIt === 'block' ? 'inline-block' : showIt; - var showLinkParent = showLink.closest('.frm-upgrade-modal-actions'); - if (showLinkParent) { - showLinkParent.style.display = showIt === 'block' ? 'flex' : showIt; - } -} -function initModal(id, width) { - var $info = jQuery(id); - if (!$info.length) { - return false; - } - if (width === undefined) { - width = '552px'; - } - var dialogArgs = { - dialogClass: 'frm-dialog', - modal: true, - autoOpen: false, - closeOnEscape: true, - width: width, - resizable: false, - draggable: false, - open: function open() { - jQuery('.ui-dialog-titlebar').addClass('frm_hidden').removeClass('ui-helper-clearfix'); - jQuery('#wpwrap').addClass('frm_overlay'); - jQuery('.frm-dialog').removeClass('ui-widget ui-widget-content ui-corner-all'); - $info.removeClass('ui-dialog-content ui-widget-content'); - bindClickForDialogClose($info); - }, - close: function close() { - jQuery('#wpwrap').removeClass('frm_overlay'); - jQuery('.spinner').css('visibility', 'hidden'); - this.removeAttribute('data-option-type'); - var optionType = document.getElementById('bulk-option-type'); - if (optionType) { - optionType.value = ''; - } - } - }; - $info.dialog(dialogArgs); - return $info; -} -function bindClickForDialogClose($modal) { - var closeModal = function closeModal() { - $modal.dialog('close'); - }; - jQuery('.ui-widget-overlay').on('click', closeModal); - $modal.on('click', 'a.dismiss', closeModal); -} -function initUpgradeModal() { - var $info = initModal('#frm_upgrade_modal'); - if ($info === false) { - return; - } - document.addEventListener('click', handleUpgradeClick); - frmDom.util.documentOn('change', 'select.frm_select_with_upgrade', handleUpgradeClick); - function handleUpgradeClick(event) { - var element; - var link; - var content; - element = event.target; - if (!element.classList) { - return; - } - var showExpiredModal = element.classList.contains('frm_show_expired_modal') || null !== element.querySelector('.frm_show_expired_modal') || element.closest('.frm_show_expired_modal'); - - // If a `select` element is clicked, check if the selected option has a 'data-upgrade' attribute - if (event.type === 'change' && element.classList.contains('frm_select_with_upgrade')) { - var selectedOption = element.options[element.selectedIndex]; - if (selectedOption && selectedOption.dataset.upgrade) { - element = selectedOption; - } - } - if (!element.dataset.upgrade) { - var parent = element.closest('[data-upgrade]'); - if (!parent) { - parent = element.closest('.frm_field_box'); - if (!parent) { - return; - } - // Fake it if it's missing to avoid error. - element.dataset.upgrade = ''; - } - element = parent; - } - if (showExpiredModal) { - var hookName = 'frm_show_expired_modal'; - wp.hooks.doAction(hookName, element); - return; - } - var upgradeLabel = element.dataset.upgrade; - if (!upgradeLabel || element.classList.contains('frm_show_upgrade_tab')) { - return; - } - event.preventDefault(); - var modal = $info.get(0); - modal.classList.remove('frm-success'); - var lockIcon = modal.querySelector('.frm_lock_icon'); - if (lockIcon) { - lockIcon.style.display = 'block'; - lockIcon.classList.remove('frm_lock_open_icon'); - lockIcon.querySelector('use').setAttribute('href', '#frm_lock_icon'); - } - var upgradeImageId = 'frm_upgrade_modal_image'; - var oldImage = document.getElementById(upgradeImageId); - if (oldImage) { - oldImage.remove(); - } - if (element.dataset.image && lockIcon) { - lockIcon.style.display = 'none'; - lockIcon.parentNode.insertBefore(frmDom.img({ - id: upgradeImageId, - src: "".concat(frmGlobal.url, "/images/").concat(element.dataset.image) - }), lockIcon); - } - var level = modal.querySelector('.license-level'); - if (level) { - level.textContent = getRequiredLicenseFromTrigger(element); - } - - // If one click upgrade, hide other content - addOneClick(element, 'modal', upgradeLabel); - var notInstalled = modal.querySelector('.frm_are_not_installed'); - notInstalled.style.display = element.dataset.image || element.dataset.oneclick ? 'none' : 'inline-block'; - notInstalled.textContent = notInstalled.dataset.default; - modal.querySelector('.frm-upgrade-modal-title-prefix').style.display = element.dataset.oneclick ? 'inline' : 'none'; - modal.querySelector('.frm_feature_label').textContent = upgradeLabel; - modal.querySelector('.frm-upgrade-modal-title-suffix').style.display = 'none'; - modal.querySelector('h2').style.display = 'block'; - $info.dialog('open'); - - // set the utm medium - var button = modal.querySelector('.button-primary:not(.frm-oneclick-button)'); - link = button.getAttribute('href').replace(/(medium=)[a-z_-]+/ig, "$1".concat(element.getAttribute('data-medium'))); - content = element.getAttribute('data-content'); - if (content === null) { - content = ''; - } - link = link.replace(/(content=)[a-z_-]+/ig, "$1".concat(content)); - button.setAttribute('href', link); - if (element.classList.contains('frm_show_update')) { - applyUpdateModalOverrides(modal); - } - } -} - -/** - * Override upgrade modal content for update prompts. - * - * @since 6.29 - * - * @param {Element} modal The upgrade modal element. - */ -function applyUpdateModalOverrides(modal) { - var titlePrefix = modal.querySelector('.frm-upgrade-modal-title-prefix'); - if (titlePrefix) { - titlePrefix.style.display = 'none'; - } - var notInstalled = modal.querySelector('.frm_are_not_installed'); - if (notInstalled) { - notInstalled.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('require an update', 'formidable'); - notInstalled.style.display = ''; // Clear inline style, span defaults to display:inline. - } - var oneclickMsg = modal.querySelector('.frm-oneclick'); - if (oneclickMsg) { - oneclickMsg.style.display = 'none'; - } - var button = modal.querySelector('.frm-oneclick-button'); - if (button) { - button.textContent = (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Update Now', 'formidable'); - } -} -function getRequiredLicenseFromTrigger(element) { - if (element.dataset.requires) { - return element.dataset.requires; - } - return 'Pro'; -} - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. -(() => { -/*!************************************!*\ - !*** ./js/src/frm_testing_mode.js ***! - \************************************/ -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -(function () { - var _require = __webpack_require__(/*! ./admin/addon-state */ "./js/src/admin/addon-state.js"), - toggleAddonState = _require.toggleAddonState; - function onReady() { - jQuery(document).on('click', '#frm_upgrade_modal .frm-install-addon', installAddon); - jQuery(document).on('click', '#frm_upgrade_modal .frm-activate-addon', activateAddon); - function activateAddon(e) { - e.preventDefault(); - toggleAddonState(this, 'frm_activate_addon'); - } - function installAddon(e) { - e.preventDefault(); - toggleAddonState(this, 'frm_install_addon'); - } - initUpgradeModal(); - setupBootstrapDropdowns(); - jQuery(document).on('mouseenter.frm', '.frm_help', function () { - jQuery(this).off('mouseenter.frm'); - jQuery(this).tooltip('show'); - }); - } - function initUpgradeModal() { - return _initUpgradeModal.apply(this, arguments); - } - function _initUpgradeModal() { - _initUpgradeModal = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { - var upgradePopup; - return _regenerator().w(function (_context) { - while (1) switch (_context.n) { - case 0: - _context.n = 1; - return Promise.resolve(/*! import() */).then(__webpack_require__.bind(__webpack_require__, /*! ./admin/upgrade-popup */ "./js/src/admin/upgrade-popup.js")); - case 1: - upgradePopup = _context.v; - upgradePopup.initUpgradeModal(); - case 2: - return _context.a(2); - } - }, _callee); - })); - return _initUpgradeModal.apply(this, arguments); - } - function setupBootstrapDropdowns() { - var _window = window, - frmDom = _window.frmDom; - frmDom.bootstrap.setupBootstrapDropdowns(function () { - var toggle = document.querySelector('#frm_testmode_enabled_form_actions .dropdown-toggle'); - if (toggle) { - toggle.classList.add('frm-dropdown-toggle'); - if (!toggle.hasAttribute('role')) { - toggle.setAttribute('role', 'button'); - } - if (!toggle.hasAttribute('tabindex')) { - toggle.setAttribute('tabindex', 0); - } - } - }); - var element = document.getElementById('frm_testmode_enabled_form_actions'); - if (element) { - element.style.display = 'none'; - frmDom.bootstrap.multiselect.init.bind(element)(); - if (element.disabled) { - element.parentElement.querySelector('.dropdown-toggle').classList.add('frm_noallow'); - } - } - } - if (document.readyState === 'complete') { - onReady(); - } else { - document.addEventListener('DOMContentLoaded', onReady); - } - document.addEventListener('frm_after_start_over', function () { - setupBootstrapDropdowns(); - }); - jQuery(document).on('frmPageChanged frmFormComplete', function () { - setupBootstrapDropdowns(); - }); -})(); -})(); - -/******/ })() -; -//# sourceMappingURL=frm_testing_mode.js.map \ No newline at end of file +/*! For license information please see frm_testing_mode.js.LICENSE.txt */ +(()=>{var e={65:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(8793),o=r(1323);function a(e){var t=(0,n.A)(e);return function(e){return(0,o.A)(t,e)}}},1323:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n={"!":function(e){return!e},"*":function(e,t){return e*t},"/":function(e,t){return e/t},"%":function(e,t){return e%t},"+":function(e,t){return e+t},"-":function(e,t){return e-t},"<":function(e,t){return e":function(e,t){return e>t},">=":function(e,t){return e>=t},"==":function(e,t){return e===t},"!=":function(e,t){return e!==t},"&&":function(e,t){return e&&t},"||":function(e,t){return e||t},"?:":function(e,t,r){if(e)throw t;return r}};function o(e,t){var r,o,a,i,s,l,c=[];for(r=0;r{"use strict";r.d(t,{A:()=>o});var n=r(65);function o(e){var t=(0,n.A)(e);return function(e){return+t({n:e})}}},8793:(e,t,r)=>{"use strict";var n,o,a,i;function s(e){for(var t,r,s,l,c=[],u=[];t=e.match(i);){for(r=t[0],(s=e.substr(0,t.index).trim())&&c.push(s);l=u.pop();){if(a[r]){if(a[r][0]===l){r=a[r][1]||r;break}}else if(o.indexOf(l)>=0||n[l]s}),n={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},o=["(","?"],a={")":["("],":":["?","?:"]},i=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/},7521:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(6956),o=r(7395);const a=function(e,t){return function(r,a,i){var s=arguments.length>3&&void 0!==arguments[3]?arguments[3]:10,l=e[t];if((0,o.A)(r)&&(0,n.A)(a))if("function"==typeof i)if("number"==typeof s){var c={callback:i,priority:s,namespace:a};if(l[r]){var u,d=l[r].handlers;for(u=d.length;u>0&&!(s>=d[u-1].priority);u--);u===d.length?d[u]=c:d.splice(u,0,c),l.__current.forEach(function(e){e.name===r&&e.currentIndex>=u&&e.currentIndex++})}else l[r]={handlers:[c],runs:0};"hookAdded"!==r&&e.doAction("hookAdded",r,a,i,s)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}}},11:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(){var r,n,o=e[t];return null!==(r=null===(n=o.__current[o.__current.length-1])||void 0===n?void 0:n.name)&&void 0!==r?r:null}}},5375:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(7395);const o=function(e,t){return function(r){var o=e[t];if((0,n.A)(r))return o[r]&&o[r].runs?o[r].runs:0}}},3561:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r){var n=e[t];return void 0===r?void 0!==n.__current[0]:!!n.__current[0]&&r===n.__current[0].name}}},8830:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){return function(r,n){var o=e[t];return void 0!==n?r in o&&o[r].handlers.some(function(e){return e.namespace===n}):r in o}}},7765:(e,t,r)=>{"use strict";r.d(t,{A:()=>f});var n=r(3029),o=r(7521),a=r(4194),i=r(8830),s=r(6763),l=r(11),c=r(3561),u=r(5375),d=function e(){(0,n.A)(this,e),this.actions=Object.create(null),this.actions.__current=[],this.filters=Object.create(null),this.filters.__current=[],this.addAction=(0,o.A)(this,"actions"),this.addFilter=(0,o.A)(this,"filters"),this.removeAction=(0,a.A)(this,"actions"),this.removeFilter=(0,a.A)(this,"filters"),this.hasAction=(0,i.A)(this,"actions"),this.hasFilter=(0,i.A)(this,"filters"),this.removeAllActions=(0,a.A)(this,"actions",!0),this.removeAllFilters=(0,a.A)(this,"filters",!0),this.doAction=(0,s.A)(this,"actions"),this.applyFilters=(0,s.A)(this,"filters",!0),this.currentAction=(0,l.A)(this,"actions"),this.currentFilter=(0,l.A)(this,"filters"),this.doingAction=(0,c.A)(this,"actions"),this.doingFilter=(0,c.A)(this,"filters"),this.didAction=(0,u.A)(this,"actions"),this.didFilter=(0,u.A)(this,"filters")};const f=function(){return new d}},4194:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(6956),o=r(7395);const a=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(a,i){var s=e[t];if((0,o.A)(a)&&(r||(0,n.A)(i))){if(!s[a])return 0;var l=0;if(r)l=s[a].handlers.length,s[a]={runs:s[a].runs,handlers:[]};else for(var c=s[a].handlers,u=function(e){c[e].namespace===i&&(c.splice(e,1),l++,s.__current.forEach(function(t){t.name===a&&t.currentIndex>=e&&t.currentIndex--}))},d=c.length-1;d>=0;d--)u(d);return"hookRemoved"!==a&&e.doAction("hookRemoved",a,i),l}}}},6763:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e,t){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var o=e[t];o[n]||(o[n]={handlers:[],runs:0}),o[n].runs++;for(var a=o[n].handlers,i=arguments.length,s=new Array(i>1?i-1:0),l=1;l{"use strict";r.d(t,{se:()=>n});var n=(0,r(7765).A)();n.addAction,n.addFilter,n.removeAction,n.removeFilter,n.hasAction,n.hasFilter,n.removeAllActions,n.removeAllFilters,n.doAction,n.applyFilters,n.currentAction,n.currentFilter,n.doingAction,n.doingFilter,n.didAction,n.didFilter,n.actions,n.filters},7395:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The hook name must be a non-empty string."),!1):/^__/.test(e)?(console.error("The hook name cannot begin with `__`."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(e)||(console.error("The hook name can only contain numbers, letters, dashes, periods and underscores."),!1)}},6956:(e,t,r)=>{"use strict";r.d(t,{A:()=>n});const n=function(e){return"string"!=typeof e||""===e?(console.error("The namespace must be a non-empty string."),!1):!!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(e)||(console.error("The namespace can only contain numbers, letters, dashes, periods, underscores and slashes."),!1)}},772:(e,t,r)=>{"use strict";r.d(t,{h:()=>c});var n=r(4467),o=r(5397);function a(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter(function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable})),r.push.apply(r,n)}return r}function i(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:"default";n.data[t]=i(i(i({},s),n.data[t]),e),n.data[t][""]=i(i({},s[""]),n.data[t][""])},d=function(e,t){u(e,t),c()},f=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",t=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,a=arguments.length>4?arguments[4]:void 0;return n.data[e]||u(void 0,e),n.dcnpgettext(e,t,r,o,a)},p=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},m=function(e,t,n){var o=f(n,t,e);return r?(o=r.applyFilters("i18n.gettext_with_context",o,e,t,n),r.applyFilters("i18n.gettext_with_context_"+p(n),o,e,t,n)):o};if(e&&d(e,t),r){var v=function(e){l.test(e)&&c()};r.addAction("hookAdded","core/i18n",v),r.addAction("hookRemoved","core/i18n",v)}return{getLocaleData:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[e]},setLocaleData:d,resetLocaleData:function(e,t){n.data={},n.pluralForms={},d(e,t)},subscribe:function(e){return a.add(e),function(){return a.delete(e)}},__:function(e,t){var n=f(t,void 0,e);return r?(n=r.applyFilters("i18n.gettext",n,e,t),r.applyFilters("i18n.gettext_"+p(t),n,e,t)):n},_x:m,_n:function(e,t,n,o){var a=f(o,void 0,e,t,n);return r?(a=r.applyFilters("i18n.ngettext",a,e,t,n,o),r.applyFilters("i18n.ngettext_"+p(o),a,e,t,n,o)):a},_nx:function(e,t,n,o,a){var i=f(a,o,e,t,n);return r?(i=r.applyFilters("i18n.ngettext_with_context",i,e,t,n,o,a),r.applyFilters("i18n.ngettext_with_context_"+p(a),i,e,t,n,o,a)):i},isRTL:function(){return"rtl"===m("ltr","text direction")},hasTranslation:function(e,t,o){var a,i,s=t?t+""+e:e,l=!(null===(a=n.data)||void 0===a||null===(i=a[null!=o?o:"default"])||void 0===i||!i[s]);return r&&(l=r.applyFilters("i18n.has_translation",l,e,t,o),l=r.applyFilters("i18n.has_translation_"+p(o),l,e,t,o)),l}}}},5839:(e,t,r)=>{"use strict";r.d(t,{__:()=>i});var n=r(772),o=r(2133),a=(0,n.h)(void 0,void 0,o.se),i=(a.getLocaleData.bind(a),a.setLocaleData.bind(a),a.resetLocaleData.bind(a),a.subscribe.bind(a),a.__.bind(a));a._x.bind(a),a._n.bind(a),a._nx.bind(a),a.isRTL.bind(a),a.hasTranslation.bind(a)},9575:(e,t,r)=>{"use strict";r.d(t,{__:()=>n.__}),r(181),r(772);var n=r(5839)},181:(e,t,r)=>{"use strict";var n=r(8616),o=r.n(n);r(7604),o()(console.error)},1105:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addonError:()=>f,afterAddonInstall:()=>d,extractErrorFromAddOnResponse:()=>u,toggleAddonState:()=>c});var n=r(9575);function o(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=r){var n,o,a,i,s=[],l=!0,c=!1;try{if(a=(r=r.call(e)).next,0===t){if(Object(r)!==r)return;l=!1}else for(;!(l=(n=a.call(r)).done)&&(s.push(n.value),s.length!==t);l=!0);}catch(e){c=!0,o=e}finally{try{if(!l&&null!=r.return&&(i=r.return(),Object(i)!==i))return}finally{if(c)throw o}}return s}}(e,t)||function(e,t){if(e){if("string"==typeof e)return a(e,t);var r={}.toString.call(e).slice(8,-1);return"Object"===r&&e.constructor&&(r=e.constructor.name),"Map"===r||"Set"===r?Array.from(e):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?a(e,t):void 0}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function a(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=Array(t);r5&&void 0!==arguments[5]?arguments[5]:"frm_activate_addon",u=frm_admin_js,d=document.querySelectorAll(".frm-addon-status");d.forEach(function(t){t.textContent=e,t.style.display="block"}),t.css({opacity:"0"}),document.querySelectorAll(".frm-oneclick").forEach(function(e){e.style.display="none"}),function(){var e=document.getElementById("frm_upgrade_modal");if(e){e.classList.add("frm-success");var t=e.querySelector(".frm-upgrade-message");if(t){var r=t.querySelector("img");t.replaceChildren((0,n.__)("Great! Everything's ready to go!","formidable"),document.createElement("br"),(0,n.__)("You just need to refresh the builder so the new field becomes available.","formidable")),r&&t.append(r)}var o=document.querySelector(".frm-addon-status");o&&(o.textContent="");var a,i=e.querySelector(".frm-circled-icon");if(i)i.classList.add("frm-circled-icon-green"),null===(a=i.querySelector("svg"))||void 0===a||a.replaceWith(l({href:"#frm_checkmark_icon"}))}}();var f={frm_activate_addon:{class:"frm-addon-active",message:u.active},frm_deactivate_addon:{class:"frm-addon-installed",message:u.installed},frm_uninstall_addon:{class:"frm-addon-not-installed",message:u.not_installed}};f.frm_install_addon=f.frm_activate_addon;var m=o(r,1)[0];m&&(m.textContent=f[c].message);var v=o(a,1)[0].parentElement;v.classList.remove("frm-addon-not-installed","frm-addon-installed","frm-addon-active"),v.classList.add(f[c].class),o(t,1)[0].classList.remove("frm_loading_button"),document.querySelectorAll(".frm-admin-page-import, #frm-admin-smtp, #frm-welcome").length>0?window.location.reload():["settings","form_builder"].includes(i)&&d.forEach(function(e){var t=null!==e.closest("#frm_upgrade_modal");e.append(function(e,t){var r,o=[p(e)];return t&&o.push(((r=document.createElement("a")).setAttribute("href","#"),r.classList.add("button","button-secondary","frm-button-secondary","dismiss"),r.textContent=(0,n.__)("Not Now","formidable"),r)),s({className:"frm-save-and-reload-options",children:o})}(i,t))})}function f(e,t,r){e.form?(jQuery(".frm-inline-error").remove(),r.closest(".frm-card").html(e.form).css({padding:5}).find("#upgrade").attr("rel",r.attr("rel")).on("click",m)):(t.append('

                      '.concat(e.message,"

                      ")),r.removeClass("frm_loading_button"),jQuery(".frm-addon-error").delay(4e3).fadeOut())}function p(e){var t=document.createElement("button");return t.classList.add("frm-save-and-reload","button","button-primary","frm-button-primary"),t.textContent=(0,n.__)("Save and Reload","formidable"),t.addEventListener("click",function(){var t;"form_builder"===e?((t=document.getElementById("frm_submit_side_top")).classList.contains("frm_submit_ajax")&&t.setAttribute("data-new-addon-installed",!0),t.click()):"settings"===e&&function(){var e=document.getElementById("form_settings_page");if(e){var t=e.querySelector("form.frm_form_settings");null!==t&&(wp.hooks.doAction("frm_reset_fields_updated"),t.submit())}}()}),t}function m(e){e.preventDefault();var t=jQuery(this),r=t.parent().parent(),n=t.attr("rel");t.addClass("frm_loading_button"),jQuery.ajax({url:ajaxurl,type:"POST",async:!0,cache:!1,dataType:"json",data:{action:"frm_install_addon",nonce:frmAdminJs.nonce,plugin:n,hostname:r.find("#hostname").val(),username:r.find("#username").val(),password:r.find("#password").val()},success:function(e){var n,o,a=u(e=null!==(n=null===(o=e)||void 0===o?void 0:o.data)&&void 0!==n?n:e);a?f(a,r,t):d(e,t,message,r)},error:function(){t.removeClass("frm_loading_button")}})}},4260:(e,t,r)=>{"use strict";r.r(t),r.d(t,{addOneClick:()=>a,initModal:()=>i,initUpgradeModal:()=>s});var n=r(9575),o=frmDom.svg;function a(e,t,r){var a;if("modal"===t)a=document.getElementById("frm_upgrade_modal");else{if("tab"!==t)return;a=document.getElementById(e.getAttribute("href").substr(1))}var i,s=a.querySelector(".frm-oneclick"),l=a.querySelector(".frm-upgrade-message"),c=a.querySelector(".frm-upgrade-link"),u=a.querySelector(".frm-oneclick-button"),d=a.querySelector(".frm-addon-status"),f=e.getAttribute("data-oneclick"),p=e.getAttribute("data-message"),m="block",v="block",y="none",h=a.querySelector(".frm-circled-icon");h&&(h.classList.remove("frm-circled-icon-green"),null===(i=h.querySelector("svg"))||void 0===i||i.replaceWith(o({href:"#frm_filled_lock_icon"})));var g=a.querySelector(".frm-learn-more");if(g&&(g.href=e.dataset.learnMore),null!==s&&null!==u&&void 0!==f&&f){null===p&&(v="none"),m="none",y="block",f=JSON.parse(f),u.className=u.className.replace(" frm-install-addon","").replace(" frm-activate-addon",""),u.className="".concat(u.className," ").concat(f.class),u.rel=f.url,s.textContent=(0,n.__)("This plugin is not activated. Would you like to activate it now?","formidable"),u.textContent=(0,n.__)("Activate","formidable");var _=e.querySelector("use");_&&(null==h||h.querySelector("svg").replaceWith(o({href:_.getAttribute("href")||_.getAttribute("xlink:href"),classList:["frm_svg32"]})))}p||(p=l.getAttribute("data-default")),void 0!==r&&(p=p.replace('',r)),l.innerHTML=p,e.dataset.upsellImage&&l.append(frmDom.img({src:e.dataset.upsellImage,alt:e.dataset.upgrade})),c.href=function(e,t){var r=e.getAttribute("data-link");return null!=r&&""!==r||(r=t.getAttribute("data-default")),r}(e,c),d.style.display="none",s&&(s.style.display=y),u&&(u.style.display="block"===y?"inline-block":y),l.style.display=v,c.style.display="block"===m?"inline-block":m;var b=c.closest(".frm-upgrade-modal-actions");b&&(b.style.display="block"===m?"flex":m)}function i(e,t){var r=jQuery(e);if(!r.length)return!1;void 0===t&&(t="552px");var n={dialogClass:"frm-dialog",modal:!0,autoOpen:!1,closeOnEscape:!0,width:t,resizable:!1,draggable:!1,open:function(){var e,t;jQuery(".ui-dialog-titlebar").addClass("frm_hidden").removeClass("ui-helper-clearfix"),jQuery("#wpwrap").addClass("frm_overlay"),jQuery(".frm-dialog").removeClass("ui-widget ui-widget-content ui-corner-all"),r.removeClass("ui-dialog-content ui-widget-content"),e=r,t=function(){e.dialog("close")},jQuery(".ui-widget-overlay").on("click",t),e.on("click","a.dismiss",t)},close:function(){jQuery("#wpwrap").removeClass("frm_overlay"),jQuery(".spinner").css("visibility","hidden"),this.removeAttribute("data-option-type");var e=document.getElementById("bulk-option-type");e&&(e.value="")}};return r.dialog(n),r}function s(){var e=i("#frm_upgrade_modal");function t(t){var r,o,i;if((r=t.target).classList){var s=r.classList.contains("frm_show_expired_modal")||null!==r.querySelector(".frm_show_expired_modal")||r.closest(".frm_show_expired_modal");if("change"===t.type&&r.classList.contains("frm_select_with_upgrade")){var l=r.options[r.selectedIndex];l&&l.dataset.upgrade&&(r=l)}if(!r.dataset.upgrade){var c=r.closest("[data-upgrade]");if(!c){if(!(c=r.closest(".frm_field_box")))return;r.dataset.upgrade=""}r=c}if(s)wp.hooks.doAction("frm_show_expired_modal",r);else{var u=r.dataset.upgrade;if(u&&!r.classList.contains("frm_show_upgrade_tab")){t.preventDefault();var d=e.get(0);d.classList.remove("frm-success");var f=d.querySelector(".frm_lock_icon");f&&(f.style.display="block",f.classList.remove("frm_lock_open_icon"),f.querySelector("use").setAttribute("href","#frm_lock_icon"));var p="frm_upgrade_modal_image",m=document.getElementById(p);m&&m.remove(),r.dataset.image&&f&&(f.style.display="none",f.parentNode.insertBefore(frmDom.img({id:p,src:"".concat(frmGlobal.url,"/images/").concat(r.dataset.image)}),f));var v=d.querySelector(".license-level");v&&(v.textContent=function(e){return e.dataset.requires?e.dataset.requires:"Pro"}(r)),a(r,"modal",u);var y=d.querySelector(".frm_are_not_installed");y.style.display=r.dataset.image||r.dataset.oneclick?"none":"inline-block",y.textContent=y.dataset.default,d.querySelector(".frm-upgrade-modal-title-prefix").style.display=r.dataset.oneclick?"inline":"none",d.querySelector(".frm_feature_label").textContent=u,d.querySelector(".frm-upgrade-modal-title-suffix").style.display="none",d.querySelector("h2").style.display="block",e.dialog("open");var h=d.querySelector(".button-primary:not(.frm-oneclick-button)");o=h.getAttribute("href").replace(/(medium=)[a-z_-]+/gi,"$1".concat(r.getAttribute("data-medium"))),null===(i=r.getAttribute("data-content"))&&(i=""),o=o.replace(/(content=)[a-z_-]+/gi,"$1".concat(i)),h.setAttribute("href",o),r.classList.contains("frm_show_update")&&function(e){var t=e.querySelector(".frm-upgrade-modal-title-prefix");t&&(t.style.display="none");var r=e.querySelector(".frm_are_not_installed");r&&(r.textContent=(0,n.__)("require an update","formidable"),r.style.display="");var o=e.querySelector(".frm-oneclick");o&&(o.style.display="none");var a=e.querySelector(".frm-oneclick-button");a&&(a.textContent=(0,n.__)("Update Now","formidable"))}(d)}}}}!1!==e&&(document.addEventListener("click",t),frmDom.util.documentOn("change","select.frm_select_with_upgrade",t))}},8616:e=>{e.exports=function(e,t){var r,n,o=0;function a(){var a,i,s=r,l=arguments.length;e:for(;s;){if(s.args.length===arguments.length){for(i=0;i{var n;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function a(e){return function(e,t){var r,n,i,s,l,c,u,d,f,p=1,m=e.length,v="";for(n=0;n=0),s.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,s.width?parseInt(s.width):0);break;case"e":r=s.precision?parseFloat(r).toExponential(s.precision):parseFloat(r).toExponential();break;case"f":r=s.precision?parseFloat(r).toFixed(s.precision):parseFloat(r);break;case"g":r=s.precision?String(Number(r.toPrecision(s.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=s.precision?r.substring(0,s.precision):r;break;case"t":r=String(!!r),r=s.precision?r.substring(0,s.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=s.precision?r.substring(0,s.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=s.precision?r.substring(0,s.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}o.json.test(s.type)?v+=r:(!o.number.test(s.type)||d&&!s.sign?f="":(f=d?"+":"-",r=r.toString().replace(o.sign,"")),c=s.pad_char?"0"===s.pad_char?"0":s.pad_char.charAt(1):" ",u=s.width-(f+r).length,l=s.width&&u>0?c.repeat(u):"",v+=s.align?f+r+l:"0"===c?f+l+r:l+f+r)}return v}(function(e){if(s[e])return s[e];for(var t,r=e,n=[],a=0;r;){if(null!==(t=o.text.exec(r)))n.push(t[0]);else if(null!==(t=o.modulo.exec(r)))n.push("%");else{if(null===(t=o.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(t[2]){a|=1;var i=[],l=t[2],c=[];if(null===(c=o.key.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(i.push(c[1]);""!==(l=l.substring(c[0].length));)if(null!==(c=o.key_access.exec(l)))i.push(c[1]);else{if(null===(c=o.index_access.exec(l)))throw new SyntaxError("[sprintf] failed to parse named argument key");i.push(c[1])}t[2]=i}else a|=2;if(3===a)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return s[e]=n}(e),arguments)}function i(e,t){return a.apply(null,[e].concat(t||[]))}var s=Object.create(null);"undefined"!=typeof window&&(window.sprintf=a,window.vsprintf=i,void 0===(n=function(){return{sprintf:a,vsprintf:i}}.call(t,r,t,e))||(e.exports=n))}()},5397:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(1364),o={contextDelimiter:"",onMissingKey:null};function a(e,t){var r;for(r in this.data=e,this.pluralForms={},this.options={},o)this.options[r]=void 0!==t&&r in t?t[r]:o[r]}a.prototype.getPluralForm=function(e,t){var r,o,a,i=this.pluralForms[e];return i||("function"!=typeof(a=(r=this.data[e][""])["Plural-Forms"]||r["plural-forms"]||r.plural_forms)&&(o=function(e){var t,r,n;for(t=e.split(";"),r=0;r{"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}r.d(t,{A:()=>n})},4467:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(9922);function o(e,t,r){return(t=(0,n.A)(t))in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}},2327:(e,t,r)=>{"use strict";r.d(t,{A:()=>o});var n=r(2284);function o(e,t){if("object"!=(0,n.A)(e)||!e)return e;var r=e[Symbol.toPrimitive];if(void 0!==r){var o=r.call(e,t||"default");if("object"!=(0,n.A)(o))return o;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}},9922:(e,t,r)=>{"use strict";r.d(t,{A:()=>a});var n=r(2284),o=r(2327);function a(e){var t=(0,o.A)(e,"string");return"symbol"==(0,n.A)(t)?t:t+""}},2284:(e,t,r)=>{"use strict";function n(e){return n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(e)}r.d(t,{A:()=>n})}},t={};function r(n){var o=t[n];if(void 0!==o)return o.exports;var a=t[n]={exports:{}};return e[n](a,a.exports,r),a.exports}function n(){var e,t,r="function"==typeof Symbol?Symbol:{},a=r.iterator||"@@iterator",i=r.toStringTag||"@@toStringTag";function s(r,n,a,i){var s=n&&n.prototype instanceof c?n:c,u=Object.create(s.prototype);return o(u,"_invoke",function(r,n,o){var a,i,s,c=0,u=o||[],d=!1,f={p:0,n:0,v:e,a:p,f:p.bind(e,4),d:function(t,r){return a=t,i=0,s=e,f.n=r,l}};function p(r,n){for(i=r,s=n,t=0;!d&&c&&!o&&t3?(o=m===n)&&(s=a[(i=a[4])?5:(i=3,3)],a[4]=a[5]=e):a[0]<=p&&((o=r<2&&pn||n>m)&&(a[4]=r,a[5]=n,f.n=m,i=0))}if(o||r>1)return l;throw d=!0,n}return function(o,u,m){if(c>1)throw TypeError("Generator is already running");for(d&&1===u&&p(u,m),i=u,s=m;(t=i<2?e:s)||!d;){a||(i?i<3?(i>1&&(f.n=-1),p(i,s)):f.n=s:f.v=s);try{if(c=2,a){if(i||(o="next"),t=a[o]){if(!(t=t.call(a,s)))throw TypeError("iterator result is not an object");if(!t.done)return t;s=t.value,i<2&&(i=0)}else 1===i&&(t=a.return)&&t.call(a),i<2&&(s=TypeError("The iterator does not provide a '"+o+"' method"),i=1);a=e}else if((t=(d=f.n<0)?s:r.call(n,f))!==l)break}catch(t){a=e,i=1,s=t}finally{c=1}}return{value:t,done:d}}}(r,a,i),!0),u}var l={};function c(){}function u(){}function d(){}t=Object.getPrototypeOf;var f=[][a]?t(t([][a]())):(o(t={},a,function(){return this}),t),p=d.prototype=c.prototype=Object.create(f);function m(e){return Object.setPrototypeOf?Object.setPrototypeOf(e,d):(e.__proto__=d,o(e,i,"GeneratorFunction")),e.prototype=Object.create(p),e}return u.prototype=d,o(p,"constructor",d),o(d,"constructor",u),u.displayName="GeneratorFunction",o(d,i,"GeneratorFunction"),o(p),o(p,i,"Generator"),o(p,a,function(){return this}),o(p,"toString",function(){return"[object Generator]"}),(n=function(){return{w:s,m}})()}function o(e,t,r,n){var a=Object.defineProperty;try{a({},"",{})}catch(e){a=0}o=function(e,t,r,n){function i(t,r){o(e,t,function(e){return this._invoke(t,r,e)})}t?a?a(e,t,{value:r,enumerable:!n,configurable:!n,writable:!n}):e[t]=r:(i("next",0),i("throw",1),i("return",2))},o(e,t,r,n)}function a(e,t,r,n,o,a,i){try{var s=e[a](i),l=s.value}catch(e){return void r(e)}s.done?t(l):Promise.resolve(l).then(n,o)}r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},function(){var e=r(1105).toggleAddonState;function t(){jQuery(document).on("click","#frm_upgrade_modal .frm-install-addon",function(t){t.preventDefault(),e(this,"frm_install_addon")}),jQuery(document).on("click","#frm_upgrade_modal .frm-activate-addon",function(t){t.preventDefault(),e(this,"frm_activate_addon")}),function(){o.apply(this,arguments)}(),i(),jQuery(document).on("mouseenter.frm",".frm_help",function(){jQuery(this).off("mouseenter.frm"),jQuery(this).tooltip("show")})}function o(){var e;return e=n().m(function e(){return n().w(function(e){for(;;)switch(e.n){case 0:return e.n=1,Promise.resolve().then(r.bind(r,4260));case 1:e.v.initUpgradeModal();case 2:return e.a(2)}},e)}),o=function(){var t=this,r=arguments;return new Promise(function(n,o){var i=e.apply(t,r);function s(e){a(i,n,o,s,l,"next",e)}function l(e){a(i,n,o,s,l,"throw",e)}s(void 0)})},o.apply(this,arguments)}function i(){var e=window.frmDom;e.bootstrap.setupBootstrapDropdowns(function(){var e=document.querySelector("#frm_testmode_enabled_form_actions .dropdown-toggle");e&&(e.classList.add("frm-dropdown-toggle"),e.hasAttribute("role")||e.setAttribute("role","button"),e.hasAttribute("tabindex")||e.setAttribute("tabindex",0))});var t=document.getElementById("frm_testmode_enabled_form_actions");t&&(t.style.display="none",e.bootstrap.multiselect.init.bind(t)(),t.disabled&&t.parentElement.querySelector(".dropdown-toggle").classList.add("frm_noallow"))}"complete"===document.readyState?t():document.addEventListener("DOMContentLoaded",t),document.addEventListener("frm_after_start_over",function(){i()}),jQuery(document).on("frmPageChanged frmFormComplete",function(){i()})}()})(); \ No newline at end of file diff --git a/js/onboarding-wizard.js b/js/onboarding-wizard.js index dff5ef18bc..d114a1e6d6 100644 --- a/js/onboarding-wizard.js +++ b/js/onboarding-wizard.js @@ -1,1899 +1,2 @@ -/******/ (() => { // webpackBootstrap -/******/ "use strict"; -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": -/*!*****************************************************************!*\ - !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ domReady) -/* harmony export */ }); -/** - * @typedef {() => void} Callback - * - * TODO: Remove this typedef and inline `() => void` type. - * - * This typedef is used so that a descriptive type is provided in our - * automatically generated documentation. - * - * An in-line type `() => void` would be preferable, but the generated - * documentation is `null` in that case. - * - * @see https://github.com/WordPress/gutenberg/issues/18045 - */ - -/** - * Specify a function to execute when the DOM is fully loaded. - * - * @param {Callback} callback A function to execute after the DOM is ready. - * - * @example - * ```js - * import domReady from '@wordpress/dom-ready'; - * - * domReady( function() { - * //do something after DOM loads. - * } ); - * ``` - * - * @return {void} - */ -function domReady(callback) { - if (typeof document === 'undefined') { - return; - } - - if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. - document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. - ) { - return void callback(); - } // DOMContentLoaded has not fired yet, delay callback until then. - - - document.addEventListener('DOMContentLoaded', callback); -} -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/events/index.js": -/*!*************************************!*\ - !*** ./js/src/core/events/index.js ***! - \*************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addOptionBoxEvents: () => (/* reexport safe */ _optionBoxListener__WEBPACK_IMPORTED_MODULE_0__.addOptionBoxEvents) -/* harmony export */ }); -/* harmony import */ var _optionBoxListener__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./optionBoxListener */ "./js/src/core/events/optionBoxListener.js"); - - -/***/ }), - -/***/ "./js/src/core/events/optionBoxListener.js": -/*!*************************************************!*\ - !*** ./js/src/core/events/optionBoxListener.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addOptionBoxEvents: () => (/* binding */ addOptionBoxEvents) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - -var OPTION_BOX_CLASS = '.frm-option-box'; - -/** - * Manages event handling for an option-box. - * - * @return {void} - */ -function addOptionBoxEvents() { - var optionBoxes = document.querySelectorAll(OPTION_BOX_CLASS); - optionBoxes.forEach(function (optionBox) { - optionBox.addEventListener('click', onOptionBoxClick); - }); -} - -/** - * Handles the click event on a option box item. - * - * @private - * @param {Event} event The click event object. - */ -function onOptionBoxClick(event) { - if (event.target.tagName.toLowerCase() !== 'input') { - return; - } - var optionBox = event.currentTarget.closest(OPTION_BOX_CLASS); - optionBox.classList.toggle(core_constants__WEBPACK_IMPORTED_MODULE_0__.CHECKED_CLASS); -} - -/***/ }), - -/***/ "./js/src/core/factory/createPageElements.js": -/*!***************************************************!*\ - !*** ./js/src/core/factory/createPageElements.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* binding */ createPageElements) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page elements manager. - * - * @param {Object} [initialElements={}] An object containing initial DOM elements. - * @throws {Error} Throws an error if the `initialElements` is not an object. - * @return {Object} An object with methods to get and add elements. - */ -function createPageElements() { - var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialElements) !== 'object' || initialElements === null) { - throw new Error('createPageElements: initialElements must be a non-null object'); - } - var elements = initialElements; - - /** - * Retrieve the initialized essential DOM elements. - * - * @return {Object} The initialized elements object. - */ - function getElements() { - return elements; - } - - /** - * Add new elements to the elements object. - * - * @param {Object} newElements An object containing new elements to be added. - * @throws {Error} Throws an error if the `newElements` is not a non-null object. - * @return {void} Updates the elements object by merging the new elements into it. - */ - function addElements(newElements) { - if (_typeof(newElements) !== 'object' || newElements === null) { - throw new Error('addElements: newElements must be a non-null object'); - } - elements = _objectSpread(_objectSpread({}, elements), newElements); - } - return { - getElements: getElements, - addElements: addElements - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/createPageState.js": -/*!************************************************!*\ - !*** ./js/src/core/factory/createPageState.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageState: () => (/* binding */ createPageState) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page state manager. - * - * @param {Object} [initialState={}] An object containing the initial state. - * @throws {Error} Throws an error if the `initialState` is not a plain object. - * @return {Object} An object with methods to initialize, get, and set the page state. - */ -function createPageState() { - var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialState) !== 'object' || initialState === null) { - throw new Error('createPageState: initialState must be a non-null object'); - } - var state = initialState; - - /** - * Returns the current page state. - * - * @return {Object|null} The current state of the page or null if not initialized. - */ - var getState = function getState() { - return state; - }; - - /** - * Returns a specific property from the current page state. - * - * @param {string} propertyName The name of the property to retrieve. - * @return {*} The value of the specified property, or null if it doesn't exist. - */ - var getSingleState = function getSingleState(propertyName) { - var value = Reflect.get(state, propertyName); - - // We convert `undefined` to `null` for a consistent API. - // This makes it easier for users to handle the results since all missing properties return `null`. - return value === undefined ? null : value; - }; - - /** - * Updates the page state with new values. - * - * @param {Object} newState The new values to update the state with. - * @throws {Error} Throws an error if `newState` is not a plain object. - * @return {void} - */ - var setState = function setState(newState) { - if (_typeof(newState) !== 'object' || newState === null) { - throw new Error('setState: newState must be a non-null object'); - } - state = _objectSpread(_objectSpread({}, state), newState); - }; - - /** - * Updates a specific property in the page state with a new value. - * - * @param {string} propertyName The name of the property to update. - * @param {*} value The new value to set for the property. - * @return {void} - */ - var setSingleState = function setSingleState(propertyName, value) { - if (Reflect.has(state, propertyName)) { - Reflect.set(state, propertyName, value); - } - }; - return { - getState: getState, - getSingleState: getSingleState, - setState: setState, - setSingleState: setSingleState - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/index.js": -/*!**************************************!*\ - !*** ./js/src/core/factory/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), -/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) -/* harmony export */ }); -/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); -/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); - - - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }), - -/***/ "./js/src/onboarding-wizard/dataUtils/index.js": -/*!*****************************************************!*\ - !*** ./js/src/onboarding-wizard/dataUtils/index.js ***! - \*****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ setupUsageData: () => (/* reexport safe */ _setupUsageData__WEBPACK_IMPORTED_MODULE_0__["default"]) -/* harmony export */ }); -/* harmony import */ var _setupUsageData__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupUsageData */ "./js/src/onboarding-wizard/dataUtils/setupUsageData.js"); - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/dataUtils/setupUsageData.js": -/*!**************************************************************!*\ - !*** ./js/src/onboarding-wizard/dataUtils/setupUsageData.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); -/** - * Internal Dependencies - */ - - -/** - * Processes and submits usage data for the specified onboarding step. - * - * @param {string} processedStep The name of the step that has just been processed. - * @param {string} nextStepName The name of the next step in the onboarding process. - * @return {void} - */ -function setupUsageData(processedStep, nextStepName) { - var formData = processDataForStep(processedStep, nextStepName); - if (!formData) { - return; - } - - // Send the POST request - var doJsonPost = frmDom.ajax.doJsonPost; - doJsonPost('onboarding_setup_usage_data', formData); -} - -/** - * Processes onboarding step data and returns the corresponding FormData. - * - * @private - * @param {string} processedStep The name of the step that has just been processed. - * @param {string} nextStepName The name of the next step in the onboarding process. - * @return {FormData|null} The FormData to be submitted for the step, or null if there's no data. - */ -function processDataForStep(processedStep, nextStepName) { - var formData; - - // Append completed steps if moving to the success step - if (_shared__WEBPACK_IMPORTED_MODULE_0__.STEPS.SUCCESS === nextStepName || _shared__WEBPACK_IMPORTED_MODULE_0__.STEPS.UNSUCCESSFUL === nextStepName) { - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_0__.getState)(), - processedSteps = _getState.processedSteps; - if (processedSteps.length > 1) { - if (!processedSteps.includes(nextStepName)) { - processedSteps.push(nextStepName); - } - formData = new FormData(); - formData.append('processed_steps', processedSteps.join(',')); - formData.append('completed_steps', true); - } - } - - // Append installed addons for the addon installation step - if (_shared__WEBPACK_IMPORTED_MODULE_0__.STEPS.INSTALL_ADDONS === processedStep) { - var _getState2 = (0,_shared__WEBPACK_IMPORTED_MODULE_0__.getState)(), - installedAddons = _getState2.installedAddons; - if (installedAddons.length > 0) { - formData = formData !== null && formData !== void 0 ? formData : new FormData(); - formData.append('installed_addons', installedAddons.join(',')); - } - } - return formData; -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (setupUsageData); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/elements/elements.js": -/*!*******************************************************!*\ - !*** ./js/src/onboarding-wizard/elements/elements.js ***! - \*******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* binding */ addElements), -/* harmony export */ getElements: () => (/* binding */ getElements) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - -var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)({ - onboardingWizardPage: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-wizard-page")), - container: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-container")), - rootline: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-rootline")), - steps: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-step")), - skipStepButtons: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-skip-step")), - backButtons: document.querySelectorAll(".".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-back-button")), - consentTrackingButton: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-consent-tracking")), - installAddonsButton: document.getElementById("".concat(_shared__WEBPACK_IMPORTED_MODULE_1__.PREFIX, "-install-addons-button")), - hiddenLicenseKeyInput: document.getElementById('frm-license-key') - }), - getElements = _createPageElements.getElements, - addElements = _createPageElements.addElements; - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/elements/index.js": -/*!****************************************************!*\ - !*** ./js/src/onboarding-wizard/elements/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/onboarding-wizard/elements/elements.js"); - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/events/backButtonListener.js": -/*!***************************************************************!*\ - !*** ./js/src/onboarding-wizard/events/backButtonListener.js ***! - \***************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - -/** - * Manages event handling for the "Back" button. - * - * @return {void} - */ -function addBackButtonEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - backButtons = _getElements.backButtons; - - // Attach click event listeners to each back buttons - backButtons.forEach(function (backButton) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(backButton, onBackButtonClick); - }); -} - -/** - * Handles the click event on a "Back" button. - * - * @private - * @return {void} - */ -var onBackButtonClick = function onBackButtonClick() { - (0,_utils__WEBPACK_IMPORTED_MODULE_2__.navigateToPrevStep)(); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addBackButtonEvents); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/events/consentTrackingButtonListener.js": -/*!**************************************************************************!*\ - !*** ./js/src/onboarding-wizard/events/consentTrackingButtonListener.js ***! - \**************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - -/** - * Manages event handling for the "Allow & Continue" button in the "Never miss an important update" step. - * - * @return {void} - */ -function addConsentTrackingButtonEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - consentTrackingButton = _getElements.consentTrackingButton; - - // Attach click event listener - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(consentTrackingButton, onConsentTrackingButtonClick); -} - -/** - * Handles the click event on the "Allow & Continue" button in the "Never miss an important update" step. - * - * @private - * @return {void} - */ -var onConsentTrackingButtonClick = /*#__PURE__*/function () { - var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { - var doJsonPost; - return _regenerator().w(function (_context) { - while (1) switch (_context.n) { - case 0: - doJsonPost = frmDom.ajax.doJsonPost; - doJsonPost('onboarding_consent_tracking', new FormData()).then(_utils__WEBPACK_IMPORTED_MODULE_2__.navigateToNextStep); - case 1: - return _context.a(2); - } - }, _callee); - })); - return function onConsentTrackingButtonClick() { - return _ref.apply(this, arguments); - }; -}(); -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addConsentTrackingButtonEvents); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/events/index.js": -/*!**************************************************!*\ - !*** ./js/src/onboarding-wizard/events/index.js ***! - \**************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) -/* harmony export */ }); -/* harmony import */ var core_events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/events */ "./js/src/core/events/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _skipStepButtonListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./skipStepButtonListener */ "./js/src/onboarding-wizard/events/skipStepButtonListener.js"); -/* harmony import */ var _backButtonListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./backButtonListener */ "./js/src/onboarding-wizard/events/backButtonListener.js"); -/* harmony import */ var _consentTrackingButtonListener__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./consentTrackingButtonListener */ "./js/src/onboarding-wizard/events/consentTrackingButtonListener.js"); -/* harmony import */ var _installAddonsButtonListener__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./installAddonsButtonListener */ "./js/src/onboarding-wizard/events/installAddonsButtonListener.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - - - -/** - * Attaches event listeners for handling user interactions. - * - * @return {void} - */ -function addEventListeners() { - // Add event handling for the "Skip" and "Back" buttons - (0,_skipStepButtonListener__WEBPACK_IMPORTED_MODULE_2__["default"])(); - (0,_backButtonListener__WEBPACK_IMPORTED_MODULE_3__["default"])(); - (0,_consentTrackingButtonListener__WEBPACK_IMPORTED_MODULE_4__["default"])(); - - // Add event handling for the "Install & Finish Setup" button in the "Install Formidable Add-ons" step - (0,_installAddonsButtonListener__WEBPACK_IMPORTED_MODULE_5__["default"])(); - // Add event handling for an option-box - (0,core_events__WEBPACK_IMPORTED_MODULE_0__.addOptionBoxEvents)(); -} - -/** - * Responds to browser navigation events (back/forward) by updating the UI to match the step indicated in the URL or history state. - * - * @param {PopStateEvent} event The event object associated with the navigation action. - * @return {void} - */ -window.addEventListener('popstate', function (event) { - var _event$state; - var stepName = ((_event$state = event.state) === null || _event$state === void 0 ? void 0 : _event$state.step) || (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.getQueryParam)('step'); - // Navigate to the specified step without adding to browser history - (0,_utils__WEBPACK_IMPORTED_MODULE_6__.navigateToStep)(stepName, 'replaceState'); -}); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/events/installAddonsButtonListener.js": -/*!************************************************************************!*\ - !*** ./js/src/onboarding-wizard/events/installAddonsButtonListener.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _regeneratorValues(e) { if (null != e) { var t = e["function" == typeof Symbol && Symbol.iterator || "@@iterator"], r = 0; if (t) return t.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) return { next: function next() { return e && r >= e.length && (e = void 0), { value: e && e[r++], done: !e }; } }; } throw new TypeError(_typeof(e) + " is not iterable"); } -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t.return || t.return(); } finally { if (u) throw o; } } }; } -function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } -function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - -/** - * Manages event handling for the "Install & Finish Setup" button in the "Install Formidable Add-ons" step. - * - * @return {void} - */ -function addInstallAddonsButtonEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)(), - installAddonsButton = _getElements.installAddonsButton; - - // Attach click event listener - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.onClickPreventDefault)(installAddonsButton, onInstallAddonsButtonClick); -} - -/** - * Handles the click event on the "Install & Finish Setup" button in the "Install Formidable Add-ons" step. - * - * @private - * @param {Event} event The click event object. - * @return {void} - */ -var onInstallAddonsButtonClick = /*#__PURE__*/function () { - var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(event) { - var addons, _getState, installedAddons, installAddonsButton, _iterator, _step, _loop, _t2; - return _regenerator().w(function (_context2) { - while (1) switch (_context2.p = _context2.n) { - case 0: - addons = document.querySelectorAll('.frm-option-box.frm-checked:not(.frm-disabled)'); - _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_3__.getState)(), installedAddons = _getState.installedAddons; - installAddonsButton = event.currentTarget; - installAddonsButton.classList.add('frm_loading_button'); - _iterator = _createForOfIteratorHelper(addons); - _context2.p = 1; - _loop = /*#__PURE__*/_regenerator().m(function _loop() { - var addon, addonTitle, _t; - return _regenerator().w(function (_context) { - while (1) switch (_context.p = _context.n) { - case 0: - addon = _step.value; - _context.p = 1; - _context.n = 2; - return (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue)(function () { - return installAddon(addon.getAttribute('rel'), addon.dataset); - }); - case 2: - // Capture addon title - addonTitle = addon.dataset.title; - if (!installedAddons.includes(addonTitle)) { - installedAddons.push(addonTitle); - } - _context.n = 4; - break; - case 3: - _context.p = 3; - _t = _context.v; - console.error('An error occurred:', _t); - case 4: - return _context.a(2); - } - }, _loop, null, [[1, 3]]); - }); - _iterator.s(); - case 2: - if ((_step = _iterator.n()).done) { - _context2.n = 4; - break; - } - return _context2.d(_regeneratorValues(_loop()), 3); - case 3: - _context2.n = 2; - break; - case 4: - _context2.n = 6; - break; - case 5: - _context2.p = 5; - _t2 = _context2.v; - _iterator.e(_t2); - case 6: - _context2.p = 6; - _iterator.f(); - return _context2.f(6); - case 7: - installAddonsButton.classList.remove('frm_loading_button'); - (0,_shared__WEBPACK_IMPORTED_MODULE_3__.setSingleState)('installedAddons', installedAddons); - (0,_utils__WEBPACK_IMPORTED_MODULE_4__.navigateToNextStep)(); - case 8: - return _context2.a(2); - } - }, _callee, null, [[1, 5, 6, 7]]); - })); - return function onInstallAddonsButtonClick(_x) { - return _ref.apply(this, arguments); - }; -}(); - -/** - * Installs an add-on or plugin based on the provided plugin name and vendor status. - * - * @private - * @param {string} plugin The unique identifier or name of the plugin or add-on to be installed. - * @param {Object} options An object containing additional options for the installation. - * @param {boolean} options.isInstalled Indicates whether the plugin is already installed. - * @param {boolean} options.isVendor Indicates whether the plugin is a vendor plugin (true) or a regular add-on (false). - * @return {Promise} A promise that resolves with the JSON response from the server after the installation request is completed. - */ -function installAddon(_x2, _x3) { - return _installAddon.apply(this, arguments); -} -function _installAddon() { - _installAddon = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2(plugin, _ref2) { - var isVendor, isInstalled, formData, addonAction, response, _t3; - return _regenerator().w(function (_context3) { - while (1) switch (_context3.p = _context3.n) { - case 0: - isVendor = _ref2.isVendor, isInstalled = _ref2.isInstalled; - // Prepare FormData for the POST request - formData = new FormData(); - formData.append('nonce', core_constants__WEBPACK_IMPORTED_MODULE_0__.nonce); - formData.append('plugin', plugin); - addonAction = isInstalled ? 'frm_activate_addon' : 'frm_install_addon'; - formData.append('action', isVendor ? 'frm_install_plugin' : addonAction); - _context3.p = 1; - _context3.n = 2; - return fetch(ajaxurl, { - method: 'POST', - body: formData - }); - case 2: - response = _context3.v; - if (response.ok) { - _context3.n = 3; - break; - } - throw new Error("Server responded with status ".concat(response.status)); - case 3: - _context3.n = 4; - return response.json(); - case 4: - return _context3.a(2, _context3.v); - case 5: - _context3.p = 5; - _t3 = _context3.v; - console.error('An error occurred:', _t3); - case 6: - return _context3.a(2); - } - }, _callee2, null, [[1, 5]]); - })); - return _installAddon.apply(this, arguments); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addInstallAddonsButtonEvents); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/events/skipStepButtonListener.js": -/*!*******************************************************************!*\ - !*** ./js/src/onboarding-wizard/events/skipStepButtonListener.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - -/** - * Manages event handling for the "Skip" step button. - * - * @return {void} - */ -function addSkipStepButtonEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - skipStepButtons = _getElements.skipStepButtons; - - // Attach click event listeners to each skip buttons - skipStepButtons.forEach(function (skipButton) { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(skipButton, onSkipStepButtonClick); - }); -} - -/** - * Handles the click event on a "Skip" step button. - * - * @private - * @return {void} - */ -var onSkipStepButtonClick = function onSkipStepButtonClick() { - (0,_utils__WEBPACK_IMPORTED_MODULE_2__.navigateToNextStep)(); -}; -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addSkipStepButtonEvents); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/initializeOnboardingWizard.js": -/*!****************************************************************!*\ - !*** ./js/src/onboarding-wizard/initializeOnboardingWizard.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/onboarding-wizard/ui/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./js/src/onboarding-wizard/events/index.js"); -/** - * Internal dependencies - */ - - - -/** - * Initializes Onboarding Wizard. - * - * @return {void} - */ -function initializeOnboardingWizard() { - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.setupInitialView)(); - (0,_events__WEBPACK_IMPORTED_MODULE_1__.addEventListeners)(); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeOnboardingWizard); - -/***/ }), - -/***/ "./js/src/onboarding-wizard/shared/constants.js": -/*!******************************************************!*\ - !*** ./js/src/onboarding-wizard/shared/constants.js ***! - \******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ INITIAL_STEP: () => (/* binding */ INITIAL_STEP), -/* harmony export */ PREFIX: () => (/* binding */ PREFIX), -/* harmony export */ STEPS: () => (/* binding */ STEPS) -/* harmony export */ }); -var INITIAL_STEP = window.frmOnboardingWizardVars.INITIAL_STEP; - -var PREFIX = 'frm-onboarding'; -var STEPS = { - INITIAL: INITIAL_STEP, - INSTALL_ADDONS: 'install-addons', - SUCCESS: 'success', - UNSUCCESSFUL: 'unsuccessful' -}; - -/***/ }), - -/***/ "./js/src/onboarding-wizard/shared/index.js": -/*!**************************************************!*\ - !*** ./js/src/onboarding-wizard/shared/index.js ***! - \**************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ INITIAL_STEP: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.INITIAL_STEP), -/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), -/* harmony export */ STEPS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.STEPS), -/* harmony export */ getSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getSingleState), -/* harmony export */ getState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.getState), -/* harmony export */ setSingleState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setSingleState), -/* harmony export */ setState: () => (/* reexport safe */ _pageState__WEBPACK_IMPORTED_MODULE_1__.setState) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/onboarding-wizard/shared/constants.js"); -/* harmony import */ var _pageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./pageState */ "./js/src/onboarding-wizard/shared/pageState.js"); - - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/shared/pageState.js": -/*!******************************************************!*\ - !*** ./js/src/onboarding-wizard/shared/pageState.js ***! - \******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getSingleState: () => (/* binding */ getSingleState), -/* harmony export */ getState: () => (/* binding */ getState), -/* harmony export */ setSingleState: () => (/* binding */ setSingleState), -/* harmony export */ setState: () => (/* binding */ setState) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/** - * External dependencies - */ - -var _createPageState = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageState)({ - processedSteps: [], - installedAddons: [] - }), - getState = _createPageState.getState, - getSingleState = _createPageState.getSingleState, - setState = _createPageState.setState, - setSingleState = _createPageState.setSingleState; - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/ui/index.js": -/*!**********************************************!*\ - !*** ./js/src/onboarding-wizard/ui/index.js ***! - \**********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ setupInitialView: () => (/* reexport safe */ _setupInitialView__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ updateRootline: () => (/* reexport safe */ _rootline__WEBPACK_IMPORTED_MODULE_1__.updateRootline) -/* harmony export */ }); -/* harmony import */ var _setupInitialView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./setupInitialView */ "./js/src/onboarding-wizard/ui/setupInitialView.js"); -/* harmony import */ var _rootline__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./rootline */ "./js/src/onboarding-wizard/ui/rootline.js"); - - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/ui/rootline.js": -/*!*************************************************!*\ - !*** ./js/src/onboarding-wizard/ui/rootline.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ updateRootline: () => (/* binding */ updateRootline) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - -var COMPLETED_STEP_CLASS = 'frm-completed-step'; - -/** - * Updates the rootline to reflect the current and completed steps. - * - * - Applies COMPLETED_STEP_CLASS to steps before the current one. - * - Applies CURRENT_CLASS to the current step, unless it is the success step. - * - * @param {string} currentStep The current step in the process. - * @return {void} - */ -function updateRootline(currentStep) { - if (currentStep === _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.UNSUCCESSFUL) { - currentStep = _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.SUCCESS; - } - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - rootline = _getElements.rootline; - var currentItem = rootline.querySelector(".frm-rootline-item[data-step=\"".concat(currentStep, "\"]")); - rootline.querySelectorAll('.frm-rootline-item').forEach(function (item) { - item.classList.remove(COMPLETED_STEP_CLASS); - item.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - }); - var prevItem = currentItem.previousElementSibling; - if (prevItem) { - while (prevItem) { - prevItem.classList.add(COMPLETED_STEP_CLASS); - prevItem = prevItem.previousElementSibling; // move to the previous sibling - } - } - if (currentStep === _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.SUCCESS) { - currentItem.classList.add(COMPLETED_STEP_CLASS); - } else { - currentItem.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - } -} - -/***/ }), - -/***/ "./js/src/onboarding-wizard/ui/setupInitialView.js": -/*!*********************************************************!*\ - !*** ./js/src/onboarding-wizard/ui/setupInitialView.js ***! - \*********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ setupInitialView) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils */ "./js/src/onboarding-wizard/utils/index.js"); -/** - * External dependencies - */ - - -/** - * Internal dependencies - */ - - - - -/** - * Initializes the onboarding wizard's UI, sets up the initial step based on certain conditions, - * and applies necessary UI enhancements for a smoother user experience. - * - * @return {void} - */ -function setupInitialView() { - navigateToInitialStep(); - fadeInPageElements(); -} - -/** - * Determines the initial step in the onboarding process and navigates to it, considering the installation - * status of Formidable Pro and specific query parameters. - * - * @private - * @return {void} - */ -function navigateToInitialStep() { - var initialStepName = determineInitialStep(); - clearOnboardingQueryParams(); - (0,_utils__WEBPACK_IMPORTED_MODULE_3__.navigateToStep)(initialStepName, 'replaceState'); -} - -/** - * Determines the initial step based on the current state, such as whether Formidable Pro is installed - * and the presence of specific query parameters. Also handles the removal of unnecessary steps. - * - * @private - * @return {string} The name of the initial step to navigate to. - */ -function determineInitialStep() { - var isConnectedAccount = (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('success'); - if (isConnectedAccount === '0') { - return _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.UNSUCCESSFUL; - } - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - hiddenLicenseKeyInput = _getElements.hiddenLicenseKeyInput; - if (hiddenLicenseKeyInput || isConnectedAccount) { - return _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.INSTALL_ADDONS; - } - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('step') || _shared__WEBPACK_IMPORTED_MODULE_2__.STEPS.INITIAL; -} - -/** - * Clears specific query parameters related to the onboarding process. - * - * @private - * @return {void} - */ -function clearOnboardingQueryParams() { - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.removeQueryParam)('key'); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.removeQueryParam)('success'); -} - -/** - * Smoothly fades in the background and container elements of the page for a more pleasant user experience. - * - * @private - * @return {void} - */ -function fadeInPageElements() { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - container = _getElements2.container; - new core_utils__WEBPACK_IMPORTED_MODULE_0__.frmAnimate(container).fadeIn(); -} - -/***/ }), - -/***/ "./js/src/onboarding-wizard/utils/index.js": -/*!*************************************************!*\ - !*** ./js/src/onboarding-wizard/utils/index.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ navigateToNextStep: () => (/* reexport safe */ _navigateToStep__WEBPACK_IMPORTED_MODULE_0__.navigateToNextStep), -/* harmony export */ navigateToPrevStep: () => (/* reexport safe */ _navigateToStep__WEBPACK_IMPORTED_MODULE_0__.navigateToPrevStep), -/* harmony export */ navigateToStep: () => (/* reexport safe */ _navigateToStep__WEBPACK_IMPORTED_MODULE_0__.navigateToStep) -/* harmony export */ }); -/* harmony import */ var _navigateToStep__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./navigateToStep */ "./js/src/onboarding-wizard/utils/navigateToStep.js"); - - -/***/ }), - -/***/ "./js/src/onboarding-wizard/utils/navigateToStep.js": -/*!**********************************************************!*\ - !*** ./js/src/onboarding-wizard/utils/navigateToStep.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ navigateToNextStep: () => (/* binding */ navigateToNextStep), -/* harmony export */ navigateToPrevStep: () => (/* binding */ navigateToPrevStep), -/* harmony export */ navigateToStep: () => (/* binding */ navigateToStep) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _dataUtils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../dataUtils */ "./js/src/onboarding-wizard/dataUtils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../elements */ "./js/src/onboarding-wizard/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../shared */ "./js/src/onboarding-wizard/shared/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../ui */ "./js/src/onboarding-wizard/ui/index.js"); -/** - * External dependencies - */ - - - -/** - * Internal dependencies - */ - - - - - -/** - * Navigates to the given step in the onboarding sequence. - * Optionally updates the browser's history state to include the current step. - * - * @param {string} stepName The name of the step to navigate to. - * @param {string} [updateMethod='pushState'] Specifies the method to update the browser's history and URL. Accepts 'pushState' or 'replaceState'. If omitted, defaults to 'pushState'. - * @return {void} - */ -var navigateToStep = function navigateToStep(stepName) { - var updateMethod = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'pushState'; - // Find the target step element - var targetStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step[data-step-name=\"").concat(stepName, "\"]")); - if (!targetStep) { - return; - } - - // Find and hide the current step element - var currentStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step.").concat(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS)); - if (currentStep) { - currentStep.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.hide)(currentStep); - } - - // Display the target step element - targetStep.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS); - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.show)(targetStep); - new core_utils__WEBPACK_IMPORTED_MODULE_1__.frmAnimate(targetStep).fadeIn(); - - // Update the onboarding wizard's current step attribute - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_3__.getElements)(), - onboardingWizardPage = _getElements.onboardingWizardPage; - onboardingWizardPage.setAttribute('data-current-step', stepName); - - // Update the URL query parameter, with control over history update method - (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.setQueryParam)('step', stepName, updateMethod); - (0,_ui__WEBPACK_IMPORTED_MODULE_5__.updateRootline)(stepName); -}; - -/** - * Navigates to the next step in the sequence. - * - * The function assumes steps are sequentially ordered in the DOM. - * - * @return {void} - */ -var navigateToNextStep = function navigateToNextStep() { - var currentStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step.").concat(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS)); - var nextStep = currentStep === null || currentStep === void 0 ? void 0 : currentStep.nextElementSibling; - if (!nextStep) { - return; - } - var processedStep = currentStep.dataset.stepName; - var nextStepName = nextStep.dataset.stepName; - - // Save processed steps - var _getState = (0,_shared__WEBPACK_IMPORTED_MODULE_4__.getState)(), - processedSteps = _getState.processedSteps; - if (!processedSteps.includes(processedStep)) { - processedSteps.push(processedStep); - (0,_shared__WEBPACK_IMPORTED_MODULE_4__.setSingleState)('processedSteps', processedSteps); - } - (0,_dataUtils__WEBPACK_IMPORTED_MODULE_2__.setupUsageData)(processedStep, nextStepName); - navigateToStep(nextStepName); -}; - -/** - * Navigates to the previous step in the sequence. - * - * The function assumes steps are sequentially ordered in the DOM. - * - * @return {void} - */ -var navigateToPrevStep = function navigateToPrevStep() { - var currentStep = document.querySelector(".".concat(_shared__WEBPACK_IMPORTED_MODULE_4__.PREFIX, "-step.").concat(core_constants__WEBPACK_IMPORTED_MODULE_0__.CURRENT_CLASS)); - var prevStep = currentStep === null || currentStep === void 0 ? void 0 : currentStep.previousElementSibling; - if (!prevStep) { - return; - } - navigateToStep(prevStep.dataset.stepName); -}; - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be isolated against other modules in the chunk. -(() => { -/*!*******************************************!*\ - !*** ./js/src/onboarding-wizard/index.js ***! - \*******************************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); -/* harmony import */ var _initializeOnboardingWizard__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./initializeOnboardingWizard */ "./js/src/onboarding-wizard/initializeOnboardingWizard.js"); -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - -(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_1__["default"])(function () { - (0,_initializeOnboardingWizard__WEBPACK_IMPORTED_MODULE_0__["default"])(); -}); -})(); - -/******/ })() -; -//# sourceMappingURL=onboarding-wizard.js.map \ No newline at end of file +/*! For license information please see onboarding-wizard.js.LICENSE.txt */ +(()=>{"use strict";function t(e){return t="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},t(e)}function e(t,e){for(var r=0;r1&&void 0!==arguments[1]?arguments[1]:"default";!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,t),this.elements=e,this.type=n,this.prepareElements()},n=[{key:"fadeIn",value:function(){var t=this;this.applyStyleToElements(function(e){e.classList.add("frm-fadein-up"),e.addEventListener("animationend",function(){t.resetOpacity(),e.classList.remove("frm-fadein-up")},{once:!0})})}},{key:"cascadeFadeIn",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:.03;setTimeout(function(){t.applyStyleToElements(function(t,n){t.classList.remove("frm-animate"),t.style.transitionDelay="".concat((n+1)*e,"s")})},200)}},{key:"prepareElements",value:function(){var t=this;this.applyStyleToElements(function(e){"default"===t.type&&(e.style.opacity="0.0"),"cascade"===t.type&&e.classList.add("frm-init-cascade-animation"),"cascade-3d"===t.type&&e.classList.add("frm-init-fadein-3d"),e.classList.add("frm-animate")})}},{key:"resetOpacity",value:function(){this.applyStyleToElements(function(t){return t.style.opacity="1.0"})}},{key:"applyStyleToElements",value:function(t){this.elements instanceof Element?t(this.elements,0):00&&void 0!==arguments[0]?arguments[0]:{};if("object"!==_(t)||null===t)throw new Error("createPageState: initialState must be a non-null object");var e=t;return{getState:function(){return e},getSingleState:function(t){var n=Reflect.get(e,t);return void 0===n?null:n},setState:function(t){if("object"!==_(t)||null===t)throw new Error("setState: newState must be a non-null object");e=T(T({},e),t)},setSingleState:function(t,n){Reflect.has(e,t)&&Reflect.set(e,t,n)}}}({processedSteps:[],installedAddons:[]}),I=A.getState,D=(A.getSingleState,A.setState,A.setSingleState),C=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==j(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var e=t;return{getElements:function(){return e},addElements:function(t){if("object"!==j(t)||null===t)throw new Error("addElements: newElements must be a non-null object");e=g(g({},e),t)}}}({onboardingWizardPage:document.getElementById("".concat(E,"-wizard-page")),container:document.getElementById("".concat(E,"-container")),rootline:document.getElementById("".concat(E,"-rootline")),steps:document.querySelectorAll(".".concat(E,"-step")),skipStepButtons:document.querySelectorAll(".".concat(E,"-skip-step")),backButtons:document.querySelectorAll(".".concat(E,"-back-button")),consentTrackingButton:document.getElementById("".concat(E,"-consent-tracking")),installAddonsButton:document.getElementById("".concat(E,"-install-addons-button")),hiddenLicenseKeyInput:document.getElementById("frm-license-key")}),N=C.getElements;C.addElements;var U=function(t){var e,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"pushState",o=document.querySelector(".".concat(E,'-step[data-step-name="').concat(t,'"]'));if(o){var i=document.querySelector(".".concat(E,"-step.").concat(S));i&&(i.classList.remove(S),null==(e=i)||e.classList.add(b)),o.classList.add(S),function(t){null==t||t.classList.remove(b)}(o),new r(o).fadeIn(),N().onboardingWizardPage.setAttribute("data-current-step",t),function(t,e){var n,r,o,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"pushState";if(p.set(t,e),f.search=p.toString(),["pushState","replaceState"].includes(i)){var a=(n={},o=e,(r=function(t){var e=function(t){if("object"!=s(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var n=e.call(t,"string");if("object"!=s(n))return n;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==s(e)?e:e+""}(r=t))in n?Object.defineProperty(n,r,{value:o,enumerable:!0,configurable:!0,writable:!0}):n[r]=o,n);window.history[i](a,"",f)}f.toString()}("step",t,n),function(t){t===P.UNSUCCESSFUL&&(t=P.SUCCESS);var e=N().rootline,n=e.querySelector('.frm-rootline-item[data-step="'.concat(t,'"]'));e.querySelectorAll(".frm-rootline-item").forEach(function(t){t.classList.remove(B),t.classList.remove(S)});var r=n.previousElementSibling;if(r)for(;r;)r.classList.add(B),r=r.previousElementSibling;t===P.SUCCESS?n.classList.add(B):n.classList.add(S)}(t)}},x=function(){var t=document.querySelector(".".concat(E,"-step.").concat(S)),e=null==t?void 0:t.nextElementSibling;if(e){var n=t.dataset.stepName,r=e.dataset.stepName,o=I().processedSteps;o.includes(n)||(o.push(n),D("processedSteps",o)),function(t,e){var n=function(t,e){var n;if(P.SUCCESS===e||P.UNSUCCESSFUL===e){var r=I().processedSteps;r.length>1&&(r.includes(e)||r.push(e),(n=new FormData).append("processed_steps",r.join(",")),n.append("completed_steps",!0))}if(P.INSTALL_ADDONS===t){var o=I().installedAddons;o.length>0&&(n=null!=n?n:new FormData).append("installed_addons",o.join(","))}return n}(t,e);n&&(0,frmDom.ajax.doJsonPost)("onboarding_setup_usage_data",n)}(n,r),U(r)}};var B="frm-completed-step",F=".frm-option-box";function G(t){"input"===t.target.tagName.toLowerCase()&&t.currentTarget.closest(F).classList.toggle("frm-checked")}var q=function(){x()};var z=function(){var t,e;(e=null==(t=document.querySelector(".".concat(E,"-step.").concat(S)))?void 0:t.previousElementSibling)&&U(e.dataset.stepName)};function R(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function i(n,r,o,i){var u=r&&r.prototype instanceof c?r:c,l=Object.create(u.prototype);return J(l,"_invoke",function(n,r,o){var i,c,u,l=0,s=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,n){return i=e,c=0,u=t,p.n=n,a}};function d(n,r){for(c=n,u=r,e=0;!f&&l&&!o&&e3?(o=y===r)&&(u=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=n<2&&dr||r>y)&&(i[4]=n,i[5]=r,p.n=y,c=0))}if(o||n>1)return a;throw f=!0,r}return function(o,s,y){if(l>1)throw TypeError("Generator is already running");for(f&&1===s&&d(s,y),c=s,u=y;(e=c<2?t:u)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,u)):p.n=u:p.v=u);try{if(l=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,u)))throw TypeError("iterator result is not an object");if(!e.done)return e;u=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(u=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?u:n.call(r,p))!==a)break}catch(e){i=t,c=1,u=e}finally{l=1}}return{value:e,done:f}}}(n,o,i),!0),l}var a={};function c(){}function u(){}function l(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(J(e={},r,function(){return this}),e),f=l.prototype=c.prototype=Object.create(s);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,l):(t.__proto__=l,J(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return u.prototype=l,J(f,"constructor",l),J(l,"constructor",u),u.displayName="GeneratorFunction",J(l,o,"GeneratorFunction"),J(f),J(f,o,"Generator"),J(f,r,function(){return this}),J(f,"toString",function(){return"[object Generator]"}),(R=function(){return{w:i,m:p}})()}function J(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}J=function(t,e,n,r){function i(e,n){J(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(i("next",0),i("throw",1),i("return",2))},J(t,e,n,r)}function M(t,e,n,r,o,i,a){try{var c=t[i](a),u=c.value}catch(t){return void n(t)}c.done?e(u):Promise.resolve(u).then(r,o)}var W=function(){var t,e=(t=R().m(function t(){return R().w(function(t){for(;;)switch(t.n){case 0:(0,frmDom.ajax.doJsonPost)("onboarding_consent_tracking",new FormData).then(x);case 1:return t.a(2)}},t)}),function(){var e=this,n=arguments;return new Promise(function(r,o){var i=t.apply(e,n);function a(t){M(i,r,o,a,c,"next",t)}function c(t){M(i,r,o,a,c,"throw",t)}a(void 0)})});return function(){return e.apply(this,arguments)}}();function K(t){return K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},K(t)}function V(t){if(null!=t){var e=t["function"==typeof Symbol&&Symbol.iterator||"@@iterator"],n=0;if(e)return e.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length))return{next:function(){return t&&n>=t.length&&(t=void 0),{value:t&&t[n++],done:!t}}}}throw new TypeError(K(t)+" is not iterable")}function $(){var t,e,n="function"==typeof Symbol?Symbol:{},r=n.iterator||"@@iterator",o=n.toStringTag||"@@toStringTag";function i(n,r,o,i){var u=r&&r.prototype instanceof c?r:c,l=Object.create(u.prototype);return H(l,"_invoke",function(n,r,o){var i,c,u,l=0,s=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,n){return i=e,c=0,u=t,p.n=n,a}};function d(n,r){for(c=n,u=r,e=0;!f&&l&&!o&&e3?(o=y===r)&&(u=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=n<2&&dr||r>y)&&(i[4]=n,i[5]=r,p.n=y,c=0))}if(o||n>1)return a;throw f=!0,r}return function(o,s,y){if(l>1)throw TypeError("Generator is already running");for(f&&1===s&&d(s,y),c=s,u=y;(e=c<2?t:u)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,u)):p.n=u:p.v=u);try{if(l=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,u)))throw TypeError("iterator result is not an object");if(!e.done)return e;u=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(u=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?u:n.call(r,p))!==a)break}catch(e){i=t,c=1,u=e}finally{l=1}}return{value:e,done:f}}}(n,o,i),!0),l}var a={};function c(){}function u(){}function l(){}e=Object.getPrototypeOf;var s=[][r]?e(e([][r]())):(H(e={},r,function(){return this}),e),f=l.prototype=c.prototype=Object.create(s);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,l):(t.__proto__=l,H(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return u.prototype=l,H(f,"constructor",l),H(l,"constructor",u),u.displayName="GeneratorFunction",H(l,o,"GeneratorFunction"),H(f),H(f,o,"Generator"),H(f,r,function(){return this}),H(f,"toString",function(){return"[object Generator]"}),($=function(){return{w:i,m:p}})()}function H(t,e,n,r){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}H=function(t,e,n,r){function i(e,n){H(t,e,function(t){return this._invoke(e,n,t)})}e?o?o(t,e,{value:n,enumerable:!r,configurable:!r,writable:!r}):t[e]=n:(i("next",0),i("throw",1),i("return",2))},H(t,e,n,r)}function Q(t,e){var n="undefined"!=typeof Symbol&&t[Symbol.iterator]||t["@@iterator"];if(!n){if(Array.isArray(t)||(n=function(t,e){if(t){if("string"==typeof t)return X(t,e);var n={}.toString.call(t).slice(8,-1);return"Object"===n&&t.constructor&&(n=t.constructor.name),"Map"===n||"Set"===n?Array.from(t):"Arguments"===n||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)?X(t,e):void 0}}(t))||e&&t&&"number"==typeof t.length){n&&(t=n);var r=0,o=function(){};return{s:o,n:function(){return r>=t.length?{done:!0}:{done:!1,value:t[r++]}},e:function(t){throw t},f:o}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,a=!0,c=!1;return{s:function(){n=n.call(t)},n:function(){var t=n.next();return a=t.done,t},e:function(t){c=!0,i=t},f:function(){try{a||null==n.return||n.return()}finally{if(c)throw i}}}}function X(t,e){(null==e||e>t.length)&&(e=t.length);for(var n=0,r=Array(e);n span.frm-component-label { - font-weight: 500; - font-size: var(--text-sm) !important; - color: var(--grey-900) !important; - width: 40% !important; - display: block !important; - margin-right: 12px !important; -} - -.frm-border-radius-component .frm-border-radius-container { - width: 100%; - display: flex; - justify-content: space-between; - flex-wrap: wrap; -} -.frm-border-radius-component .frm-border-radius-container button { - overflow: hidden; - text-indent: -9999px; - cursor: pointer; - width: 36px; - height: 36px; - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - background: white; - display: flex; - justify-content: center; - align-items: center; - box-sizing: border-box; - background: url('data:image/svg+xml,') no-repeat center center; - background-size: 20px; -} -.frm-border-radius-component .frm-border-radius-container button.frm-active, .frm-border-radius-component .frm-border-radius-container button:hover { - background-color: rgba(0, 0, 0, 0.05); -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper { - width: 100%; - justify-content: space-between; - flex-wrap: wrap; -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden) { - display: flex; -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span { - position: relative; - display: block; - overflow: hidden; - width: calc(50% - 6px); - height: 36px; - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - margin-top: 12px; -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input { - width: 100%; - height: 100%; - padding: 0; - font-size: var(--text-sm); - color: rgb(16, 24, 40); - padding: 0 12px 0px 20px; - box-sizing: border-box; - border: none; - text-align: right; -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus { - outline: none; -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before { - content: ""; - position: absolute; - display: block; - width: 12px; - height: 12px; - left: 12px; - top: 0; - bottom: 0; - right: auto; - margin: auto; - background: url('data:image/svg+xml,') center center no-repeat; - background-size: 12px; -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before { - transform: rotate(180deg); -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before { - transform: rotate(0deg); -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before { - transform: rotate(90deg); -} -.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before { - transform: rotate(-90deg); -} -.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper { - width: calc(100% - 36px - 12px); - height: 36px; - display: flex; - justify-content: center; - box-sizing: border-box; - background: white; - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - overflow: hidden; -} -.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper > * { - border: none; -} -.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input { - width: calc(100% - 44px); - height: 100%; - padding: 0; - font-size: var(--text-sm); - color: rgb(16, 24, 40); - padding-left: 12px; - box-sizing: border-box; -} -.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus { - outline: none; -} -.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select { - text-align: right; - padding: 0; - font-size: var(--text-sm); - color: rgb(102, 112, 133); - width: 44px; - background: url("../../images/style/small-arrow.svg") no-repeat; - background-position: center right 12px; -} -.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus { - outline: none; -} - -/*# sourceMappingURL=frm-border-radius-component.css.map*/ \ No newline at end of file +:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-border-radius-component .frm-border-radius-container{width:100%;display:flex;justify-content:space-between;flex-wrap:wrap}.frm-border-radius-component .frm-border-radius-container button{overflow:hidden;text-indent:-9999px;cursor:pointer;width:36px;height:36px;border-radius:var(--small-radius);border:1px solid var(--grey-300);background:#fff;display:flex;justify-content:center;align-items:center;box-sizing:border-box;background:url('data:image/svg+xml,') no-repeat center center;background-size:20px}.frm-border-radius-component .frm-border-radius-container button.frm-active,.frm-border-radius-component .frm-border-radius-container button:hover{background-color:rgba(0,0,0,.05)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper{width:100%;justify-content:space-between;flex-wrap:wrap}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper:not(.frm_hidden){display:flex}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span{position:relative;display:block;overflow:hidden;width:calc(50% - 6px);height:36px;border-radius:var(--small-radius);border:1px solid var(--grey-300);margin-top:12px}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input{width:100%;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding:0 12px 0px 20px;box-sizing:border-box;border:none;text-align:right}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span input:focus{outline:none}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span:before{content:"";position:absolute;display:block;width:12px;height:12px;left:12px;top:0;bottom:0;right:auto;margin:auto;background:url('data:image/svg+xml,') center center no-repeat;background-size:12px}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-top:before{transform:rotate(180deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-bottom:before{transform:rotate(0deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-left:before{transform:rotate(90deg)}.frm-border-radius-component .frm-border-radius-container .frm-border-individual-inputs-wrapper span.frm-border-input-right:before{transform:rotate(-90deg)}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper{width:calc(100% - 36px - 12px);height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300);overflow:hidden}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper>*{border:none}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input{width:calc(100% - 44px);height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper input:focus{outline:none}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px}.frm-border-radius-component .frm-border-radius-container .frm-input-wrapper select:focus{outline:none} diff --git a/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css b/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css index af5620eb54..544c82b1fb 100644 --- a/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css +++ b/js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.css @@ -1,154 +1 @@ -/*!****************************************************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-colorpicker-component/frm-colorpicker-component.scss ***! - \****************************************************************************************************************************************************************************************************************************************************************************/ -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -.frm_hidden { - display: none; -} - -.frm-component:not(.frm-tabs-wrapper) { - display: flex; - justify-content: space-between; - align-items: center; -} -.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { - font-weight: 500; - font-size: var(--text-sm) !important; - color: var(--grey-900) !important; - width: 40% !important; - display: block !important; - margin-right: 12px !important; -} - -.frm-colorpicker-component .wp-picker-container button[type=button] { - position: relative; - height: 36px !important; - background-image: none !important; - background-color: #fff !important; - overflow: hidden; -} -.frm-colorpicker-component .wp-picker-container button[type=button]:after { - content: ""; - width: 20px; - height: 20px; - display: block; - position: absolute; - top: 0; - right: 8px; - bottom: 0; - margin: auto; - background: url("--frm-plugin-url/images/style/small-arrow.svg") no-repeat; - background-position: center; - z-index: 10; -} -.frm-colorpicker-component .wp-picker-container button[type=button]:focus { - border-color: var(--primary-500) !important; -} -.frm-colorpicker-component .wp-color-result-text { - line-height: 36px !important; - padding: 0 12px; - border: 0; -} -.frm-colorpicker-component .color-alpha { - width: 20px !important; - height: 20px !important; - border-radius: 50% !important; - border: 1px solid rgb(208, 213, 221); - top: 0; - left: 0; - bottom: 0; - margin: auto; - margin-left: 12px; -} -.frm-colorpicker-component .wp-picker-input-wrap input { - width: calc(100% - 10px) !important; - margin: 1px 5px; - height: 32px; - line-height: 32px; -} - -/*# sourceMappingURL=frm-colorpicker-component.css.map*/ \ No newline at end of file +:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-colorpicker-component .wp-picker-container button[type=button]{position:relative;height:36px !important;background-image:none !important;background-color:#fff !important;overflow:hidden}.frm-colorpicker-component .wp-picker-container button[type=button]:after{content:"";width:20px;height:20px;display:block;position:absolute;top:0;right:8px;bottom:0;margin:auto;background:url("--frm-plugin-url/images/style/small-arrow.svg") no-repeat;background-position:center;z-index:10}.frm-colorpicker-component .wp-picker-container button[type=button]:focus{border-color:var(--primary-500) !important}.frm-colorpicker-component .wp-color-result-text{line-height:36px !important;padding:0 12px;border:0}.frm-colorpicker-component .color-alpha{width:20px !important;height:20px !important;border-radius:50% !important;border:1px solid #d0d5dd;top:0;left:0;bottom:0;margin:auto;margin-left:12px}.frm-colorpicker-component .wp-picker-input-wrap input{width:calc(100% - 10px) !important;margin:1px 5px;height:32px;line-height:32px} diff --git a/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css b/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css index aae593022a..a0fddc88ff 100644 --- a/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css +++ b/js/src/web-components/frm-dropdown-component/frm-dropdown-component.css @@ -1,132 +1 @@ -/*!**********************************************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-dropdown-component/frm-dropdown-component.scss ***! - \**********************************************************************************************************************************************************************************************************************************************************************/ -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -.frm_hidden { - display: none; -} - -.frm-component:not(.frm-tabs-wrapper) { - display: flex; - justify-content: space-between; - align-items: center; -} -.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { - font-weight: 500; - font-size: var(--text-sm) !important; - color: var(--grey-900) !important; - width: 40% !important; - display: block !important; - margin-right: 12px !important; -} - -.frm-dropdown-component select { - width: 100%; - outline: 0; - box-shadow: var(--box-shadow-xs); - border-radius: var(--small-radius); - padding: 5px var(--gap-lg) 5px 14px; - border-color: var(--grey-300); - color: var(--grey-800); - font-size: var(--text-md); - margin: 0; - line-height: var(--leading); - border-width: 1px; - border-style: solid; - background-position: center 5px; - background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%; - background-color: #fff; - appearance: none; - -webkit-appearance: none; - -moz-appearance: none; -} -.frm-dropdown-component select:focus { - border-color: var(--primary-500); - box-shadow: none; -} - -/*# sourceMappingURL=frm-dropdown-component.css.map*/ \ No newline at end of file +:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-dropdown-component select{width:100%;outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px var(--gap-lg) 5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;line-height:var(--leading);border-width:1px;border-style:solid;background-position:center 5px;background:rgba(0,0,0,0) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='none'%3E%3Cpath stroke='%2398A2B3' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M12.708 8.959 10 11.875 7.292 8.96'/%3E%3C/svg%3E") no-repeat right 8px top 50%;background-color:#fff;appearance:none;-webkit-appearance:none;-moz-appearance:none}.frm-dropdown-component select:focus{border-color:var(--primary-500);box-shadow:none} diff --git a/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css b/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css index 861ead77f7..2b25df1459 100644 --- a/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css +++ b/js/src/web-components/frm-range-slider-component/frm-range-slider-component.css @@ -1,290 +1 @@ -/*!******************************************************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-range-slider-component/frm-range-slider-component.scss ***! - \******************************************************************************************************************************************************************************************************************************************************************************/ -/** - * Sliders component styles - */ -.frm-style-component .frm-slider-container { - width: calc(100% - 91px); - display: flex; - align-items: center; - color: rgb(29, 41, 57); -} -.frm-style-component .frm-slider-container svg.frmsvg { - color: currentColor; - margin-right: 8px; - margin-left: -5px; - position: relative; - z-index: 15; -} - -.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover { - color: rgb(65, 153, 253); - cursor: pointer; -} - -.frm-style-component .frm-slider-container .frm-slider-active-track { - display: block; - height: 100%; - width: 0; - position: relative; - border-radius: 200px; -} -.frm-style-component .frm-slider-container .frm-slider-active-track, -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { - background: rgb(65, 153, 253); - box-shadow: 0 1.88px 4px -1px rgba(16, 24, 40, 0.03), 0 6px 8px -2px rgba(16, 24, 40, 0.08); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet { - position: absolute; - display: block; - width: 16px; - height: 16px; - border-radius: 50%; - transform: translateX(15px); - cursor: grab; - right: 0; - top: 0; - bottom: 0; - margin: auto; -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label { - position: absolute; - display: block; - width: 48px; - height: 36px; - background: rgb(16, 24, 40); - color: white; - font-weight: 400; - font-size: var(--text-sm); - line-height: 36px; - border-radius: var(--small-radius); - transform: translate(-18px, -42px) scale3d(0.7, 1, 1); - opacity: 0; - z-index: -2; - pointer-events: none; - text-align: center; - user-select: none; -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label { - z-index: 12; - transform: translate(-18px, -42px) scale3d(1, 1, 1); - opacity: 1; - transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before { - content: ""; - display: block; - position: absolute; - width: 18px; - height: 18px; - border-radius: 50%; - left: 0; - top: 0; - transform: translate(-5px, -5px) scale3d(0.7, 0.7, 1); - border: 4px solid rgb(65, 153, 253); - opacity: 0; - transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before { - opacity: 0.5; - transform: translate(-5px, -5px) scale3d(1, 1, 1); - transition: 0.3s opacity, 0.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} -.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after { - content: ""; - position: absolute; - display: block; - width: 180%; - height: 200%; - border-radius: 50%; - left: 0; - top: 0; - transform: translate(-24%, -24%); -} - -.frm-style-component .frm-slider-value { - width: 86px; - height: 36px; - display: flex; - justify-content: center; - box-sizing: border-box; - background: white; - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); -} -.frm-style-component .frm-slider-value > * { - border: none; -} -.frm-style-component .frm-slider-value input { - width: 40px; - height: 100%; - padding: 0; - font-size: var(--text-sm); - color: rgb(16, 24, 40); - padding-left: 12px; - box-sizing: border-box; -} -.frm-style-component .frm-slider-value select { - text-align: right; - padding: 0; - font-size: var(--text-sm); - color: rgb(102, 112, 133); - width: 44px; - background: url("../../images/style/small-arrow.svg") no-repeat; - background-position: center right 12px; - padding-right: 24px !important; -} -.frm-style-component .frm-slider-value select.frm-single-unit { - pointer-events: none; - background-image: none; - padding-right: 12px !important; -} -.frm-style-component .frm-slider { - display: block; - width: calc(100% - 5px); - height: 4px; - background: rgb(234, 236, 240); - border-radius: 200px; - cursor: pointer; -} - -.frm-slider-component .frm-independent-slider-field { - margin-top: 10px; -} -.frm-slider-component.frm-disabled .frm-slider-container { - pointer-events: none; - opacity: 0.5; -} -.frm-slider-component.frm-disabled .frm-slider-value input[type=text] { - width: 28px; -} -.frm-slider-component.frm-disabled .frm-slider-value select { - width: 56px; -} -.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text] { - width: 56px; -} -.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select { - width: 28px; -} - -.frm-style-component .frm-slider-component.frm-has-multiple-values { - margin-bottom: 10px; -} - -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -.frm_hidden { - display: none; -} - -.frm-component:not(.frm-tabs-wrapper) { - display: flex; - justify-content: space-between; - align-items: center; -} -.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { - font-weight: 500; - font-size: var(--text-sm) !important; - color: var(--grey-900) !important; - width: 40% !important; - display: block !important; - margin-right: 12px !important; -} - -.frm-component .frmsvg { - width: 18px; - height: 18px; -} -.frm-component .frm-sliders-container { - width: 100%; -} -.frm-component .frm-group-sliders .frm-slider-component { - margin-top: 5px; -} - -/*# sourceMappingURL=frm-range-slider-component.css.map*/ \ No newline at end of file +.frm-style-component .frm-slider-container{width:calc(100% - 91px);display:flex;align-items:center;color:#1d2939}.frm-style-component .frm-slider-container svg.frmsvg{color:currentColor;margin-right:8px;margin-left:-5px;position:relative;z-index:15}.frm-style-component .frm-group-sliders .frm-slider-container svg.frmsvg:hover{color:#4199fd;cursor:pointer}.frm-style-component .frm-slider-container .frm-slider-active-track{display:block;height:100%;width:0;position:relative;border-radius:200px}.frm-style-component .frm-slider-container .frm-slider-active-track,.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{background:#4199fd;box-shadow:0 1.88px 4px -1px rgba(16,24,40,.03),0 6px 8px -2px rgba(16,24,40,.08)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet{position:absolute;display:block;width:16px;height:16px;border-radius:50%;transform:translateX(15px);cursor:grab;right:0;top:0;bottom:0;margin:auto}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet .frm-slider-value-label{position:absolute;display:block;width:48px;height:36px;background:#101828;color:#fff;font-weight:400;font-size:var(--text-sm);line-height:36px;border-radius:var(--small-radius);transform:translate(-18px, -42px) scale3d(0.7, 1, 1);opacity:0;z-index:-2;pointer-events:none;text-align:center;user-select:none}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging .frm-slider-value-label{z-index:12;transform:translate(-18px, -42px) scale3d(1, 1, 1);opacity:1;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::before{content:"";display:block;position:absolute;width:18px;height:18px;border-radius:50%;left:0;top:0;transform:translate(-5px, -5px) scale3d(0.7, 0.7, 1);border:4px solid #4199fd;opacity:0;transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet.frm-dragging::before{opacity:.5;transform:translate(-5px, -5px) scale3d(1, 1, 1);transition:.3s opacity,.35s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-style-component .frm-slider-container .frm-slider-active-track .frm-slider-bullet::after{content:"";position:absolute;display:block;width:180%;height:200%;border-radius:50%;left:0;top:0;transform:translate(-24%, -24%)}.frm-style-component .frm-slider-value{width:86px;height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300)}.frm-style-component .frm-slider-value>*{border:none}.frm-style-component .frm-slider-value input{width:40px;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:12px;box-sizing:border-box}.frm-style-component .frm-slider-value select{text-align:right;padding:0;font-size:var(--text-sm);color:#667085;width:44px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px;padding-right:24px !important}.frm-style-component .frm-slider-value select.frm-single-unit{pointer-events:none;background-image:none;padding-right:12px !important}.frm-style-component .frm-slider{display:block;width:calc(100% - 5px);height:4px;background:#eaecf0;border-radius:200px;cursor:pointer}.frm-slider-component .frm-independent-slider-field{margin-top:10px}.frm-slider-component.frm-disabled .frm-slider-container{pointer-events:none;opacity:.5}.frm-slider-component.frm-disabled .frm-slider-value input[type=text]{width:28px}.frm-slider-component.frm-disabled .frm-slider-value select{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value input[type=text]{width:56px}.frm-slider-component.frm-disabled.frm-empty .frm-slider-value select{width:28px}.frm-style-component .frm-slider-component.frm-has-multiple-values{margin-bottom:10px}:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-component .frmsvg{width:18px;height:18px}.frm-component .frm-sliders-container{width:100%}.frm-component .frm-group-sliders .frm-slider-component{margin-top:5px} diff --git a/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css b/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css index 4e1c15aded..29b60a813b 100644 --- a/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css +++ b/js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.css @@ -1,243 +1 @@ -/*!********************************************************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-tab-navigator-component/frm-tab-navigator-component.scss ***! - \********************************************************************************************************************************************************************************************************************************************************************************/ -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -.frm_hidden { - display: none; -} - -.frm-component:not(.frm-tabs-wrapper) { - display: flex; - justify-content: space-between; - align-items: center; -} -.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { - font-weight: 500; - font-size: var(--text-sm) !important; - color: var(--grey-900) !important; - width: 40% !important; - display: block !important; - margin-right: 12px !important; -} - -.frm-tabs-wrapper { - position: relative; - overflow: hidden; -} -.frm-tabs-wrapper .frm-tabs-navigator { - margin: 0; - padding: 0; - display: flex; - gap: var(--gap-xs); - justify-content: space-between; - align-items: center; - background: rgb(242, 244, 247); - border-radius: var(--small-radius); - box-sizing: border-box; - height: 44px; - position: relative; - z-index: 2; -} -.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item { - flex: 1; - text-align: center; - cursor: pointer; -} -.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background { - display: block; - height: 100%; - background: white; - position: absolute; - top: 0; - left: 0; - z-index: 1; -} - -.frm-tabs-navs { - padding: 0; - min-height: 44px; -} -.frm-tabs-navs ul { - margin: 0; - height: var(--h-md); - position: relative; - display: flex; - justify-content: space-between; - list-style-type: none; - padding: 0px; -} -.frm-tabs-navs ul li, -.frm-tabs-navs ul li a { - color: var(--grey-500); - font-weight: 500; - font-size: var(--text-sm); - line-height: 28px; -} -.frm-tabs-navs ul li { - flex: 1; - height: 28px; - text-align: center; - margin-top: var(--gap-xs); - margin-bottom: 0; - cursor: pointer; -} - -.frm-tabs-navs ul li.frm-active, .frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a { - color: var(--grey-900); -} - -.frm-tabs-navs ul li:first-child { - margin-left: var(--gap-xs); -} - -.frm-tabs-navs ul li:last-child { - margin-right: var(--gap-xs); -} - -.frm-tabs-delimiter { - position: absolute; - top: 0; - left: 0; - width: 100%; - background: rgb(242, 244, 247); - height: 44px; - margin: 0; - border-radius: var(--small-radius); -} -.frm-tabs-delimiter .frm-tabs-active-underline { - height: 28px; - background: white; - position: absolute; - left: 0; - bottom: 8px; - transition: 0.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); - border-radius: var(--small-radius); - box-shadow: var(--button-shadow); - display: none; -} - -.frm-tabs-container { - position: relative; - overflow: hidden; - margin-top: var(--gap-md); - height: 100%; -} - -.frm-tabs-container .frm-tabs-slide-track { - display: flex; - transition: 0.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94); -} - -.frm-tabs-slide-track > div { - flex: 0 0 100%; - opacity: 0; - transition: 0.25s opacity linear; - position: relative; - height: auto; - max-height: unset; - overflow: hidden; - box-sizing: border-box; -} - -.frm-tabs-slide-track > div > div { - overflow: auto; - position: relative; - width: 100%; - padding: 0; - box-sizing: border-box; -} - -.frm-tabs-slide-track > div > div:first-child { - height: 100%; -} - -.frm-tabs-slide-track > div.frm-active { - opacity: 1; - transition: 0.35s opacity linear; -} - -/*# sourceMappingURL=frm-tab-navigator-component.css.map*/ \ No newline at end of file +:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-tabs-wrapper{position:relative;overflow:hidden}.frm-tabs-wrapper .frm-tabs-navigator{margin:0;padding:0;display:flex;gap:var(--gap-xs);justify-content:space-between;align-items:center;background:#f2f4f7;border-radius:var(--small-radius);box-sizing:border-box;height:44px;position:relative;z-index:2}.frm-tabs-wrapper .frm-tabs-navigator .frm-tab-item{flex:1;text-align:center;cursor:pointer}.frm-tabs-wrapper .frm-tabs-navigator .frm-active-background{display:block;height:100%;background:#fff;position:absolute;top:0;left:0;z-index:1}.frm-tabs-navs{padding:0;min-height:44px}.frm-tabs-navs ul{margin:0;height:var(--h-md);position:relative;display:flex;justify-content:space-between;list-style-type:none;padding:0px}.frm-tabs-navs ul li,.frm-tabs-navs ul li a{color:var(--grey-500);font-weight:500;font-size:var(--text-sm);line-height:28px}.frm-tabs-navs ul li{flex:1;height:28px;text-align:center;margin-top:var(--gap-xs);margin-bottom:0;cursor:pointer}.frm-tabs-navs ul li.frm-active,.frm-style-tabs-wrapper .frm-tabs-navs ul li.frm-active a{color:var(--grey-900)}.frm-tabs-navs ul li:first-child{margin-left:var(--gap-xs)}.frm-tabs-navs ul li:last-child{margin-right:var(--gap-xs)}.frm-tabs-delimiter{position:absolute;top:0;left:0;width:100%;background:#f2f4f7;height:44px;margin:0;border-radius:var(--small-radius)}.frm-tabs-delimiter .frm-tabs-active-underline{height:28px;background:#fff;position:absolute;left:0;bottom:8px;transition:.4s transform cubic-bezier(0.25, 0.46, 0.45, 0.94);border-radius:var(--small-radius);box-shadow:var(--button-shadow);display:none}.frm-tabs-container{position:relative;overflow:hidden;margin-top:var(--gap-md);height:100%}.frm-tabs-container .frm-tabs-slide-track{display:flex;transition:.32s transform cubic-bezier(0.25, 0.46, 0.45, 0.94)}.frm-tabs-slide-track>div{flex:0 0 100%;opacity:0;transition:.25s opacity linear;position:relative;height:auto;max-height:unset;overflow:hidden;box-sizing:border-box}.frm-tabs-slide-track>div>div{overflow:auto;position:relative;width:100%;padding:0;box-sizing:border-box}.frm-tabs-slide-track>div>div:first-child{height:100%}.frm-tabs-slide-track>div.frm-active{opacity:1;transition:.35s opacity linear} diff --git a/js/src/web-components/frm-typography-component/frm-typography-component.css b/js/src/web-components/frm-typography-component/frm-typography-component.css index 7d1ee3da53..a399a2a963 100644 --- a/js/src/web-components/frm-typography-component/frm-typography-component.css +++ b/js/src/web-components/frm-typography-component/frm-typography-component.css @@ -1,166 +1 @@ -/*!**************************************************************************************************************************************************************************************************************************************************************************!*\ - !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[1]!./node_modules/css-unicode-loader/index.js!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./js/src/web-components/frm-typography-component/frm-typography-component.scss ***! - \**************************************************************************************************************************************************************************************************************************************************************************/ -/** - * Base - Variables - */ -:root, -.frm-white-body, -.frm_wrap { - --grey-900: #101828; - --grey-800: #1d2939; - --grey-700: #344054; - --grey-600: #475467; - --grey-500: #667085; /* Roughly 65% opacity */ - --grey-400: #98a2b3; - --grey-300: #d0d5dd; - --grey-200: #eaecf0; - --grey-100: #f2f4f7; - --grey-50: #f9fafb; - --grey-25: #fcfcfd; - --dark-grey: var(--grey-700); /* Deprecated */ - --medium-grey: rgba(40, 47, 54, 0.65); - --grey: var(--grey-500); /* Deprecated */ - --grey-border: var(--grey-300); /* Deprecated */ - --lightest-grey: rgb(250, 250, 250); - --sidebar-color: var(--grey-50); - --sidebar-hover: var(--grey-200); - --primary-700: #2b66a9; - --primary-500: #4199fd; - --primary-300: #80bbfe; - --primary-200: #c0ddfe; - --primary-50: #ecf5ff; - --primary-25: #f5faff; - --primary-color: var(--primary-500); /* Deprecated */ - --primary-hover: var(--primary-700); /* Deprecated */ - --light-blue: var(--primary-25); /* Deprecated */ - --blue-border: rgb(188, 224, 253); - --error-700: #b42318; - --error-500: #f04438; - --error-300: #fecdca; - --error-100: #fee4e2; - --error-25: #fff5f4; - --green: rgb(63, 172, 37); - --orange: #f15a24; - --warning-500: #f79009; - --pink: rgb(226, 42, 110); - --purple: rgb(141, 53, 245); - --success-900: #054f31; - --success-800: #065f46; - --success-500: #12b76a; - --success-100: #d1fae5; - --success-200: #a6f4c5; - --success-50: #ecfdf3; - --success-25: #f6fef9; - --border-radius: 35px; - --small-radius: 8px; - --medium-radius: 16px; - --small-sidebar: 275px; - --medium-sidebar: 350px; - --big-sidebar: 390px; - --biggest-sidebar: 450px; - --text-xs: 12px; - --text-sm: 14px; - --text-md: 16px; - --text-lg: 18px; - --text-xl: 20px; - --h-xs: 24px; - --h-sm: 30px; - --h-md: 36px; - --leading: 1.5; - --gap-2xs: 4px; - --gap-xs: 8px; - --gap-sm: 16px; - --gap-md: 24px; - --gap-lg: 32px; - --gap-xl: 40px; - --gap-2xl: 48px; - --box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05); - --box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06); - --box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03); - --box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18); - --button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1); - /* Override front-end CSS */ - --check-label-color: var(--grey-700); -} - -.frm_hidden { - display: none; -} - -.frm-component:not(.frm-tabs-wrapper) { - display: flex; - justify-content: space-between; - align-items: center; -} -.frm-component:not(.frm-tabs-wrapper) > span.frm-component-label { - font-weight: 500; - font-size: var(--text-sm) !important; - color: var(--grey-900) !important; - width: 40% !important; - display: block !important; - margin-right: 12px !important; -} - -.frm-typography-component .frm-typography-container { - display: flex; - justify-content: space-between; - width: 100%; -} -.frm-typography-component .frm-typography-container select { - width: calc(70% - 6px); - outline: 0; - box-shadow: var(--box-shadow-xs); - border-radius: var(--small-radius); - padding: 5px 14px; - border-color: var(--grey-300); - color: var(--grey-800); - font-size: var(--text-md); - margin: 0; - background-color: #fff; - line-height: var(--leading); - border-width: 1px; - border-style: solid; -} -.frm-typography-component .frm-typography-container .frm-unit-value { - width: 28%; - height: 36px; - display: flex; - justify-content: center; - box-sizing: border-box; - background: white; - border-radius: var(--small-radius); - border: 1px solid var(--grey-300); - overflow: hidden; -} -.frm-typography-component .frm-typography-container .frm-unit-value > * { - border: none; -} -.frm-typography-component .frm-typography-container .frm-unit-value input { - width: 32px; - height: 100%; - padding: 0; - font-size: var(--text-sm); - color: rgb(16, 24, 40); - padding-left: 8px; - box-sizing: border-box; -} -.frm-typography-component .frm-typography-container .frm-unit-value input:focus { - outline: none; -} -.frm-typography-component .frm-typography-container .frm-unit-value select { - text-align: left; - padding: 0; - font-size: var(--text-sm); - color: rgb(102, 112, 133); - width: 36px; - background: url("../../images/style/small-arrow.svg") no-repeat; - background-position: center right 12px; -} -.frm-typography-component .frm-typography-container .frm-unit-value select:focus { - outline: none; -} - -/*# sourceMappingURL=frm-typography-component.css.map*/ \ No newline at end of file +:root,.frm-white-body,.frm_wrap{--grey-900: #101828;--grey-800: #1d2939;--grey-700: #344054;--grey-600: #475467;--grey-500: #667085;--grey-400: #98a2b3;--grey-300: #d0d5dd;--grey-200: #eaecf0;--grey-100: #f2f4f7;--grey-50: #f9fafb;--grey-25: #fcfcfd;--dark-grey: var(--grey-700);--medium-grey: rgba(40, 47, 54, 0.65);--grey: var(--grey-500);--grey-border: var(--grey-300);--lightest-grey: rgb(250, 250, 250);--sidebar-color: var(--grey-50);--sidebar-hover: var(--grey-200);--primary-700: #2b66a9;--primary-500: #4199fd;--primary-300: #80bbfe;--primary-200: #c0ddfe;--primary-50: #ecf5ff;--primary-25: #f5faff;--primary-color: var(--primary-500);--primary-hover: var(--primary-700);--light-blue: var(--primary-25);--blue-border: rgb(188, 224, 253);--error-700: #b42318;--error-500: #f04438;--error-300: #fecdca;--error-100: #fee4e2;--error-25: #fff5f4;--green: rgb(63, 172, 37);--orange: #f15a24;--warning-500: #f79009;--pink: rgb(226, 42, 110);--purple: rgb(141, 53, 245);--success-900: #054f31;--success-800: #065f46;--success-500: #12b76a;--success-100: #d1fae5;--success-200: #a6f4c5;--success-50: #ecfdf3;--success-25: #f6fef9;--border-radius: 35px;--small-radius: 8px;--medium-radius: 16px;--small-sidebar: 275px;--medium-sidebar: 350px;--big-sidebar: 390px;--biggest-sidebar: 450px;--text-xs: 12px;--text-sm: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 20px;--h-xs: 24px;--h-sm: 30px;--h-md: 36px;--leading: 1.5;--gap-2xs: 4px;--gap-xs: 8px;--gap-sm: 16px;--gap-md: 24px;--gap-lg: 32px;--gap-xl: 40px;--gap-2xl: 48px;--box-shadow-xs: 0 0.47074466943740845px 0.9414893388748169px 0 rgba(16, 24, 40, 0.05);--box-shadow-sm: 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-md: 0 1.88298px 3.76596px -0.941489px rgba(16, 24, 40, 0.1), 0 0.941489px 1.88298px -0.941489px rgba(16, 24, 40, 0.06);--box-shadow-lg: 0 6px 8px -2px rgba(16, 24, 40, 0.08), 0 1.88298px 4px -1px rgba(16, 24, 40, 0.03), 0 0.470745px 1.41223px rgba(16, 24, 40, 0.1), 0 0.470745px 0.941489px rgba(16, 24, 40, 0.06);--box-shadow-xl: 0 9.41489px 11.2979px -1.88298px rgba(16, 24, 40, 0.08), 0 3.76596px 3.76596px -1.88298px rgba(16, 24, 40, 0.03);--box-shadow-xxl: 0 11px 22px -5px rgba(16, 24, 40, 0.18);--button-shadow: 0 0.47px 0.94px 0 rgba(16, 24, 40, 0.06), 0 0.47px 1.47px 0 rgba(16, 24, 40, 0.1);--check-label-color: var(--grey-700)}.frm_hidden{display:none}.frm-component:not(.frm-tabs-wrapper){display:flex;justify-content:space-between;align-items:center}.frm-component:not(.frm-tabs-wrapper)>span.frm-component-label{font-weight:500;font-size:var(--text-sm) !important;color:var(--grey-900) !important;width:40% !important;display:block !important;margin-right:12px !important}.frm-typography-component .frm-typography-container{display:flex;justify-content:space-between;width:100%}.frm-typography-component .frm-typography-container select{width:calc(70% - 6px);outline:0;box-shadow:var(--box-shadow-xs);border-radius:var(--small-radius);padding:5px 14px;border-color:var(--grey-300);color:var(--grey-800);font-size:var(--text-md);margin:0;background-color:#fff;line-height:var(--leading);border-width:1px;border-style:solid}.frm-typography-component .frm-typography-container .frm-unit-value{width:28%;height:36px;display:flex;justify-content:center;box-sizing:border-box;background:#fff;border-radius:var(--small-radius);border:1px solid var(--grey-300);overflow:hidden}.frm-typography-component .frm-typography-container .frm-unit-value>*{border:none}.frm-typography-component .frm-typography-container .frm-unit-value input{width:32px;height:100%;padding:0;font-size:var(--text-sm);color:#101828;padding-left:8px;box-sizing:border-box}.frm-typography-component .frm-typography-container .frm-unit-value input:focus{outline:none}.frm-typography-component .frm-typography-container .frm-unit-value select{text-align:left;padding:0;font-size:var(--text-sm);color:#667085;width:36px;background:url("../../images/style/small-arrow.svg") no-repeat;background-position:center right 12px}.frm-typography-component .frm-typography-container .frm-unit-value select:focus{outline:none} diff --git a/js/welcome-tour.js b/js/welcome-tour.js index af97ea8d36..20079e0d6c 100644 --- a/js/welcome-tour.js +++ b/js/welcome-tour.js @@ -1,4436 +1,2 @@ -/******/ (() => { // webpackBootstrap -/******/ var __webpack_modules__ = ({ - -/***/ "./node_modules/@tannin/compile/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/compile/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ compile) -/* harmony export */ }); -/* harmony import */ var _tannin_postfix__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/postfix */ "./node_modules/@tannin/postfix/index.js"); -/* harmony import */ var _tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tannin/evaluate */ "./node_modules/@tannin/evaluate/index.js"); - - - -/** - * Given a C expression, returns a function which can be called to evaluate its - * result. - * - * @example - * - * ```js - * import compile from '@tannin/compile'; - * - * const evaluate = compile( 'n > 1' ); - * - * evaluate( { n: 2 } ); - * // ⇒ true - * ``` - * - * @param {string} expression C expression. - * - * @return {(variables?:{[variable:string]:*})=>*} Compiled evaluator. - */ -function compile( expression ) { - var terms = (0,_tannin_postfix__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( variables ) { - return (0,_tannin_evaluate__WEBPACK_IMPORTED_MODULE_1__["default"])( terms, variables ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/evaluate/index.js": -/*!************************************************!*\ - !*** ./node_modules/@tannin/evaluate/index.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ evaluate) -/* harmony export */ }); -/** - * Operator callback functions. - * - * @type {Object} - */ -var OPERATORS = { - '!': function( a ) { - return ! a; - }, - '*': function( a, b ) { - return a * b; - }, - '/': function( a, b ) { - return a / b; - }, - '%': function( a, b ) { - return a % b; - }, - '+': function( a, b ) { - return a + b; - }, - '-': function( a, b ) { - return a - b; - }, - '<': function( a, b ) { - return a < b; - }, - '<=': function( a, b ) { - return a <= b; - }, - '>': function( a, b ) { - return a > b; - }, - '>=': function( a, b ) { - return a >= b; - }, - '==': function( a, b ) { - return a === b; - }, - '!=': function( a, b ) { - return a !== b; - }, - '&&': function( a, b ) { - return a && b; - }, - '||': function( a, b ) { - return a || b; - }, - '?:': function( a, b, c ) { - if ( a ) { - throw b; - } - - return c; - }, -}; - -/** - * Given an array of postfix terms and operand variables, returns the result of - * the postfix evaluation. - * - * @example - * - * ```js - * import evaluate from '@tannin/evaluate'; - * - * // 3 + 4 * 5 / 6 ⇒ '3 4 5 * 6 / +' - * const terms = [ '3', '4', '5', '*', '6', '/', '+' ]; - * - * evaluate( terms, {} ); - * // ⇒ 6.333333333333334 - * ``` - * - * @param {string[]} postfix Postfix terms. - * @param {Object} variables Operand variables. - * - * @return {*} Result of evaluation. - */ -function evaluate( postfix, variables ) { - var stack = [], - i, j, args, getOperatorResult, term, value; - - for ( i = 0; i < postfix.length; i++ ) { - term = postfix[ i ]; - - getOperatorResult = OPERATORS[ term ]; - if ( getOperatorResult ) { - // Pop from stack by number of function arguments. - j = getOperatorResult.length; - args = Array( j ); - while ( j-- ) { - args[ j ] = stack.pop(); - } - - try { - value = getOperatorResult.apply( null, args ); - } catch ( earlyReturn ) { - return earlyReturn; - } - } else if ( variables.hasOwnProperty( term ) ) { - value = variables[ term ]; - } else { - value = +term; - } - - stack.push( value ); - } - - return stack[ 0 ]; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/plural-forms/index.js": -/*!****************************************************!*\ - !*** ./node_modules/@tannin/plural-forms/index.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ pluralForms) -/* harmony export */ }); -/* harmony import */ var _tannin_compile__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/compile */ "./node_modules/@tannin/compile/index.js"); - - -/** - * Given a C expression, returns a function which, when called with a value, - * evaluates the result with the value assumed to be the "n" variable of the - * expression. The result will be coerced to its numeric equivalent. - * - * @param {string} expression C expression. - * - * @return {Function} Evaluator function. - */ -function pluralForms( expression ) { - var evaluate = (0,_tannin_compile__WEBPACK_IMPORTED_MODULE_0__["default"])( expression ); - - return function( n ) { - return +evaluate( { n: n } ); - }; -} - - -/***/ }), - -/***/ "./node_modules/@tannin/postfix/index.js": -/*!***********************************************!*\ - !*** ./node_modules/@tannin/postfix/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ postfix) -/* harmony export */ }); -var PRECEDENCE, OPENERS, TERMINATORS, PATTERN; - -/** - * Operator precedence mapping. - * - * @type {Object} - */ -PRECEDENCE = { - '(': 9, - '!': 8, - '*': 7, - '/': 7, - '%': 7, - '+': 6, - '-': 6, - '<': 5, - '<=': 5, - '>': 5, - '>=': 5, - '==': 4, - '!=': 4, - '&&': 3, - '||': 2, - '?': 1, - '?:': 1, -}; - -/** - * Characters which signal pair opening, to be terminated by terminators. - * - * @type {string[]} - */ -OPENERS = [ '(', '?' ]; - -/** - * Characters which signal pair termination, the value an array with the - * opener as its first member. The second member is an optional operator - * replacement to push to the stack. - * - * @type {string[]} - */ -TERMINATORS = { - ')': [ '(' ], - ':': [ '?', '?:' ], -}; - -/** - * Pattern matching operators and openers. - * - * @type {RegExp} - */ -PATTERN = /<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/; - -/** - * Given a C expression, returns the equivalent postfix (Reverse Polish) - * notation terms as an array. - * - * If a postfix string is desired, simply `.join( ' ' )` the result. - * - * @example - * - * ```js - * import postfix from '@tannin/postfix'; - * - * postfix( 'n > 1' ); - * // ⇒ [ 'n', '1', '>' ] - * ``` - * - * @param {string} expression C expression. - * - * @return {string[]} Postfix terms. - */ -function postfix( expression ) { - var terms = [], - stack = [], - match, operator, term, element; - - while ( ( match = expression.match( PATTERN ) ) ) { - operator = match[ 0 ]; - - // Term is the string preceding the operator match. It may contain - // whitespace, and may be empty (if operator is at beginning). - term = expression.substr( 0, match.index ).trim(); - if ( term ) { - terms.push( term ); - } - - while ( ( element = stack.pop() ) ) { - if ( TERMINATORS[ operator ] ) { - if ( TERMINATORS[ operator ][ 0 ] === element ) { - // Substitution works here under assumption that because - // the assigned operator will no longer be a terminator, it - // will be pushed to the stack during the condition below. - operator = TERMINATORS[ operator ][ 1 ] || operator; - break; - } - } else if ( OPENERS.indexOf( element ) >= 0 || PRECEDENCE[ element ] < PRECEDENCE[ operator ] ) { - // Push to stack if either an opener or when pop reveals an - // element of lower precedence. - stack.push( element ); - break; - } - - // For each popped from stack, push to terms. - terms.push( element ); - } - - if ( ! TERMINATORS[ operator ] ) { - stack.push( operator ); - } - - // Slice matched fragment from expression to continue match. - expression = expression.substr( match.index + operator.length ); - } - - // Push remainder of operand, if exists, to terms. - expression = expression.trim(); - if ( expression ) { - terms.push( expression ); - } - - // Pop remaining items from stack into terms. - return terms.concat( stack.reverse() ); -} - - -/***/ }), - -/***/ "./node_modules/@wordpress/dom-ready/build-module/index.js": -/*!*****************************************************************!*\ - !*** ./node_modules/@wordpress/dom-ready/build-module/index.js ***! - \*****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ domReady) -/* harmony export */ }); -/** - * @typedef {() => void} Callback - * - * TODO: Remove this typedef and inline `() => void` type. - * - * This typedef is used so that a descriptive type is provided in our - * automatically generated documentation. - * - * An in-line type `() => void` would be preferable, but the generated - * documentation is `null` in that case. - * - * @see https://github.com/WordPress/gutenberg/issues/18045 - */ - -/** - * Specify a function to execute when the DOM is fully loaded. - * - * @param {Callback} callback A function to execute after the DOM is ready. - * - * @example - * ```js - * import domReady from '@wordpress/dom-ready'; - * - * domReady( function() { - * //do something after DOM loads. - * } ); - * ``` - * - * @return {void} - */ -function domReady(callback) { - if (typeof document === 'undefined') { - return; - } - - if (document.readyState === 'complete' || // DOMContentLoaded + Images/Styles/etc loaded, so we call directly. - document.readyState === 'interactive' // DOMContentLoaded fires at this point, so we call directly. - ) { - return void callback(); - } // DOMContentLoaded has not fired yet, delay callback until then. - - - document.addEventListener('DOMContentLoaded', callback); -} -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createAddHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createAddHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback AddHook - * - * Adds the hook to the appropriate hooks container. - * - * @param {string} hookName Name of hook to add - * @param {string} namespace The unique namespace identifying the callback in the form `vendor/plugin/function`. - * @param {import('.').Callback} callback Function to call when the hook is run - * @param {number} [priority=10] Priority of this hook - */ - -/** - * Returns a function which, when invoked, will add a hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {AddHook} Function that adds a new hook. - */ - -function createAddHook(hooks, storeKey) { - return function addHook(hookName, namespace, callback) { - var priority = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 10; - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } - - if ('function' !== typeof callback) { - // eslint-disable-next-line no-console - console.error('The hook callback must be a function.'); - return; - } // Validate numeric priority - - - if ('number' !== typeof priority) { - // eslint-disable-next-line no-console - console.error('If specified, the hook priority must be a number.'); - return; - } - - var handler = { - callback: callback, - priority: priority, - namespace: namespace - }; - - if (hooksStore[hookName]) { - // Find the correct insert index of the new hook. - var handlers = hooksStore[hookName].handlers; - /** @type {number} */ - - var i; - - for (i = handlers.length; i > 0; i--) { - if (priority >= handlers[i - 1].priority) { - break; - } - } - - if (i === handlers.length) { - // If append, operate via direct assignment. - handlers[i] = handler; - } else { - // Otherwise, insert before index via splice. - handlers.splice(i, 0, handler); - } // We may also be currently executing this hook. If the callback - // we're adding would come after the current callback, there's no - // problem; otherwise we need to increase the execution index of - // any other runs by 1 to account for the added element. - - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex++; - } - }); - } else { - // This is the first hook of its type. - hooksStore[hookName] = { - handlers: [handler], - runs: 0 - }; - } - - if (hookName !== 'hookAdded') { - hooks.doAction('hookAdded', hookName, namespace, callback, priority); - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createAddHook); -//# sourceMappingURL=createAddHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createCurrentHook.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Returns a function which, when invoked, will return the name of the - * currently running hook, or `null` if no hook of the given type is currently - * running. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {() => string | null} Function that returns the current hook name or null. - */ -function createCurrentHook(hooks, storeKey) { - return function currentHook() { - var _hooksStore$__current, _hooksStore$__current2; - - var hooksStore = hooks[storeKey]; - return (_hooksStore$__current = (_hooksStore$__current2 = hooksStore.__current[hooksStore.__current.length - 1]) === null || _hooksStore$__current2 === void 0 ? void 0 : _hooksStore$__current2.name) !== null && _hooksStore$__current !== void 0 ? _hooksStore$__current : null; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createCurrentHook); -//# sourceMappingURL=createCurrentHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDidHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDidHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - -/** - * @callback DidHook - * - * Returns the number of times an action has been fired. - * - * @param {string} hookName The hook name to check. - * - * @return {number | undefined} The number of times the hook has run. - */ - -/** - * Returns a function which, when invoked, will return the number of times a - * hook has been called. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DidHook} Function that returns a hook's call count. - */ - -function createDidHook(hooks, storeKey) { - return function didHook(hookName) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_0__["default"])(hookName)) { - return; - } - - return hooksStore[hookName] && hooksStore[hookName].runs ? hooksStore[hookName].runs : 0; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDidHook); -//# sourceMappingURL=createDidHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js": -/*!***********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createDoingHook.js ***! - \***********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback DoingHook - * Returns whether a hook is currently being executed. - * - * @param {string} [hookName] The name of the hook to check for. If - * omitted, will check for any hook being executed. - * - * @return {boolean} Whether the hook is being executed. - */ - -/** - * Returns a function which, when invoked, will return whether a hook is - * currently being executed. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {DoingHook} Function that returns whether a hook is currently - * being executed. - */ -function createDoingHook(hooks, storeKey) { - return function doingHook(hookName) { - var hooksStore = hooks[storeKey]; // If the hookName was not passed, check for any current hook. - - if ('undefined' === typeof hookName) { - return 'undefined' !== typeof hooksStore.__current[0]; - } // Return the __current hook. - - - return hooksStore.__current[0] ? hookName === hooksStore.__current[0].name : false; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createDoingHook); -//# sourceMappingURL=createDoingHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHasHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHasHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * @callback HasHook - * - * Returns whether any handlers are attached for the given hookName and optional namespace. - * - * @param {string} hookName The name of the hook to check for. - * @param {string} [namespace] Optional. The unique namespace identifying the callback - * in the form `vendor/plugin/function`. - * - * @return {boolean} Whether there are handlers that are attached to the given hook. - */ - -/** - * Returns a function which, when invoked, will return whether any handlers are - * attached to a particular hook. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * - * @return {HasHook} Function that returns whether any handlers are - * attached to a particular hook and optional namespace. - */ -function createHasHook(hooks, storeKey) { - return function hasHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; // Use the namespace if provided. - - if ('undefined' !== typeof namespace) { - return hookName in hooksStore && hooksStore[hookName].handlers.some(function (hook) { - return hook.namespace === namespace; - }); - } - - return hookName in hooksStore; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHasHook); -//# sourceMappingURL=createHasHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createHooks.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createHooks.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ _Hooks: () => (/* binding */ _Hooks), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/classCallCheck */ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js"); -/* harmony import */ var _createAddHook__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createAddHook */ "./node_modules/@wordpress/hooks/build-module/createAddHook.js"); -/* harmony import */ var _createRemoveHook__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./createRemoveHook */ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js"); -/* harmony import */ var _createHasHook__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./createHasHook */ "./node_modules/@wordpress/hooks/build-module/createHasHook.js"); -/* harmony import */ var _createRunHook__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./createRunHook */ "./node_modules/@wordpress/hooks/build-module/createRunHook.js"); -/* harmony import */ var _createCurrentHook__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./createCurrentHook */ "./node_modules/@wordpress/hooks/build-module/createCurrentHook.js"); -/* harmony import */ var _createDoingHook__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./createDoingHook */ "./node_modules/@wordpress/hooks/build-module/createDoingHook.js"); -/* harmony import */ var _createDidHook__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createDidHook */ "./node_modules/@wordpress/hooks/build-module/createDidHook.js"); - - -/** - * Internal dependencies - */ - - - - - - - -/** - * Internal class for constructing hooks. Use `createHooks()` function - * - * Note, it is necessary to expose this class to make its type public. - * - * @private - */ - -var _Hooks = function _Hooks() { - (0,_babel_runtime_helpers_esm_classCallCheck__WEBPACK_IMPORTED_MODULE_0__["default"])(this, _Hooks); - - /** @type {import('.').Store} actions */ - this.actions = Object.create(null); - this.actions.__current = []; - /** @type {import('.').Store} filters */ - - this.filters = Object.create(null); - this.filters.__current = []; - this.addAction = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'actions'); - this.addFilter = (0,_createAddHook__WEBPACK_IMPORTED_MODULE_1__["default"])(this, 'filters'); - this.removeAction = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions'); - this.removeFilter = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters'); - this.hasAction = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'actions'); - this.hasFilter = (0,_createHasHook__WEBPACK_IMPORTED_MODULE_3__["default"])(this, 'filters'); - this.removeAllActions = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'actions', true); - this.removeAllFilters = (0,_createRemoveHook__WEBPACK_IMPORTED_MODULE_2__["default"])(this, 'filters', true); - this.doAction = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'actions'); - this.applyFilters = (0,_createRunHook__WEBPACK_IMPORTED_MODULE_4__["default"])(this, 'filters', true); - this.currentAction = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'actions'); - this.currentFilter = (0,_createCurrentHook__WEBPACK_IMPORTED_MODULE_5__["default"])(this, 'filters'); - this.doingAction = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'actions'); - this.doingFilter = (0,_createDoingHook__WEBPACK_IMPORTED_MODULE_6__["default"])(this, 'filters'); - this.didAction = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'actions'); - this.didFilter = (0,_createDidHook__WEBPACK_IMPORTED_MODULE_7__["default"])(this, 'filters'); -}; -/** @typedef {_Hooks} Hooks */ - -/** - * Returns an instance of the hooks object. - * - * @return {Hooks} A Hooks instance. - */ - -function createHooks() { - return new _Hooks(); -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createHooks); -//# sourceMappingURL=createHooks.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRemoveHook.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRemoveHook.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validateNamespace.js */ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js"); -/* harmony import */ var _validateHookName_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./validateHookName.js */ "./node_modules/@wordpress/hooks/build-module/validateHookName.js"); -/** - * Internal dependencies - */ - - -/** - * @callback RemoveHook - * Removes the specified callback (or all callbacks) from the hook with a given hookName - * and namespace. - * - * @param {string} hookName The name of the hook to modify. - * @param {string} namespace The unique namespace identifying the callback in the - * form `vendor/plugin/function`. - * - * @return {number | undefined} The number of callbacks removed. - */ - -/** - * Returns a function which, when invoked, will remove a specified hook or all - * hooks by the given name. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [removeAll=false] Whether to remove all callbacks for a hookName, - * without regard to namespace. Used to create - * `removeAll*` functions. - * - * @return {RemoveHook} Function that removes hooks. - */ - -function createRemoveHook(hooks, storeKey) { - var removeAll = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function removeHook(hookName, namespace) { - var hooksStore = hooks[storeKey]; - - if (!(0,_validateHookName_js__WEBPACK_IMPORTED_MODULE_1__["default"])(hookName)) { - return; - } - - if (!removeAll && !(0,_validateNamespace_js__WEBPACK_IMPORTED_MODULE_0__["default"])(namespace)) { - return; - } // Bail if no hooks exist by this name - - - if (!hooksStore[hookName]) { - return 0; - } - - var handlersRemoved = 0; - - if (removeAll) { - handlersRemoved = hooksStore[hookName].handlers.length; - hooksStore[hookName] = { - runs: hooksStore[hookName].runs, - handlers: [] - }; - } else { - // Try to find the specified callback to remove. - var handlers = hooksStore[hookName].handlers; - - var _loop = function _loop(i) { - if (handlers[i].namespace === namespace) { - handlers.splice(i, 1); - handlersRemoved++; // This callback may also be part of a hook that is - // currently executing. If the callback we're removing - // comes after the current callback, there's no problem; - // otherwise we need to decrease the execution index of any - // other runs by 1 to account for the removed element. - - hooksStore.__current.forEach(function (hookInfo) { - if (hookInfo.name === hookName && hookInfo.currentIndex >= i) { - hookInfo.currentIndex--; - } - }); - } - }; - - for (var i = handlers.length - 1; i >= 0; i--) { - _loop(i); - } - } - - if (hookName !== 'hookRemoved') { - hooks.doAction('hookRemoved', hookName, namespace); - } - - return handlersRemoved; - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRemoveHook); -//# sourceMappingURL=createRemoveHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/createRunHook.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/createRunHook.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/toConsumableArray */ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js"); - - -/** - * Returns a function which, when invoked, will execute all callbacks - * registered to a hook of the specified type, optionally returning the final - * value of the call chain. - * - * @param {import('.').Hooks} hooks Hooks instance. - * @param {import('.').StoreKey} storeKey - * @param {boolean} [returnFirstArg=false] Whether each hook callback is expected to - * return its first argument. - * - * @return {(hookName:string, ...args: unknown[]) => unknown} Function that runs hook callbacks. - */ -function createRunHook(hooks, storeKey) { - var returnFirstArg = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false; - return function runHooks(hookName) { - var hooksStore = hooks[storeKey]; - - if (!hooksStore[hookName]) { - hooksStore[hookName] = { - handlers: [], - runs: 0 - }; - } - - hooksStore[hookName].runs++; - var handlers = hooksStore[hookName].handlers; // The following code is stripped from production builds. - - if (true) { - // Handle any 'all' hooks registered. - if ('hookAdded' !== hookName && hooksStore.all) { - handlers.push.apply(handlers, (0,_babel_runtime_helpers_esm_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__["default"])(hooksStore.all.handlers)); - } - } - - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - if (!handlers || !handlers.length) { - return returnFirstArg ? args[0] : undefined; - } - - var hookInfo = { - name: hookName, - currentIndex: 0 - }; - - hooksStore.__current.push(hookInfo); - - while (hookInfo.currentIndex < handlers.length) { - var handler = handlers[hookInfo.currentIndex]; - var result = handler.callback.apply(null, args); - - if (returnFirstArg) { - args[0] = result; - } - - hookInfo.currentIndex++; - } - - hooksStore.__current.pop(); - - if (returnFirstArg) { - return args[0]; - } - }; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (createRunHook); -//# sourceMappingURL=createRunHook.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/index.js": -/*!*************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/index.js ***! - \*************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ actions: () => (/* binding */ actions), -/* harmony export */ addAction: () => (/* binding */ addAction), -/* harmony export */ addFilter: () => (/* binding */ addFilter), -/* harmony export */ applyFilters: () => (/* binding */ applyFilters), -/* harmony export */ createHooks: () => (/* reexport safe */ _createHooks__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ currentAction: () => (/* binding */ currentAction), -/* harmony export */ currentFilter: () => (/* binding */ currentFilter), -/* harmony export */ defaultHooks: () => (/* binding */ defaultHooks), -/* harmony export */ didAction: () => (/* binding */ didAction), -/* harmony export */ didFilter: () => (/* binding */ didFilter), -/* harmony export */ doAction: () => (/* binding */ doAction), -/* harmony export */ doingAction: () => (/* binding */ doingAction), -/* harmony export */ doingFilter: () => (/* binding */ doingFilter), -/* harmony export */ filters: () => (/* binding */ filters), -/* harmony export */ hasAction: () => (/* binding */ hasAction), -/* harmony export */ hasFilter: () => (/* binding */ hasFilter), -/* harmony export */ removeAction: () => (/* binding */ removeAction), -/* harmony export */ removeAllActions: () => (/* binding */ removeAllActions), -/* harmony export */ removeAllFilters: () => (/* binding */ removeAllFilters), -/* harmony export */ removeFilter: () => (/* binding */ removeFilter) -/* harmony export */ }); -/* harmony import */ var _createHooks__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createHooks */ "./node_modules/@wordpress/hooks/build-module/createHooks.js"); -/** - * Internal dependencies - */ - -/** @typedef {(...args: any[])=>any} Callback */ - -/** - * @typedef Handler - * @property {Callback} callback The callback - * @property {string} namespace The namespace - * @property {number} priority The namespace - */ - -/** - * @typedef Hook - * @property {Handler[]} handlers Array of handlers - * @property {number} runs Run counter - */ - -/** - * @typedef Current - * @property {string} name Hook name - * @property {number} currentIndex The index - */ - -/** - * @typedef {Record & {__current: Current[]}} Store - */ - -/** - * @typedef {'actions' | 'filters'} StoreKey - */ - -/** - * @typedef {import('./createHooks').Hooks} Hooks - */ - -var defaultHooks = (0,_createHooks__WEBPACK_IMPORTED_MODULE_0__["default"])(); -var addAction = defaultHooks.addAction, - addFilter = defaultHooks.addFilter, - removeAction = defaultHooks.removeAction, - removeFilter = defaultHooks.removeFilter, - hasAction = defaultHooks.hasAction, - hasFilter = defaultHooks.hasFilter, - removeAllActions = defaultHooks.removeAllActions, - removeAllFilters = defaultHooks.removeAllFilters, - doAction = defaultHooks.doAction, - applyFilters = defaultHooks.applyFilters, - currentAction = defaultHooks.currentAction, - currentFilter = defaultHooks.currentFilter, - doingAction = defaultHooks.doingAction, - doingFilter = defaultHooks.doingFilter, - didAction = defaultHooks.didAction, - didFilter = defaultHooks.didFilter, - actions = defaultHooks.actions, - filters = defaultHooks.filters; - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateHookName.js": -/*!************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateHookName.js ***! - \************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a hookName string. - * - * @param {string} hookName The hook name to validate. Should be a non empty string containing - * only numbers, letters, dashes, periods and underscores. Also, - * the hook name cannot begin with `__`. - * - * @return {boolean} Whether the hook name is valid. - */ -function validateHookName(hookName) { - if ('string' !== typeof hookName || '' === hookName) { - // eslint-disable-next-line no-console - console.error('The hook name must be a non-empty string.'); - return false; - } - - if (/^__/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name cannot begin with `__`.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.-]*$/.test(hookName)) { - // eslint-disable-next-line no-console - console.error('The hook name can only contain numbers, letters, dashes, periods and underscores.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateHookName); -//# sourceMappingURL=validateHookName.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/hooks/build-module/validateNamespace.js": -/*!*************************************************************************!*\ - !*** ./node_modules/@wordpress/hooks/build-module/validateNamespace.js ***! - \*************************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Validate a namespace string. - * - * @param {string} namespace The namespace to validate - should take the form - * `vendor/plugin/function`. - * - * @return {boolean} Whether the namespace is valid. - */ -function validateNamespace(namespace) { - if ('string' !== typeof namespace || '' === namespace) { - // eslint-disable-next-line no-console - console.error('The namespace must be a non-empty string.'); - return false; - } - - if (!/^[a-zA-Z][a-zA-Z0-9_.\-\/]*$/.test(namespace)) { - // eslint-disable-next-line no-console - console.error('The namespace can only contain numbers, letters, dashes, periods, underscores and slashes.'); - return false; - } - - return true; -} - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (validateNamespace); -//# sourceMappingURL=validateNamespace.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/create-i18n.js": -/*!******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/create-i18n.js ***! - \******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createI18n: () => (/* binding */ createI18n) -/* harmony export */ }); -/* harmony import */ var _babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js"); -/* harmony import */ var tannin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! tannin */ "./node_modules/tannin/index.js"); - - -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_esm_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - -/** - * External dependencies - */ - -/** - * @typedef {Record} LocaleData - */ - -/** - * Default locale data to use for Tannin domain when not otherwise provided. - * Assumes an English plural forms expression. - * - * @type {LocaleData} - */ - -var DEFAULT_LOCALE_DATA = { - '': { - /** @param {number} n */ - plural_forms: function plural_forms(n) { - return n === 1 ? 0 : 1; - } - } -}; -/* - * Regular expression that matches i18n hooks like `i18n.gettext`, `i18n.ngettext`, - * `i18n.gettext_domain` or `i18n.ngettext_with_context` or `i18n.has_translation`. - */ - -var I18N_HOOK_REGEXP = /^i18n\.(n?gettext|has_translation)(_|$)/; -/** - * @typedef {(domain?: string) => LocaleData} GetLocaleData - * - * Returns locale data by domain in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} SetLocaleData - * - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** - * @typedef {(data?: LocaleData, domain?: string) => void} ResetLocaleData - * - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - */ - -/** @typedef {() => void} SubscribeCallback */ - -/** @typedef {() => void} UnsubscribeCallback */ - -/** - * @typedef {(callback: SubscribeCallback) => UnsubscribeCallback} Subscribe - * - * Subscribes to changes of locale data - */ - -/** - * @typedef {(domain?: string) => string} GetFilterDomain - * Retrieve the domain to use when calling domain-specific filters. - */ - -/** - * @typedef {(text: string, domain?: string) => string} __ - * - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - */ - -/** - * @typedef {(text: string, context: string, domain?: string) => string} _x - * - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, domain?: string) => string} _n - * - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - */ - -/** - * @typedef {(single: string, plural: string, number: number, context: string, domain?: string) => string} _nx - * - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - */ - -/** - * @typedef {() => boolean} IsRtl - * - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - */ - -/** - * @typedef {(single: string, context?: string, domain?: string) => boolean} HasTranslation - * - * Check if there is a translation for a given string in singular form. - */ - -/** @typedef {import('@wordpress/hooks').Hooks} Hooks */ - -/** - * An i18n instance - * - * @typedef I18n - * @property {GetLocaleData} getLocaleData Returns locale data by domain in a Jed-formatted JSON object shape. - * @property {SetLocaleData} setLocaleData Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * @property {ResetLocaleData} resetLocaleData Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * @property {Subscribe} subscribe Subscribes to changes of Tannin locale data. - * @property {__} __ Retrieve the translation of text. - * @property {_x} _x Retrieve translated string with gettext context. - * @property {_n} _n Translates and retrieves the singular or plural form based on the supplied - * number. - * @property {_nx} _nx Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * @property {IsRtl} isRTL Check if current locale is RTL. - * @property {HasTranslation} hasTranslation Check if there is a translation for a given string. - */ - -/** - * Create an i18n instance - * - * @param {LocaleData} [initialData] Locale data configuration. - * @param {string} [initialDomain] Domain for which configuration applies. - * @param {Hooks} [hooks] Hooks implementation. - * @return {I18n} I18n instance - */ - -var createI18n = function createI18n(initialData, initialDomain, hooks) { - /** - * The underlying instance of Tannin to which exported functions interface. - * - * @type {Tannin} - */ - var tannin = new tannin__WEBPACK_IMPORTED_MODULE_1__["default"]({}); - var listeners = new Set(); - - var notifyListeners = function notifyListeners() { - listeners.forEach(function (listener) { - return listener(); - }); - }; - /** - * Subscribe to changes of locale data. - * - * @param {SubscribeCallback} callback Subscription callback. - * @return {UnsubscribeCallback} Unsubscribe callback. - */ - - - var subscribe = function subscribe(callback) { - listeners.add(callback); - return function () { - return listeners.delete(callback); - }; - }; - /** @type {GetLocaleData} */ - - - var getLocaleData = function getLocaleData() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return tannin.data[domain]; - }; - /** - * @param {LocaleData} [data] - * @param {string} [domain] - */ - - - var doSetLocaleData = function doSetLocaleData(data) { - var domain = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - tannin.data[domain] = _objectSpread(_objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA), tannin.data[domain]), data); // Populate default domain configuration (supported locale date which omits - // a plural forms expression). - - tannin.data[domain][''] = _objectSpread(_objectSpread({}, DEFAULT_LOCALE_DATA['']), tannin.data[domain]['']); - }; - /** @type {SetLocaleData} */ - - - var setLocaleData = function setLocaleData(data, domain) { - doSetLocaleData(data, domain); - notifyListeners(); - }; - /** @type {ResetLocaleData} */ - - - var resetLocaleData = function resetLocaleData(data, domain) { - // Reset all current Tannin locale data. - tannin.data = {}; // Reset cached plural forms functions cache. - - tannin.pluralForms = {}; - setLocaleData(data, domain); - }; - /** - * Wrapper for Tannin's `dcnpgettext`. Populates default locale data if not - * otherwise previously assigned. - * - * @param {string|undefined} domain Domain to retrieve the translated text. - * @param {string|undefined} context Context information for the translators. - * @param {string} single Text to translate if non-plural. Used as - * fallback return value on a caught error. - * @param {string} [plural] The text to be used if the number is - * plural. - * @param {number} [number] The number to compare against to use - * either the singular or plural form. - * - * @return {string} The translated string. - */ - - - var dcnpgettext = function dcnpgettext() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - var context = arguments.length > 1 ? arguments[1] : undefined; - var single = arguments.length > 2 ? arguments[2] : undefined; - var plural = arguments.length > 3 ? arguments[3] : undefined; - var number = arguments.length > 4 ? arguments[4] : undefined; - - if (!tannin.data[domain]) { - // use `doSetLocaleData` to set silently, without notifying listeners - doSetLocaleData(undefined, domain); - } - - return tannin.dcnpgettext(domain, context, single, plural, number); - }; - /** @type {GetFilterDomain} */ - - - var getFilterDomain = function getFilterDomain() { - var domain = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'default'; - return domain; - }; - /** @type {__} */ - - - var __ = function __(text, domain) { - var translation = dcnpgettext(domain, undefined, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext', translation, text, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_' + getFilterDomain(domain), translation, text, domain) - ); - }; - /** @type {_x} */ - - - var _x = function _x(text, context, domain) { - var translation = dcnpgettext(domain, context, text); - - if (!hooks) { - return translation; - } - /** - * Filters text with its translation based on context information. - * - * @param {string} translation Translated text. - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context', translation, text, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.gettext_with_context_' + getFilterDomain(domain), translation, text, context, domain) - ); - }; - /** @type {_n} */ - - - var _n = function _n(single, plural, number, domain) { - var translation = dcnpgettext(domain, undefined, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext', translation, single, plural, number, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_' + getFilterDomain(domain), translation, single, plural, number, domain) - ); - }; - /** @type {_nx} */ - - - var _nx = function _nx(single, plural, number, context, domain) { - var translation = dcnpgettext(domain, context, single, plural, number); - - if (!hooks) { - return translation; - } - /** - * Filters the singular or plural form of a string with gettext context. - * - * @param {string} translation Translated text. - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {string} number The number to compare against to use either the singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - - - translation = - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context', translation, single, plural, number, context, domain); - return ( - /** @type {string} */ - - /** @type {*} */ - hooks.applyFilters('i18n.ngettext_with_context_' + getFilterDomain(domain), translation, single, plural, number, context, domain) - ); - }; - /** @type {IsRtl} */ - - - var isRTL = function isRTL() { - return 'rtl' === _x('ltr', 'text direction'); - }; - /** @type {HasTranslation} */ - - - var hasTranslation = function hasTranslation(single, context, domain) { - var _tannin$data, _tannin$data2; - - var key = context ? context + "\x04" + single : single; - var result = !!((_tannin$data = tannin.data) !== null && _tannin$data !== void 0 && (_tannin$data2 = _tannin$data[domain !== null && domain !== void 0 ? domain : 'default']) !== null && _tannin$data2 !== void 0 && _tannin$data2[key]); - - if (hooks) { - /** - * Filters the presence of a translation in the locale data. - * - * @param {boolean} hasTranslation Whether the translation is present or not.. - * @param {string} single The singular form of the translated text (used as key in locale data) - * @param {string} context Context information for the translators. - * @param {string} domain Text domain. Unique identifier for retrieving translated strings. - */ - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation', result, single, context, domain); - result = - /** @type { boolean } */ - - /** @type {*} */ - hooks.applyFilters('i18n.has_translation_' + getFilterDomain(domain), result, single, context, domain); - } - - return result; - }; - - if (initialData) { - setLocaleData(initialData, initialDomain); - } - - if (hooks) { - /** - * @param {string} hookName - */ - var onHookAddedOrRemoved = function onHookAddedOrRemoved(hookName) { - if (I18N_HOOK_REGEXP.test(hookName)) { - notifyListeners(); - } - }; - - hooks.addAction('hookAdded', 'core/i18n', onHookAddedOrRemoved); - hooks.addAction('hookRemoved', 'core/i18n', onHookAddedOrRemoved); - } - - return { - getLocaleData: getLocaleData, - setLocaleData: setLocaleData, - resetLocaleData: resetLocaleData, - subscribe: subscribe, - __: __, - _x: _x, - _n: _n, - _nx: _nx, - isRTL: isRTL, - hasTranslation: hasTranslation - }; -}; -//# sourceMappingURL=create-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/default-i18n.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/default-i18n.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* binding */ __), -/* harmony export */ _n: () => (/* binding */ _n), -/* harmony export */ _nx: () => (/* binding */ _nx), -/* harmony export */ _x: () => (/* binding */ _x), -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), -/* harmony export */ getLocaleData: () => (/* binding */ getLocaleData), -/* harmony export */ hasTranslation: () => (/* binding */ hasTranslation), -/* harmony export */ isRTL: () => (/* binding */ isRTL), -/* harmony export */ resetLocaleData: () => (/* binding */ resetLocaleData), -/* harmony export */ setLocaleData: () => (/* binding */ setLocaleData), -/* harmony export */ subscribe: () => (/* binding */ subscribe) -/* harmony export */ }); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/hooks */ "./node_modules/@wordpress/hooks/build-module/index.js"); -/** - * Internal dependencies - */ - -/** - * WordPress dependencies - */ - - -var i18n = (0,_create_i18n__WEBPACK_IMPORTED_MODULE_0__.createI18n)(undefined, undefined, _wordpress_hooks__WEBPACK_IMPORTED_MODULE_1__.defaultHooks); -/** - * Default, singleton instance of `I18n`. - */ - -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (i18n); -/* - * Comments in this file are duplicated from ./i18n due to - * https://github.com/WordPress/gutenberg/pull/20318#issuecomment-590837722 - */ - -/** - * @typedef {import('./create-i18n').LocaleData} LocaleData - * @typedef {import('./create-i18n').SubscribeCallback} SubscribeCallback - * @typedef {import('./create-i18n').UnsubscribeCallback} UnsubscribeCallback - */ - -/** - * Returns locale data by domain in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {string} [domain] Domain for which to get the data. - * @return {LocaleData} Locale data. - */ - -var getLocaleData = i18n.getLocaleData.bind(i18n); -/** - * Merges locale data into the Tannin instance by domain. Accepts data in a - * Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var setLocaleData = i18n.setLocaleData.bind(i18n); -/** - * Resets all current Tannin instance locale data and sets the specified - * locale data for the domain. Accepts data in a Jed-formatted JSON object shape. - * - * @see http://messageformat.github.io/Jed/ - * - * @param {LocaleData} [data] Locale data configuration. - * @param {string} [domain] Domain for which configuration applies. - */ - -var resetLocaleData = i18n.resetLocaleData.bind(i18n); -/** - * Subscribes to changes of locale data - * - * @param {SubscribeCallback} callback Subscription callback - * @return {UnsubscribeCallback} Unsubscribe callback - */ - -var subscribe = i18n.subscribe.bind(i18n); -/** - * Retrieve the translation of text. - * - * @see https://developer.wordpress.org/reference/functions/__/ - * - * @param {string} text Text to translate. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated text. - */ - -var __ = i18n.__.bind(i18n); -/** - * Retrieve translated string with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_x/ - * - * @param {string} text Text to translate. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} Translated context string without pipe. - */ - -var _x = i18n._x.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number. - * - * @see https://developer.wordpress.org/reference/functions/_n/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _n = i18n._n.bind(i18n); -/** - * Translates and retrieves the singular or plural form based on the supplied - * number, with gettext context. - * - * @see https://developer.wordpress.org/reference/functions/_nx/ - * - * @param {string} single The text to be used if the number is singular. - * @param {string} plural The text to be used if the number is plural. - * @param {number} number The number to compare against to use either the - * singular or plural form. - * @param {string} context Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * - * @return {string} The translated singular or plural form. - */ - -var _nx = i18n._nx.bind(i18n); -/** - * Check if current locale is RTL. - * - * **RTL (Right To Left)** is a locale property indicating that text is written from right to left. - * For example, the `he` locale (for Hebrew) specifies right-to-left. Arabic (ar) is another common - * language written RTL. The opposite of RTL, LTR (Left To Right) is used in other languages, - * including English (`en`, `en-US`, `en-GB`, etc.), Spanish (`es`), and French (`fr`). - * - * @return {boolean} Whether locale is RTL. - */ - -var isRTL = i18n.isRTL.bind(i18n); -/** - * Check if there is a translation for a given string (in singular form). - * - * @param {string} single Singular form of the string to look up. - * @param {string} [context] Context information for the translators. - * @param {string} [domain] Domain to retrieve the translated text. - * @return {boolean} Whether the translation exists or not. - */ - -var hasTranslation = i18n.hasTranslation.bind(i18n); -//# sourceMappingURL=default-i18n.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/index.js": -/*!************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/index.js ***! - \************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ __: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.__), -/* harmony export */ _n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._n), -/* harmony export */ _nx: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._nx), -/* harmony export */ _x: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__._x), -/* harmony export */ createI18n: () => (/* reexport safe */ _create_i18n__WEBPACK_IMPORTED_MODULE_1__.createI18n), -/* harmony export */ defaultI18n: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ getLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.getLocaleData), -/* harmony export */ hasTranslation: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.hasTranslation), -/* harmony export */ isRTL: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.isRTL), -/* harmony export */ resetLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.resetLocaleData), -/* harmony export */ setLocaleData: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.setLocaleData), -/* harmony export */ sprintf: () => (/* reexport safe */ _sprintf__WEBPACK_IMPORTED_MODULE_0__.sprintf), -/* harmony export */ subscribe: () => (/* reexport safe */ _default_i18n__WEBPACK_IMPORTED_MODULE_2__.subscribe) -/* harmony export */ }); -/* harmony import */ var _sprintf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./sprintf */ "./node_modules/@wordpress/i18n/build-module/sprintf.js"); -/* harmony import */ var _create_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./create-i18n */ "./node_modules/@wordpress/i18n/build-module/create-i18n.js"); -/* harmony import */ var _default_i18n__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./default-i18n */ "./node_modules/@wordpress/i18n/build-module/default-i18n.js"); - - - -//# sourceMappingURL=index.js.map - -/***/ }), - -/***/ "./node_modules/@wordpress/i18n/build-module/sprintf.js": -/*!**************************************************************!*\ - !*** ./node_modules/@wordpress/i18n/build-module/sprintf.js ***! - \**************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ sprintf: () => (/* binding */ sprintf) -/* harmony export */ }); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! memize */ "./node_modules/memize/index.js"); -/* harmony import */ var memize__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(memize__WEBPACK_IMPORTED_MODULE_0__); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! sprintf-js */ "./node_modules/sprintf-js/src/sprintf.js"); -/* harmony import */ var sprintf_js__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(sprintf_js__WEBPACK_IMPORTED_MODULE_1__); -/** - * External dependencies - */ - - -/** - * Log to console, once per message; or more precisely, per referentially equal - * argument set. Because Jed throws errors, we log these to the console instead - * to avoid crashing the application. - * - * @param {...*} args Arguments to pass to `console.error` - */ - -var logErrorOnce = memize__WEBPACK_IMPORTED_MODULE_0___default()(console.error); // eslint-disable-line no-console - -/** - * Returns a formatted string. If an error occurs in applying the format, the - * original format string is returned. - * - * @param {string} format The format of the string to generate. - * @param {...*} args Arguments to apply to the format. - * - * @see https://www.npmjs.com/package/sprintf-js - * - * @return {string} The formatted string. - */ - -function sprintf(format) { - try { - for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - args[_key - 1] = arguments[_key]; - } - - return sprintf_js__WEBPACK_IMPORTED_MODULE_1___default().sprintf.apply((sprintf_js__WEBPACK_IMPORTED_MODULE_1___default()), [format].concat(args)); - } catch (error) { - logErrorOnce('sprintf error: \n\n' + error.toString()); - return format; - } -} -//# sourceMappingURL=sprintf.js.map - -/***/ }), - -/***/ "./js/src/core/constants.js": -/*!**********************************!*\ - !*** ./js/src/core/constants.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKED_CLASS: () => (/* binding */ CHECKED_CLASS), -/* harmony export */ CURRENT_CLASS: () => (/* binding */ CURRENT_CLASS), -/* harmony export */ DISABLED_CLASS: () => (/* binding */ DISABLED_CLASS), -/* harmony export */ HIDDEN_CLASS: () => (/* binding */ HIDDEN_CLASS), -/* harmony export */ HIDE_JS_CLASS: () => (/* binding */ HIDE_JS_CLASS), -/* harmony export */ HOOKS: () => (/* binding */ HOOKS), -/* harmony export */ PLUGIN_URL: () => (/* binding */ PLUGIN_URL), -/* harmony export */ SINGLE_SETTINGS_CLASS: () => (/* binding */ SINGLE_SETTINGS_CLASS), -/* harmony export */ nonce: () => (/* binding */ nonce) -/* harmony export */ }); -var _window$frmGlobal = window.frmGlobal, - PLUGIN_URL = _window$frmGlobal.url, - nonce = _window$frmGlobal.nonce; - -var HIDDEN_CLASS = 'frm_hidden'; -var DISABLED_CLASS = 'frm_disabled'; -var HIDE_JS_CLASS = 'frm-hide-js'; -var CURRENT_CLASS = 'frm-current'; -var CHECKED_CLASS = 'frm-checked'; -var SINGLE_SETTINGS_CLASS = 'frm-single-settings'; -var HOOKS = { - SHOW_FIELD_SETTINGS: 'frmShowedFieldSettings' -}; - -/***/ }), - -/***/ "./js/src/core/factory/createPageElements.js": -/*!***************************************************!*\ - !*** ./js/src/core/factory/createPageElements.js ***! - \***************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* binding */ createPageElements) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page elements manager. - * - * @param {Object} [initialElements={}] An object containing initial DOM elements. - * @throws {Error} Throws an error if the `initialElements` is not an object. - * @return {Object} An object with methods to get and add elements. - */ -function createPageElements() { - var initialElements = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialElements) !== 'object' || initialElements === null) { - throw new Error('createPageElements: initialElements must be a non-null object'); - } - var elements = initialElements; - - /** - * Retrieve the initialized essential DOM elements. - * - * @return {Object} The initialized elements object. - */ - function getElements() { - return elements; - } - - /** - * Add new elements to the elements object. - * - * @param {Object} newElements An object containing new elements to be added. - * @throws {Error} Throws an error if the `newElements` is not a non-null object. - * @return {void} Updates the elements object by merging the new elements into it. - */ - function addElements(newElements) { - if (_typeof(newElements) !== 'object' || newElements === null) { - throw new Error('addElements: newElements must be a non-null object'); - } - elements = _objectSpread(_objectSpread({}, elements), newElements); - } - return { - getElements: getElements, - addElements: addElements - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/createPageState.js": -/*!************************************************!*\ - !*** ./js/src/core/factory/createPageState.js ***! - \************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageState: () => (/* binding */ createPageState) -/* harmony export */ }); -function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } -function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -/** - * Creates a page state manager. - * - * @param {Object} [initialState={}] An object containing the initial state. - * @throws {Error} Throws an error if the `initialState` is not a plain object. - * @return {Object} An object with methods to initialize, get, and set the page state. - */ -function createPageState() { - var initialState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - if (_typeof(initialState) !== 'object' || initialState === null) { - throw new Error('createPageState: initialState must be a non-null object'); - } - var state = initialState; - - /** - * Returns the current page state. - * - * @return {Object|null} The current state of the page or null if not initialized. - */ - var getState = function getState() { - return state; - }; - - /** - * Returns a specific property from the current page state. - * - * @param {string} propertyName The name of the property to retrieve. - * @return {*} The value of the specified property, or null if it doesn't exist. - */ - var getSingleState = function getSingleState(propertyName) { - var value = Reflect.get(state, propertyName); - - // We convert `undefined` to `null` for a consistent API. - // This makes it easier for users to handle the results since all missing properties return `null`. - return value === undefined ? null : value; - }; - - /** - * Updates the page state with new values. - * - * @param {Object} newState The new values to update the state with. - * @throws {Error} Throws an error if `newState` is not a plain object. - * @return {void} - */ - var setState = function setState(newState) { - if (_typeof(newState) !== 'object' || newState === null) { - throw new Error('setState: newState must be a non-null object'); - } - state = _objectSpread(_objectSpread({}, state), newState); - }; - - /** - * Updates a specific property in the page state with a new value. - * - * @param {string} propertyName The name of the property to update. - * @param {*} value The new value to set for the property. - * @return {void} - */ - var setSingleState = function setSingleState(propertyName, value) { - if (Reflect.has(state, propertyName)) { - Reflect.set(state, propertyName, value); - } - }; - return { - getState: getState, - getSingleState: getSingleState, - setState: setState, - setSingleState: setSingleState - }; -} - -/***/ }), - -/***/ "./js/src/core/factory/index.js": -/*!**************************************!*\ - !*** ./js/src/core/factory/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ createPageElements: () => (/* reexport safe */ _createPageElements__WEBPACK_IMPORTED_MODULE_0__.createPageElements), -/* harmony export */ createPageState: () => (/* reexport safe */ _createPageState__WEBPACK_IMPORTED_MODULE_1__.createPageState) -/* harmony export */ }); -/* harmony import */ var _createPageElements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createPageElements */ "./js/src/core/factory/createPageElements.js"); -/* harmony import */ var _createPageState__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./createPageState */ "./js/src/core/factory/createPageState.js"); - - - -/***/ }), - -/***/ "./js/src/core/utils/animation.js": -/*!****************************************!*\ - !*** ./js/src/core/utils/animation.js ***! - \****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ frmAnimate: () => (/* binding */ frmAnimate) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); } -function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } } -function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -var frmAnimate = /*#__PURE__*/function () { - /** - * Construct frmAnimate - * - * @param {Element|Element[]} elements The elements to animate. - * @param {'default'|'cascade'|'cascade-3d'} type The animation type: default | cascade | cascade-3d - */ - function frmAnimate(elements) { - var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'default'; - _classCallCheck(this, frmAnimate); - this.elements = elements; - this.type = type; - this.prepareElements(); - } - - /** - * Init animation - fadeIn. - * Requires this.type = 'default'; - * ex: new frmAnimate( elements ).fadeIn(); - */ - return _createClass(frmAnimate, [{ - key: "fadeIn", - value: function fadeIn() { - var _this = this; - this.applyStyleToElements(function (element) { - element.classList.add('frm-fadein-up'); - element.addEventListener('animationend', function () { - _this.resetOpacity(); - element.classList.remove('frm-fadein-up'); - }, { - once: true - }); - }); - } - - /** - * Init animation - cascadeFadeIn. - * Requires this.type = 'cascade'|'cascade-3d'; - * ex: new frmAnimate( elements, 'cascade' ).cascadeFadeIn(); - * new frmAnimate( elements, 'cascade-3d' ).cascadeFadeIn(); - * - * @param {number} delay The transition delay value. - */ - }, { - key: "cascadeFadeIn", - value: function cascadeFadeIn() { - var _this2 = this; - var delay = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0.03; - setTimeout(function () { - _this2.applyStyleToElements(function (element, index) { - element.classList.remove('frm-animate'); - element.style.transitionDelay = "".concat((index + 1) * delay, "s"); - }); - }, 200); - } - }, { - key: "prepareElements", - value: function prepareElements() { - var _this3 = this; - this.applyStyleToElements(function (element) { - if ('default' === _this3.type) { - element.style.opacity = '0.0'; - } - if ('cascade' === _this3.type) { - element.classList.add('frm-init-cascade-animation'); - } - if ('cascade-3d' === _this3.type) { - element.classList.add('frm-init-fadein-3d'); - } - element.classList.add('frm-animate'); - }); - } - }, { - key: "resetOpacity", - value: function resetOpacity() { - this.applyStyleToElements(function (element) { - return element.style.opacity = '1.0'; - }); - } - }, { - key: "applyStyleToElements", - value: function applyStyleToElements(callback) { - if (this.elements instanceof Element) { - callback(this.elements, 0); - return; - } - if (0 < this.elements.length) { - this.elements.forEach(function (element, index) { - return callback(element, index); - }); - } - } - }]); -}(); - -/***/ }), - -/***/ "./js/src/core/utils/async.js": -/*!************************************!*\ - !*** ./js/src/core/utils/async.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addToRequestQueue: () => (/* binding */ addToRequestQueue) -/* harmony export */ }); -// Initialize lastPromise with a resolved promise as the starting point for the queue -var lastPromise = Promise.resolve(); - -/** - * Adds a task to the request queue. - * - * @param {function(): Promise} task A function that returns a promise. - * @return {Promise} The new last promise in the queue. - */ -var addToRequestQueue = function addToRequestQueue(task) { - return lastPromise = lastPromise.then(task).catch(task); -}; - -/***/ }), - -/***/ "./js/src/core/utils/error.js": -/*!************************************!*\ - !*** ./js/src/core/utils/error.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ showFormError: () => (/* binding */ showFormError) -/* harmony export */ }); -/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! . */ "./js/src/core/utils/index.js"); -/** - * Internal dependencies - */ - - -/** - * Displays form validation error messages. - * - * @param {string} inputId The ID selector for the input field with the error. - * @param {string} errorId The ID selector for the error message display element. - * @param {string} type The categorization of the error (e.g., "invalid", "empty"). - * @param {string} [message] Optional. The specific error message to display. - * @return {void} - */ -var showFormError = function showFormError(inputId, errorId, type, message) { - var inputElement = document.querySelector(inputId); - var errorElement = document.querySelector(errorId); - if (!inputElement || !errorElement) { - console.warn('showFormError: Unable to find input or error element.'); - return; - } - - // If a message is provided, update the span element's text that matches the error type - if (message) { - var span = errorElement.querySelector("span[frm-error=\"".concat(type, "\"]")); - if (span) { - span.textContent = message; - } - } - - // Assign the error type and make the error message visible - errorElement.setAttribute('frm-error', type); - (0,___WEBPACK_IMPORTED_MODULE_0__.show)(errorElement); - - // Hide the error message when the user starts typing in the faulty input field - inputElement.addEventListener('keyup', function () { - (0,___WEBPACK_IMPORTED_MODULE_0__.hide)(errorElement); - }, { - once: true - }); -}; - -/***/ }), - -/***/ "./js/src/core/utils/globalModules.js": -/*!********************************************!*\ - !*** ./js/src/core/utils/globalModules.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* binding */ a), -/* harmony export */ bold: () => (/* binding */ bold), -/* harmony export */ button: () => (/* binding */ button), -/* harmony export */ div: () => (/* binding */ div), -/* harmony export */ doJsonPost: () => (/* binding */ doJsonPost), -/* harmony export */ documentOn: () => (/* binding */ documentOn), -/* harmony export */ footerButton: () => (/* binding */ footerButton), -/* harmony export */ img: () => (/* binding */ img), -/* harmony export */ maybeCreateModal: () => (/* binding */ maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* binding */ onClickPreventDefault), -/* harmony export */ p: () => (/* binding */ p), -/* harmony export */ span: () => (/* binding */ span), -/* harmony export */ svg: () => (/* binding */ svg), -/* harmony export */ tag: () => (/* binding */ tag) -/* harmony export */ }); -var _frmDom = frmDom, - div = _frmDom.div, - span = _frmDom.span, - tag = _frmDom.tag, - a = _frmDom.a, - img = _frmDom.img, - svg = _frmDom.svg; -var _frmDom$modal = frmDom.modal, - maybeCreateModal = _frmDom$modal.maybeCreateModal, - footerButton = _frmDom$modal.footerButton; -var _frmDom$util = frmDom.util, - onClickPreventDefault = _frmDom$util.onClickPreventDefault, - documentOn = _frmDom$util.documentOn; -var doJsonPost = frmDom.ajax.doJsonPost; -var p = function p(args) { - return tag('p', args); -}; -var bold = function bold(args) { - return tag('strong', args); -}; -var button = function button(args) { - return tag('button', args); -}; - - -/***/ }), - -/***/ "./js/src/core/utils/index.js": -/*!************************************!*\ - !*** ./js/src/core/utils/index.js ***! - \************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ a: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.a), -/* harmony export */ addToRequestQueue: () => (/* reexport safe */ _async__WEBPACK_IMPORTED_MODULE_1__.addToRequestQueue), -/* harmony export */ bold: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.bold), -/* harmony export */ button: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.button), -/* harmony export */ div: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.div), -/* harmony export */ doJsonPost: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.doJsonPost), -/* harmony export */ documentOn: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.documentOn), -/* harmony export */ footerButton: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.footerButton), -/* harmony export */ frmAnimate: () => (/* reexport safe */ _animation__WEBPACK_IMPORTED_MODULE_0__.frmAnimate), -/* harmony export */ getQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.getQueryParam), -/* harmony export */ hasQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.hasQueryParam), -/* harmony export */ hide: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hide), -/* harmony export */ hideElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.hideElements), -/* harmony export */ img: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.img), -/* harmony export */ isEmptyObject: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isHTMLElement), -/* harmony export */ isValidEmail: () => (/* reexport safe */ _validation__WEBPACK_IMPORTED_MODULE_5__.isValidEmail), -/* harmony export */ isVisible: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.isVisible), -/* harmony export */ maybeCreateModal: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.maybeCreateModal), -/* harmony export */ onClickPreventDefault: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.onClickPreventDefault), -/* harmony export */ p: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.p), -/* harmony export */ removeParamFromHistory: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.removeQueryParam), -/* harmony export */ setQueryParam: () => (/* reexport safe */ _url__WEBPACK_IMPORTED_MODULE_4__.setQueryParam), -/* harmony export */ show: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.show), -/* harmony export */ showElements: () => (/* reexport safe */ _visibility__WEBPACK_IMPORTED_MODULE_6__.showElements), -/* harmony export */ showFormError: () => (/* reexport safe */ _error__WEBPACK_IMPORTED_MODULE_2__.showFormError), -/* harmony export */ span: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.span), -/* harmony export */ svg: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.svg), -/* harmony export */ tag: () => (/* reexport safe */ _globalModules__WEBPACK_IMPORTED_MODULE_3__.tag) -/* harmony export */ }); -/* harmony import */ var _animation__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./animation */ "./js/src/core/utils/animation.js"); -/* harmony import */ var _async__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./async */ "./js/src/core/utils/async.js"); -/* harmony import */ var _error__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./error */ "./js/src/core/utils/error.js"); -/* harmony import */ var _globalModules__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./globalModules */ "./js/src/core/utils/globalModules.js"); -/* harmony import */ var _url__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./url */ "./js/src/core/utils/url.js"); -/* harmony import */ var _validation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./validation */ "./js/src/core/utils/validation.js"); -/* harmony import */ var _visibility__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./visibility */ "./js/src/core/utils/visibility.js"); - - - - - - - - -/***/ }), - -/***/ "./js/src/core/utils/url.js": -/*!**********************************!*\ - !*** ./js/src/core/utils/url.js ***! - \**********************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ getQueryParam: () => (/* binding */ getQueryParam), -/* harmony export */ hasQueryParam: () => (/* binding */ hasQueryParam), -/* harmony export */ removeParamFromHistory: () => (/* binding */ removeParamFromHistory), -/* harmony export */ removeQueryParam: () => (/* binding */ removeQueryParam), -/* harmony export */ setQueryParam: () => (/* binding */ setQueryParam) -/* harmony export */ }); -function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } -function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } -function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } -function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } -/** - * Initializes URL and URLSearchParams objects from the current window's location - */ -var url = new URL(window.location.href); -var urlParams = url.searchParams; - -/** - * Gets the value of a specified query parameter from the current URL. - * - * @param {string} paramName The name of the query parameter to retrieve. - * @return {string|null} The value associated with the specified query parameter name, or null if not found. - */ -var getQueryParam = function getQueryParam(paramName) { - return urlParams.get(paramName); -}; - -/** - * Removes a query parameter from the current URL and returns the updated URL string. - * - * @param {string} paramName The name of the query parameter to remove. - * @return {string} The updated URL string. - */ -var removeQueryParam = function removeQueryParam(paramName) { - urlParams.delete(paramName); - url.search = urlParams.toString(); - return url.toString(); -}; - -/** - * Sets the value of a query parameter in the current URL and optionally updates the browser's history state. - * - * @param {string} paramName The name of the query parameter to set. - * @param {string} paramValue The value to set for the query parameter. - * @param {string} [updateMethod='pushState'] The method to use for updating the history state. Accepts 'pushState' or 'replaceState'. - * @return {string} The updated URL string. - */ -var setQueryParam = function setQueryParam(paramName, paramValue) { - var updateMethod = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'pushState'; - urlParams.set(paramName, paramValue); - url.search = urlParams.toString(); - if (['pushState', 'replaceState'].includes(updateMethod)) { - var state = _defineProperty({}, paramName, paramValue); - window.history[updateMethod](state, '', url); - } - return url.toString(); -}; - -/** - * Checks if a query parameter exists in the current URL. - * - * @param {string} paramName The name of the query parameter to check. - * @return {boolean} True if the query parameter exists, otherwise false. - */ -var hasQueryParam = function hasQueryParam(paramName) { - return urlParams.has(paramName); -}; - -/** - * Removes a query parameter and updates history with replaceState. - * - * @param {string} paramName The query parameter to remove. - * @return {void} - */ -var removeParamFromHistory = function removeParamFromHistory(paramName) { - return history.replaceState({}, '', removeQueryParam(paramName)); -}; - -/***/ }), - -/***/ "./js/src/core/utils/validation.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/validation.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ isEmptyObject: () => (/* binding */ isEmptyObject), -/* harmony export */ isHTMLElement: () => (/* binding */ isHTMLElement), -/* harmony export */ isValidEmail: () => (/* binding */ isValidEmail) -/* harmony export */ }); -/** - * Validates an email address using a regular expression. - * - * @param {string} email The email address to validate. - * @return {boolean} True if the email address is valid, otherwise false. - */ -var isValidEmail = function isValidEmail(email) { - return typeof email === 'string' ? /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/i.test(email) : false; -}; - -/** - * Validates if the given element is an instance of HTMLElement. - * - * @param {any} element Element to be checked. - * @return {boolean} True if it's an HTMLElement, otherwise false. - */ -var isHTMLElement = function isHTMLElement(element) { - return element instanceof HTMLElement || console.warn('Invalid argument: Element must be an instance of HTMLElement') || false; -}; - -/** - * Checks if the given object is empty. - * - * @param {Object} obj The object to check. - * @return {boolean} True if the object is empty, otherwise false. - */ -var isEmptyObject = function isEmptyObject(obj) { - return Object.keys(obj).length === 0 && obj.constructor === Object; -}; - -/***/ }), - -/***/ "./js/src/core/utils/visibility.js": -/*!*****************************************!*\ - !*** ./js/src/core/utils/visibility.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ hide: () => (/* binding */ hide), -/* harmony export */ hideElements: () => (/* binding */ hideElements), -/* harmony export */ isVisible: () => (/* binding */ isVisible), -/* harmony export */ show: () => (/* binding */ show), -/* harmony export */ showElements: () => (/* binding */ showElements) -/* harmony export */ }); -/* harmony import */ var core_constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/constants */ "./js/src/core/constants.js"); -/** - * Internal dependencies - */ - - -/** - * Shows specified elements by removing the hidden class. - * - * @param {Array} elements An array of elements to show. - * @return {void} - */ -var showElements = function showElements(elements) { - var _Array$from; - return (_Array$from = Array.from(elements)) === null || _Array$from === void 0 ? void 0 : _Array$from.forEach(function (element) { - return show(element); - }); -}; - -/** - * Hides specified elements by adding the hidden class. - * - * @param {Array} elements An array of elements to hide. - * @return {void} - */ -var hideElements = function hideElements(elements) { - var _Array$from2; - return (_Array$from2 = Array.from(elements)) === null || _Array$from2 === void 0 ? void 0 : _Array$from2.forEach(function (element) { - return hide(element); - }); -}; - -/** - * Removes the hidden class to show the element. - * - * @param {Element} element The element to show. - * @return {void} - */ -var show = function show(element) { - return element === null || element === void 0 ? void 0 : element.classList.remove(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Adds the hidden class to hide the element. - * - * @param {Element} element The element to hide. - * @return {void} - */ -var hide = function hide(element) { - return element === null || element === void 0 ? void 0 : element.classList.add(core_constants__WEBPACK_IMPORTED_MODULE_0__.HIDDEN_CLASS); -}; - -/** - * Checks if an element is visible. - * - * @param {HTMLElement} element The HTML element to check for visibility. - * @return {boolean} Returns true if the element is visible, otherwise false. - */ -var isVisible = function isVisible(element) { - var styles = window.getComputedStyle(element); - return styles.getPropertyValue('display') !== 'none'; -}; - -/***/ }), - -/***/ "./js/src/welcome-tour/elements/beginTourModalElement.js": -/*!***************************************************************!*\ - !*** ./js/src/welcome-tour/elements/beginTourModalElement.js ***! - \***************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ buildBeginTourModalElement: () => (/* binding */ buildBeginTourModalElement) -/* harmony export */ }); -/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/i18n */ "./node_modules/@wordpress/i18n/build-module/index.js"); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./elements */ "./js/src/welcome-tour/elements/elements.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../shared */ "./js/src/welcome-tour/shared/index.js"); -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - - - - -/** - * Build the begin tour modal element. - * - * @return {void} - */ -function buildBeginTourModalElement() { - addBeginTourModalToElements(createBeginTourModalElement()); -} - -/** - * Create and return the begin tour modal HTML element. - * - * @private - * @return {HTMLElement} The begin tour modal element. - */ -function createBeginTourModalElement() { - var beginTourModal = (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.maybeCreateModal)('frm_get_started_modal', { - title: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Get Started with Formidable Forms', 'formidable'), - content: (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.p)({ - className: 'frm-px-md', - text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Here\'s a quick checklist to help you set up and explore the key features of the plugin, so you can start building powerful forms in no time.', 'formidable') - }), - footer: (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.div)({ - className: 'frmcenter', - child: (0,core_utils__WEBPACK_IMPORTED_MODULE_1__.a)({ - className: 'button button-primary frm-button-primary', - href: _shared__WEBPACK_IMPORTED_MODULE_3__.TOUR_URL, - text: (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_0__.__)('Begin Tour', 'formidable') - }) - }), - width: _shared__WEBPACK_IMPORTED_MODULE_3__.MODAL_SIZE, - dialogClass: 'frm-fadein-up-back' - }); - beginTourModal.classList.add('frm_wrap', 'frm-welcome-tour-modal', 'frmcenter'); - return beginTourModal; -} - -/** - * Add the begin tour modal to the elements registry. - * - * @private - * @param {HTMLElement} beginTourModal The begin tour modal element. - * @return {void} - */ -function addBeginTourModalToElements(beginTourModal) { - if (!(0,_elements__WEBPACK_IMPORTED_MODULE_2__.getElements)().beginTourModal) { - (0,_elements__WEBPACK_IMPORTED_MODULE_2__.addElements)({ - beginTourModal: beginTourModal - }); - } -} - -/***/ }), - -/***/ "./js/src/welcome-tour/elements/elements.js": -/*!**************************************************!*\ - !*** ./js/src/welcome-tour/elements/elements.js ***! - \**************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* binding */ addElements), -/* harmony export */ getElements: () => (/* binding */ getElements) -/* harmony export */ }); -/* harmony import */ var core_factory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/factory */ "./js/src/core/factory/index.js"); -/** - * External dependencies - */ - -var elements; -var welcomeTour = document.getElementById('frm-welcome-tour'); -if (welcomeTour) { - elements = { - welcomeTour: welcomeTour, - checklist: welcomeTour.querySelector('.frm-checklist'), - dismiss: welcomeTour.querySelector('.frm-checklist__dismiss'), - spotlight: document.querySelector('.frm-welcome-tour-spotlight') - }; -} -var _createPageElements = (0,core_factory__WEBPACK_IMPORTED_MODULE_0__.createPageElements)(elements), - getElements = _createPageElements.getElements, - addElements = _createPageElements.addElements; - - -/***/ }), - -/***/ "./js/src/welcome-tour/elements/index.js": -/*!***********************************************!*\ - !*** ./js/src/welcome-tour/elements/index.js ***! - \***********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.addElements), -/* harmony export */ buildBeginTourModalElement: () => (/* reexport safe */ _beginTourModalElement__WEBPACK_IMPORTED_MODULE_1__.buildBeginTourModalElement), -/* harmony export */ getElements: () => (/* reexport safe */ _elements__WEBPACK_IMPORTED_MODULE_0__.getElements) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./elements */ "./js/src/welcome-tour/elements/elements.js"); -/* harmony import */ var _beginTourModalElement__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./beginTourModalElement */ "./js/src/welcome-tour/elements/beginTourModalElement.js"); - - - -/***/ }), - -/***/ "./js/src/welcome-tour/events/checklistEvents.js": -/*!*******************************************************!*\ - !*** ./js/src/welcome-tour/events/checklistEvents.js ***! - \*******************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); -/** - * Internal dependencies - */ - - -/** - * Adds events to the checklist. - * - * @return {void} - */ -function addChecklistEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_0__.getElements)(), - checklist = _getElements.checklist; - if (!checklist) { - return; - } - checklist.querySelector('.frm-checklist__header').addEventListener('click', function () { - return onChecklistHeaderClick(checklist); - }); -} - -/** - * Handles the checklist header click event. - * - * @private - * @param {HTMLElement} checklist The checklist element. - * @return {void} - */ -function onChecklistHeaderClick(checklist) { - checklist.classList.toggle('frm-checklist--collapsed'); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addChecklistEvents); - -/***/ }), - -/***/ "./js/src/welcome-tour/events/dismissEvents.js": -/*!*****************************************************!*\ - !*** ./js/src/welcome-tour/events/dismissEvents.js ***! - \*****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); -/** - * Internal dependencies - */ - - - -/** - * Adds events to the dismiss button. - * - * @return {void} - */ -function addDismissEvents() { - var _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - dismiss = _getElements.dismiss; - if (!dismiss) { - return; - } - dismiss.addEventListener('click', onDismissClick); -} - -/** - * Handles the dismiss button click event. - * - * @private - * @return {void} - */ -function onDismissClick() { - var _getElements2 = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), - welcomeTour = _getElements2.welcomeTour, - spotlight = _getElements2.spotlight; - welcomeTour === null || welcomeTour === void 0 || welcomeTour.remove(); - spotlight === null || spotlight === void 0 || spotlight.remove(); - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.doJsonPost)('dismiss_welcome_tour', new FormData()); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addDismissEvents); - -/***/ }), - -/***/ "./js/src/welcome-tour/events/index.js": -/*!*********************************************!*\ - !*** ./js/src/welcome-tour/events/index.js ***! - \*********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ addEventListeners: () => (/* binding */ addEventListeners) -/* harmony export */ }); -/* harmony import */ var _checklistEvents__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./checklistEvents */ "./js/src/welcome-tour/events/checklistEvents.js"); -/* harmony import */ var _dismissEvents__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./dismissEvents */ "./js/src/welcome-tour/events/dismissEvents.js"); -/* harmony import */ var _stylerUpdateButtonEvents__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./stylerUpdateButtonEvents */ "./js/src/welcome-tour/events/stylerUpdateButtonEvents.js"); - - - - -/** - * Attaches event listeners for handling user interactions. - * - * @return {void} - */ -function addEventListeners() { - (0,_checklistEvents__WEBPACK_IMPORTED_MODULE_0__["default"])(); - (0,_dismissEvents__WEBPACK_IMPORTED_MODULE_1__["default"])(); - (0,_stylerUpdateButtonEvents__WEBPACK_IMPORTED_MODULE_2__["default"])(); -} - -/***/ }), - -/***/ "./js/src/welcome-tour/events/stylerUpdateButtonEvents.js": -/*!****************************************************************!*\ - !*** ./js/src/welcome-tour/events/stylerUpdateButtonEvents.js ***! - \****************************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils */ "./js/src/welcome-tour/utils/index.js"); -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * Internal dependencies - */ - - - -/** - * Adds events to the styler update button. - * - * @return {void} - */ -function addStylerUpdateEvents() { - if ('formidable-styles' !== (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('page')) { - return; - } - (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.onClickPreventDefault)(document.getElementById('frm_submit_side_top'), onStylerUpdateClick); -} - -/** - * Handles the styler update button click event. - * - * @private - * @return {void} - */ -function onStylerUpdateClick() { - return _onStylerUpdateClick.apply(this, arguments); -} -function _onStylerUpdateClick() { - _onStylerUpdateClick = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() { - return _regenerator().w(function (_context) { - while (1) switch (_context.n) { - case 0: - _context.n = 1; - return (0,_utils__WEBPACK_IMPORTED_MODULE_1__.markStepAsCompleted)('style-form'); - case 1: - window.location.reload(); - case 2: - return _context.a(2); - } - }, _callee); - })); - return _onStylerUpdateClick.apply(this, arguments); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (addStylerUpdateEvents); - -/***/ }), - -/***/ "./js/src/welcome-tour/shared/constants.js": -/*!*************************************************!*\ - !*** ./js/src/welcome-tour/shared/constants.js ***! - \*************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKLIST_STEPS: () => (/* binding */ CHECKLIST_STEPS), -/* harmony export */ IS_DASHBOARD_PAGE: () => (/* binding */ IS_DASHBOARD_PAGE), -/* harmony export */ IS_WELCOME_TOUR_SEEN: () => (/* binding */ IS_WELCOME_TOUR_SEEN), -/* harmony export */ MODAL_SIZE: () => (/* binding */ MODAL_SIZE), -/* harmony export */ PREFIX: () => (/* binding */ PREFIX), -/* harmony export */ PROGRESS_BAR_PERCENT: () => (/* binding */ PROGRESS_BAR_PERCENT), -/* harmony export */ TOUR_URL: () => (/* binding */ TOUR_URL) -/* harmony export */ }); -var _window$frmWelcomeTou = window.frmWelcomeTourVars, - IS_DASHBOARD_PAGE = _window$frmWelcomeTou.IS_DASHBOARD_PAGE, - IS_WELCOME_TOUR_SEEN = _window$frmWelcomeTou.IS_WELCOME_TOUR_SEEN, - CHECKLIST_STEPS = _window$frmWelcomeTou.CHECKLIST_STEPS, - TOUR_URL = _window$frmWelcomeTou.TOUR_URL, - PROGRESS_BAR_PERCENT = _window$frmWelcomeTou.PROGRESS_BAR_PERCENT; - -var PREFIX = 'frm-welcome-tour'; -var MODAL_SIZE = '440px'; - -/***/ }), - -/***/ "./js/src/welcome-tour/shared/index.js": -/*!*********************************************!*\ - !*** ./js/src/welcome-tour/shared/index.js ***! - \*********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ CHECKLIST_STEPS: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.CHECKLIST_STEPS), -/* harmony export */ IS_DASHBOARD_PAGE: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.IS_DASHBOARD_PAGE), -/* harmony export */ IS_WELCOME_TOUR_SEEN: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.IS_WELCOME_TOUR_SEEN), -/* harmony export */ MODAL_SIZE: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.MODAL_SIZE), -/* harmony export */ PREFIX: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PREFIX), -/* harmony export */ PROGRESS_BAR_PERCENT: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.PROGRESS_BAR_PERCENT), -/* harmony export */ TOUR_URL: () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_0__.TOUR_URL) -/* harmony export */ }); -/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./constants */ "./js/src/welcome-tour/shared/constants.js"); - - -/***/ }), - -/***/ "./js/src/welcome-tour/ui/checklist.js": -/*!*********************************************!*\ - !*** ./js/src/welcome-tour/ui/checklist.js ***! - \*********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../shared */ "./js/src/welcome-tour/shared/index.js"); -/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils */ "./js/src/welcome-tour/utils/index.js"); -/** - * Internal dependencies - */ - - - -/** - * Initializes the checklist. - * - * @return {void} - */ -function initializeChecklist() { - setProgressBarPercent(); - document.addEventListener('frm_added_field', function () { - return (0,_utils__WEBPACK_IMPORTED_MODULE_1__.markStepAsCompleted)('add-fields'); - }); -} - -/** - * Sets the progress bar percent. - * - * @private - * @return {void} - */ -function setProgressBarPercent() { - var progressFill = document.querySelector('.frm-welcome-tour .frm-checklist__progress-fill'); - if (!progressFill) { - return; - } - progressFill.style.width = "".concat(_shared__WEBPACK_IMPORTED_MODULE_0__.PROGRESS_BAR_PERCENT, "%"); -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeChecklist); - -/***/ }), - -/***/ "./js/src/welcome-tour/ui/index.js": -/*!*****************************************!*\ - !*** ./js/src/welcome-tour/ui/index.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ initializeChecklist: () => (/* reexport safe */ _checklist__WEBPACK_IMPORTED_MODULE_2__["default"]), -/* harmony export */ initializeModal: () => (/* reexport safe */ _modal__WEBPACK_IMPORTED_MODULE_0__["default"]), -/* harmony export */ initializeSpotlight: () => (/* reexport safe */ _spotlight__WEBPACK_IMPORTED_MODULE_1__["default"]) -/* harmony export */ }); -/* harmony import */ var _modal__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./modal */ "./js/src/welcome-tour/ui/modal.js"); -/* harmony import */ var _spotlight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./spotlight */ "./js/src/welcome-tour/ui/spotlight.js"); -/* harmony import */ var _checklist__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./checklist */ "./js/src/welcome-tour/ui/checklist.js"); - - - - -/***/ }), - -/***/ "./js/src/welcome-tour/ui/modal.js": -/*!*****************************************!*\ - !*** ./js/src/welcome-tour/ui/modal.js ***! - \*****************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); -/* harmony import */ var _shared__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../shared */ "./js/src/welcome-tour/shared/index.js"); -/** - * Internal dependencies - */ - - - -/** - * Initialize the modal widget. - * - * @return {void} - */ -function initializeModal() { - if (_shared__WEBPACK_IMPORTED_MODULE_1__.IS_DASHBOARD_PAGE && !_shared__WEBPACK_IMPORTED_MODULE_1__.IS_WELCOME_TOUR_SEEN) { - (0,_elements__WEBPACK_IMPORTED_MODULE_0__.buildBeginTourModalElement)(); - } -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeModal); - -/***/ }), - -/***/ "./js/src/welcome-tour/ui/spotlight.js": -/*!*********************************************!*\ - !*** ./js/src/welcome-tour/ui/spotlight.js ***! - \*********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) -/* harmony export */ }); -/** - * Initialize the spotlight widget. - * - * @return {void} - */ -function initializeSpotlight() { - document.querySelectorAll('.frm-spotlight').forEach(function (spotlightElement) { - setTimeout(function () { - setupSpotlight(spotlightElement); - }, 0); - }); -} - -/** - * Setup spotlight with positioning and scroll listeners. - * - * @private - * @param {HTMLElement} spotlightElement The spotlight container. - * @return {void} - */ -function setupSpotlight(spotlightElement) { - var targetElement = document.querySelector(spotlightElement.dataset.target); - if (!targetElement) { - return; - } - document.body.append(spotlightElement); - - // Add scroll listeners to all scrollable ancestors - var scrollableElements = getScrollableAncestors(targetElement); - scrollableElements.forEach(function (element) { - element.addEventListener('scroll', function () { - updateSpotlightPosition(spotlightElement, targetElement); - handleSpotlightFadeAnimation(spotlightElement); - }, { - passive: true - }); - }); - window.addEventListener('resize', function () { - return updateSpotlightPosition(spotlightElement, targetElement); - }, { - passive: true - }); - - // Re-position and show spotlight after a short delay on page load - setTimeout(function () { - updateSpotlightPosition(spotlightElement, targetElement); - spotlightElement.classList.remove('frm-force-hidden'); - }, 200); -} - -/** - * Update spotlight position based on target element. - * - * @private - * @param {HTMLElement} spotlightElement The spotlight container. - * @param {HTMLElement} targetElement The target element. - * @return {void} - */ -function updateSpotlightPosition(spotlightElement, targetElement) { - if (!targetElement.offsetParent) { - return; - } - var targetRect = targetElement.getBoundingClientRect(); - if (targetRect.width === 0 || targetRect.height === 0) { - return; - } - var left; - var leftPositionAttr = spotlightElement.dataset.leftPosition; - switch (leftPositionAttr) { - case 'middle': - left = targetRect.left + Math.round(targetRect.width / 2); - break; - case 'end': - left = targetRect.right; - break; - default: - left = targetRect.left + parseInt(leftPositionAttr); - break; - } - spotlightElement.style.left = "".concat(left || targetRect.left, "px"); - var top = 'bottom' === spotlightElement.dataset.placement ? targetRect.top + targetRect.height : targetRect.top + Math.round(targetRect.height / 2); - spotlightElement.style.top = "".concat(top, "px"); -} - -/** - * Handle fade animations based on spotlight position relative to #frm_top_bar. - * - * @private - * @param {HTMLElement} spotlightElement The spotlight container. - * @return {void} - */ -function handleSpotlightFadeAnimation(spotlightElement) { - var topBar = document.getElementById('frm_top_bar'); - if (!topBar) { - return; - } - var shouldFadeOut = spotlightElement.getBoundingClientRect().top + 24 <= topBar.getBoundingClientRect().bottom; - if (shouldFadeOut && !spotlightElement.classList.contains('frm-fadeout')) { - spotlightElement.classList.remove('frm-fadein'); - spotlightElement.classList.add('frm-fadeout'); - } else if (!shouldFadeOut && !spotlightElement.classList.contains('frm-fadein')) { - spotlightElement.classList.remove('frm-fadeout'); - spotlightElement.classList.add('frm-fadein'); - } -} - -/** - * Get all scrollable ancestor elements. - * - * @private - * @param {HTMLElement} element The target element. - * @return {HTMLElement[]} Array of scrollable elements. - */ -function getScrollableAncestors(element) { - var scrollables = [window]; - var parent = element.parentElement; - while (parent && document.body !== parent) { - var _getComputedStyle = getComputedStyle(parent), - overflow = _getComputedStyle.overflow, - overflowY = _getComputedStyle.overflowY; - if (['auto', 'scroll'].includes(overflow) || ['auto', 'scroll'].includes(overflowY)) { - scrollables.push(parent); - } - parent = parent.parentElement; - } - return scrollables; -} -/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (initializeSpotlight); - -/***/ }), - -/***/ "./js/src/welcome-tour/utils/index.js": -/*!********************************************!*\ - !*** ./js/src/welcome-tour/utils/index.js ***! - \********************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ markStepAsCompleted: () => (/* reexport safe */ _markStepAsCompleted__WEBPACK_IMPORTED_MODULE_1__.markStepAsCompleted), -/* harmony export */ onDashboardPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onDashboardPage), -/* harmony export */ onEditorPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onEditorPage), -/* harmony export */ onFormTemplatesPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onFormTemplatesPage), -/* harmony export */ onStylerPage: () => (/* reexport safe */ _pageDetection__WEBPACK_IMPORTED_MODULE_0__.onStylerPage) -/* harmony export */ }); -/* harmony import */ var _pageDetection__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./pageDetection */ "./js/src/welcome-tour/utils/pageDetection.js"); -/* harmony import */ var _markStepAsCompleted__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./markStepAsCompleted */ "./js/src/welcome-tour/utils/markStepAsCompleted.js"); - - - -/***/ }), - -/***/ "./js/src/welcome-tour/utils/markStepAsCompleted.js": -/*!**********************************************************!*\ - !*** ./js/src/welcome-tour/utils/markStepAsCompleted.js ***! - \**********************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ markStepAsCompleted: () => (/* binding */ markStepAsCompleted) -/* harmony export */ }); -/* harmony import */ var core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils */ "./js/src/core/utils/index.js"); -/* harmony import */ var _elements__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../elements */ "./js/src/welcome-tour/elements/index.js"); -function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i.return) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); } -function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); } -function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } -function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } -/** - * Internal dependencies - */ - - -var STEP_PREFIX = 'frm-checklist__step'; - -/** - * Marks a step as completed. - * - * @param {string} stepKey The step key. - * @return {Promise} - */ -function markStepAsCompleted(_x) { - return _markStepAsCompleted.apply(this, arguments); -} - -/** - * Wraps step title with anchor link from dataset. - * - * @private - * @param {HTMLElement} stepElement The step element to wrap. - * @return {void} - */ -function _markStepAsCompleted() { - _markStepAsCompleted = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(stepKey) { - var _getElements, checklist, stepElement, formData, nextStep, _t; - return _regenerator().w(function (_context) { - while (1) switch (_context.p = _context.n) { - case 0: - _getElements = (0,_elements__WEBPACK_IMPORTED_MODULE_1__.getElements)(), checklist = _getElements.checklist; - if (checklist) { - _context.n = 1; - break; - } - return _context.a(2); - case 1: - stepElement = document.getElementById("".concat(STEP_PREFIX, "-").concat(stepKey)); - if (stepElement) { - _context.n = 2; - break; - } - return _context.a(2); - case 2: - if (stepElement.classList.contains("".concat(STEP_PREFIX, "--active"))) { - _context.n = 3; - break; - } - return _context.a(2); - case 3: - formData = new FormData(); - formData.append('step_key', stepKey); - _context.p = 4; - _context.n = 5; - return (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.doJsonPost)('mark_checklist_step_as_completed', formData); - case 5: - stepElement.classList.remove("".concat(STEP_PREFIX, "--active")); - stepElement.classList.add("".concat(STEP_PREFIX, "--completed")); - nextStep = stepElement.nextElementSibling; - if (nextStep) { - _context.n = 6; - break; - } - return _context.a(2); - case 6: - nextStep.classList.add("".concat(STEP_PREFIX, "--active")); - if (nextStep.dataset.link) { - wrapStepTitleWithLink(nextStep); - } - _context.n = 8; - break; - case 7: - _context.p = 7; - _t = _context.v; - console.error('Failed to mark step as completed:', _t); - case 8: - return _context.a(2); - } - }, _callee, null, [[4, 7]]); - })); - return _markStepAsCompleted.apply(this, arguments); -} -function wrapStepTitleWithLink(stepElement) { - var stepTitle = stepElement.querySelector('.frm-checklist__step-title'); - if (stepTitle !== null && stepTitle !== void 0 && stepTitle.querySelector('a')) { - return; - } - var anchor = (0,core_utils__WEBPACK_IMPORTED_MODULE_0__.a)({ - href: stepElement.dataset.link, - className: 'frm-h-stack-xs', - children: Array.from(stepTitle.childNodes) - }); - stepTitle.replaceChildren(anchor); -} - -/***/ }), - -/***/ "./js/src/welcome-tour/utils/pageDetection.js": -/*!****************************************************!*\ - !*** ./js/src/welcome-tour/utils/pageDetection.js ***! - \****************************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ onDashboardPage: () => (/* binding */ onDashboardPage), -/* harmony export */ onEditorPage: () => (/* binding */ onEditorPage), -/* harmony export */ onFormTemplatesPage: () => (/* binding */ onFormTemplatesPage), -/* harmony export */ onStylerPage: () => (/* binding */ onStylerPage) -/* harmony export */ }); -/* harmony import */ var core_utils_url__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! core/utils/url */ "./js/src/core/utils/url.js"); -/** - * Internal dependencies - */ - - -/** - * Checks if the current page is the editor page. - * - * @return {boolean} True if the current page is the editor page, false otherwise. - */ -var onEditorPage = function onEditorPage() { - return document.getElementById('frm_form_editor_container') !== null; -}; - -/** - * Checks if the current page is the styler page. - * - * @return {boolean} True if the current page is the styler page, false otherwise. - */ -var onStylerPage = function onStylerPage() { - return document.getElementById('frm_active_style_form') !== null; -}; - -/** - * Checks if the current page is the form templates page. - * - * @return {boolean} True if the current page is the form templates page, false otherwise. - */ -var onFormTemplatesPage = function onFormTemplatesPage() { - return (0,core_utils_url__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('page') === 'formidable-form-templates'; -}; - -/** - * Checks if the current page is the dashboard page. - * - * @return {boolean} True if the current page is the dashboard page, false otherwise. - */ -var onDashboardPage = function onDashboardPage() { - return (0,core_utils_url__WEBPACK_IMPORTED_MODULE_0__.getQueryParam)('page') === 'formidable-dashboard'; -}; - -/***/ }), - -/***/ "./node_modules/memize/index.js": -/*!**************************************!*\ - !*** ./node_modules/memize/index.js ***! - \**************************************/ -/***/ ((module) => { - -/** - * Memize options object. - * - * @typedef MemizeOptions - * - * @property {number} [maxSize] Maximum size of the cache. - */ - -/** - * Internal cache entry. - * - * @typedef MemizeCacheNode - * - * @property {?MemizeCacheNode|undefined} [prev] Previous node. - * @property {?MemizeCacheNode|undefined} [next] Next node. - * @property {Array<*>} args Function arguments for cache - * entry. - * @property {*} val Function result. - */ - -/** - * Properties of the enhanced function for controlling cache. - * - * @typedef MemizeMemoizedFunction - * - * @property {()=>void} clear Clear the cache. - */ - -/** - * Accepts a function to be memoized, and returns a new memoized function, with - * optional options. - * - * @template {Function} F - * - * @param {F} fn Function to memoize. - * @param {MemizeOptions} [options] Options object. - * - * @return {F & MemizeMemoizedFunction} Memoized function. - */ -function memize( fn, options ) { - var size = 0; - - /** @type {?MemizeCacheNode|undefined} */ - var head; - - /** @type {?MemizeCacheNode|undefined} */ - var tail; - - options = options || {}; - - function memoized( /* ...args */ ) { - var node = head, - len = arguments.length, - args, i; - - searchCache: while ( node ) { - // Perform a shallow equality test to confirm that whether the node - // under test is a candidate for the arguments passed. Two arrays - // are shallowly equal if their length matches and each entry is - // strictly equal between the two sets. Avoid abstracting to a - // function which could incur an arguments leaking deoptimization. - - // Check whether node arguments match arguments length - if ( node.args.length !== arguments.length ) { - node = node.next; - continue; - } - - // Check whether node arguments match arguments values - for ( i = 0; i < len; i++ ) { - if ( node.args[ i ] !== arguments[ i ] ) { - node = node.next; - continue searchCache; - } - } - - // At this point we can assume we've found a match - - // Surface matched node to head if not already - if ( node !== head ) { - // As tail, shift to previous. Must only shift if not also - // head, since if both head and tail, there is no previous. - if ( node === tail ) { - tail = node.prev; - } - - // Adjust siblings to point to each other. If node was tail, - // this also handles new tail's empty `next` assignment. - /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; - if ( node.next ) { - node.next.prev = node.prev; - } - - node.next = head; - node.prev = null; - /** @type {MemizeCacheNode} */ ( head ).prev = node; - head = node; - } - - // Return immediately - return node.val; - } - - // No cached value found. Continue to insertion phase: - - // Create a copy of arguments (avoid leaking deoptimization) - args = new Array( len ); - for ( i = 0; i < len; i++ ) { - args[ i ] = arguments[ i ]; - } - - node = { - args: args, - - // Generate the result from original function - val: fn.apply( null, args ), - }; - - // Don't need to check whether node is already head, since it would - // have been returned above already if it was - - // Shift existing head down list - if ( head ) { - head.prev = node; - node.next = head; - } else { - // If no head, follows that there's no tail (at initial or reset) - tail = node; - } - - // Trim tail if we're reached max size and are pending cache insertion - if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { - tail = /** @type {MemizeCacheNode} */ ( tail ).prev; - /** @type {MemizeCacheNode} */ ( tail ).next = null; - } else { - size++; - } - - head = node; - - return node.val; - } - - memoized.clear = function() { - head = null; - tail = null; - size = 0; - }; - - if ( false ) {} - - // Ignore reason: There's not a clear solution to create an intersection of - // the function with additional properties, where the goal is to retain the - // function signature of the incoming argument and add control properties - // on the return value. - - // @ts-ignore - return memoized; -} - -module.exports = memize; - - -/***/ }), - -/***/ "./node_modules/sprintf-js/src/sprintf.js": -/*!************************************************!*\ - !*** ./node_modules/sprintf-js/src/sprintf.js ***! - \************************************************/ -/***/ ((module, exports, __webpack_require__) => { - -var __WEBPACK_AMD_DEFINE_RESULT__;/* global window, exports, define */ - -!function() { - 'use strict' - - var re = { - not_string: /[^s]/, - not_bool: /[^t]/, - not_type: /[^T]/, - not_primitive: /[^v]/, - number: /[diefg]/, - numeric_arg: /[bcdiefguxX]/, - json: /[j]/, - not_json: /[^j]/, - text: /^[^\x25]+/, - modulo: /^\x25{2}/, - placeholder: /^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/, - key: /^([a-z_][a-z_\d]*)/i, - key_access: /^\.([a-z_][a-z_\d]*)/i, - index_access: /^\[(\d+)\]/, - sign: /^[+-]/ - } - - function sprintf(key) { - // `arguments` is not an array, but should be fine for this call - return sprintf_format(sprintf_parse(key), arguments) - } - - function vsprintf(fmt, argv) { - return sprintf.apply(null, [fmt].concat(argv || [])) - } - - function sprintf_format(parse_tree, argv) { - var cursor = 1, tree_length = parse_tree.length, arg, output = '', i, k, ph, pad, pad_character, pad_length, is_positive, sign - for (i = 0; i < tree_length; i++) { - if (typeof parse_tree[i] === 'string') { - output += parse_tree[i] - } - else if (typeof parse_tree[i] === 'object') { - ph = parse_tree[i] // convenience purposes only - if (ph.keys) { // keyword argument - arg = argv[cursor] - for (k = 0; k < ph.keys.length; k++) { - if (arg == undefined) { - throw new Error(sprintf('[sprintf] Cannot access property "%s" of undefined value "%s"', ph.keys[k], ph.keys[k-1])) - } - arg = arg[ph.keys[k]] - } - } - else if (ph.param_no) { // positional argument (explicit) - arg = argv[ph.param_no] - } - else { // positional argument (implicit) - arg = argv[cursor++] - } - - if (re.not_type.test(ph.type) && re.not_primitive.test(ph.type) && arg instanceof Function) { - arg = arg() - } - - if (re.numeric_arg.test(ph.type) && (typeof arg !== 'number' && isNaN(arg))) { - throw new TypeError(sprintf('[sprintf] expecting number but found %T', arg)) - } - - if (re.number.test(ph.type)) { - is_positive = arg >= 0 - } - - switch (ph.type) { - case 'b': - arg = parseInt(arg, 10).toString(2) - break - case 'c': - arg = String.fromCharCode(parseInt(arg, 10)) - break - case 'd': - case 'i': - arg = parseInt(arg, 10) - break - case 'j': - arg = JSON.stringify(arg, null, ph.width ? parseInt(ph.width) : 0) - break - case 'e': - arg = ph.precision ? parseFloat(arg).toExponential(ph.precision) : parseFloat(arg).toExponential() - break - case 'f': - arg = ph.precision ? parseFloat(arg).toFixed(ph.precision) : parseFloat(arg) - break - case 'g': - arg = ph.precision ? String(Number(arg.toPrecision(ph.precision))) : parseFloat(arg) - break - case 'o': - arg = (parseInt(arg, 10) >>> 0).toString(8) - break - case 's': - arg = String(arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 't': - arg = String(!!arg) - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'T': - arg = Object.prototype.toString.call(arg).slice(8, -1).toLowerCase() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'u': - arg = parseInt(arg, 10) >>> 0 - break - case 'v': - arg = arg.valueOf() - arg = (ph.precision ? arg.substring(0, ph.precision) : arg) - break - case 'x': - arg = (parseInt(arg, 10) >>> 0).toString(16) - break - case 'X': - arg = (parseInt(arg, 10) >>> 0).toString(16).toUpperCase() - break - } - if (re.json.test(ph.type)) { - output += arg - } - else { - if (re.number.test(ph.type) && (!is_positive || ph.sign)) { - sign = is_positive ? '+' : '-' - arg = arg.toString().replace(re.sign, '') - } - else { - sign = '' - } - pad_character = ph.pad_char ? ph.pad_char === '0' ? '0' : ph.pad_char.charAt(1) : ' ' - pad_length = ph.width - (sign + arg).length - pad = ph.width ? (pad_length > 0 ? pad_character.repeat(pad_length) : '') : '' - output += ph.align ? sign + arg + pad : (pad_character === '0' ? sign + pad + arg : pad + sign + arg) - } - } - } - return output - } - - var sprintf_cache = Object.create(null) - - function sprintf_parse(fmt) { - if (sprintf_cache[fmt]) { - return sprintf_cache[fmt] - } - - var _fmt = fmt, match, parse_tree = [], arg_names = 0 - while (_fmt) { - if ((match = re.text.exec(_fmt)) !== null) { - parse_tree.push(match[0]) - } - else if ((match = re.modulo.exec(_fmt)) !== null) { - parse_tree.push('%') - } - else if ((match = re.placeholder.exec(_fmt)) !== null) { - if (match[2]) { - arg_names |= 1 - var field_list = [], replacement_field = match[2], field_match = [] - if ((field_match = re.key.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - while ((replacement_field = replacement_field.substring(field_match[0].length)) !== '') { - if ((field_match = re.key_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else if ((field_match = re.index_access.exec(replacement_field)) !== null) { - field_list.push(field_match[1]) - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - } - } - else { - throw new SyntaxError('[sprintf] failed to parse named argument key') - } - match[2] = field_list - } - else { - arg_names |= 2 - } - if (arg_names === 3) { - throw new Error('[sprintf] mixing positional and named placeholders is not (yet) supported') - } - - parse_tree.push( - { - placeholder: match[0], - param_no: match[1], - keys: match[2], - sign: match[3], - pad_char: match[4], - align: match[5], - width: match[6], - precision: match[7], - type: match[8] - } - ) - } - else { - throw new SyntaxError('[sprintf] unexpected placeholder') - } - _fmt = _fmt.substring(match[0].length) - } - return sprintf_cache[fmt] = parse_tree - } - - /** - * export to either browser or node.js - */ - /* eslint-disable quote-props */ - if (true) { - exports.sprintf = sprintf - exports.vsprintf = vsprintf - } - if (typeof window !== 'undefined') { - window['sprintf'] = sprintf - window['vsprintf'] = vsprintf - - if (true) { - !(__WEBPACK_AMD_DEFINE_RESULT__ = (function() { - return { - 'sprintf': sprintf, - 'vsprintf': vsprintf - } - }).call(exports, __webpack_require__, exports, module), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) - } - } - /* eslint-enable quote-props */ -}(); // eslint-disable-line - - -/***/ }), - -/***/ "./node_modules/tannin/index.js": -/*!**************************************!*\ - !*** ./node_modules/tannin/index.js ***! - \**************************************/ -/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ Tannin) -/* harmony export */ }); -/* harmony import */ var _tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tannin/plural-forms */ "./node_modules/@tannin/plural-forms/index.js"); - - -/** - * Tannin constructor options. - * - * @typedef {Object} TanninOptions - * - * @property {string} [contextDelimiter] Joiner in string lookup with context. - * @property {Function} [onMissingKey] Callback to invoke when key missing. - */ - -/** - * Domain metadata. - * - * @typedef {Object} TanninDomainMetadata - * - * @property {string} [domain] Domain name. - * @property {string} [lang] Language code. - * @property {(string|Function)} [plural_forms] Plural forms expression or - * function evaluator. - */ - -/** - * Domain translation pair respectively representing the singular and plural - * translation. - * - * @typedef {[string,string]} TanninTranslation - */ - -/** - * Locale data domain. The key is used as reference for lookup, the value an - * array of two string entries respectively representing the singular and plural - * translation. - * - * @typedef {{[key:string]:TanninDomainMetadata|TanninTranslation,'':TanninDomainMetadata|TanninTranslation}} TanninLocaleDomain - */ - -/** - * Jed-formatted locale data. - * - * @see http://messageformat.github.io/Jed/ - * - * @typedef {{[domain:string]:TanninLocaleDomain}} TanninLocaleData - */ - -/** - * Default Tannin constructor options. - * - * @type {TanninOptions} - */ -var DEFAULT_OPTIONS = { - contextDelimiter: '\u0004', - onMissingKey: null, -}; - -/** - * Given a specific locale data's config `plural_forms` value, returns the - * expression. - * - * @example - * - * ``` - * getPluralExpression( 'nplurals=2; plural=(n != 1);' ) === '(n != 1)' - * ``` - * - * @param {string} pf Locale data plural forms. - * - * @return {string} Plural forms expression. - */ -function getPluralExpression( pf ) { - var parts, i, part; - - parts = pf.split( ';' ); - - for ( i = 0; i < parts.length; i++ ) { - part = parts[ i ].trim(); - if ( part.indexOf( 'plural=' ) === 0 ) { - return part.substr( 7 ); - } - } -} - -/** - * Tannin constructor. - * - * @class - * - * @param {TanninLocaleData} data Jed-formatted locale data. - * @param {TanninOptions} [options] Tannin options. - */ -function Tannin( data, options ) { - var key; - - /** - * Jed-formatted locale data. - * - * @name Tannin#data - * @type {TanninLocaleData} - */ - this.data = data; - - /** - * Plural forms function cache, keyed by plural forms string. - * - * @name Tannin#pluralForms - * @type {Object} - */ - this.pluralForms = {}; - - /** - * Effective options for instance, including defaults. - * - * @name Tannin#options - * @type {TanninOptions} - */ - this.options = {}; - - for ( key in DEFAULT_OPTIONS ) { - this.options[ key ] = options !== undefined && key in options - ? options[ key ] - : DEFAULT_OPTIONS[ key ]; - } -} - -/** - * Returns the plural form index for the given domain and value. - * - * @param {string} domain Domain on which to calculate plural form. - * @param {number} n Value for which plural form is to be calculated. - * - * @return {number} Plural form index. - */ -Tannin.prototype.getPluralForm = function( domain, n ) { - var getPluralForm = this.pluralForms[ domain ], - config, plural, pf; - - if ( ! getPluralForm ) { - config = this.data[ domain ][ '' ]; - - pf = ( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - if ( typeof pf !== 'function' ) { - plural = getPluralExpression( - config[ 'Plural-Forms' ] || - config[ 'plural-forms' ] || - // Ignore reason: As known, there's no way to document the empty - // string property on a key to guarantee this as metadata. - // @ts-ignore - config.plural_forms - ); - - pf = (0,_tannin_plural_forms__WEBPACK_IMPORTED_MODULE_0__["default"])( plural ); - } - - getPluralForm = this.pluralForms[ domain ] = pf; - } - - return getPluralForm( n ); -}; - -/** - * Translate a string. - * - * @param {string} domain Translation domain. - * @param {string|void} context Context distinguishing terms of the same name. - * @param {string} singular Primary key for translation lookup. - * @param {string=} plural Fallback value used for non-zero plural - * form index. - * @param {number=} n Value to use in calculating plural form. - * - * @return {string} Translated string. - */ -Tannin.prototype.dcnpgettext = function( domain, context, singular, plural, n ) { - var index, key, entry; - - if ( n === undefined ) { - // Default to singular. - index = 0; - } else { - // Find index by evaluating plural form for value. - index = this.getPluralForm( domain, n ); - } - - key = singular; - - // If provided, context is prepended to key with delimiter. - if ( context ) { - key = context + this.options.contextDelimiter + singular; - } - - entry = this.data[ domain ][ key ]; - - // Verify not only that entry exists, but that the intended index is within - // range and non-empty. - if ( entry && entry[ index ] ) { - return entry[ index ]; - } - - if ( this.options.onMissingKey ) { - this.options.onMissingKey( singular, domain ); - } - - // If entry not found, fall back to singular vs. plural with zero index - // representing the singular value. - return index === 0 ? singular : plural; -}; - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js": -/*!*********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js ***! - \*********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayLikeToArray) -/* harmony export */ }); -function _arrayLikeToArray(r, a) { - (null == a || a > r.length) && (a = r.length); - for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; - return n; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _arrayWithoutHoles) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _arrayWithoutHoles(r) { - if (Array.isArray(r)) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/classCallCheck.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/classCallCheck.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _classCallCheck) -/* harmony export */ }); -function _classCallCheck(a, n) { - if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js": -/*!*******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***! - \*******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _defineProperty) -/* harmony export */ }); -/* harmony import */ var _toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./toPropertyKey.js */ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js"); - -function _defineProperty(e, r, t) { - return (r = (0,_toPropertyKey_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r)) in e ? Object.defineProperty(e, r, { - value: t, - enumerable: !0, - configurable: !0, - writable: !0 - }) : e[r] = t, e; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js": -/*!********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/iterableToArray.js ***! - \********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _iterableToArray) -/* harmony export */ }); -function _iterableToArray(r) { - if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _nonIterableSpread) -/* harmony export */ }); -function _nonIterableSpread() { - throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js": -/*!**********************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js ***! - \**********************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _toConsumableArray) -/* harmony export */ }); -/* harmony import */ var _arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayWithoutHoles.js */ "./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js"); -/* harmony import */ var _iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./iterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/iterableToArray.js"); -/* harmony import */ var _unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./unsupportedIterableToArray.js */ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"); -/* harmony import */ var _nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./nonIterableSpread.js */ "./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js"); - - - - -function _toConsumableArray(r) { - return (0,_arrayWithoutHoles_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r) || (0,_iterableToArray_js__WEBPACK_IMPORTED_MODULE_1__["default"])(r) || (0,_unsupportedIterableToArray_js__WEBPACK_IMPORTED_MODULE_2__["default"])(r) || (0,_nonIterableSpread_js__WEBPACK_IMPORTED_MODULE_3__["default"])(); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js": -/*!****************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPrimitive.js ***! - \****************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPrimitive) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); - -function toPrimitive(t, r) { - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(t) || !t) return t; - var e = t[Symbol.toPrimitive]; - if (void 0 !== e) { - var i = e.call(t, r || "default"); - if ("object" != (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i)) return i; - throw new TypeError("@@toPrimitive must return a primitive value."); - } - return ("string" === r ? String : Number)(t); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js": -/*!******************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/toPropertyKey.js ***! - \******************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ toPropertyKey) -/* harmony export */ }); -/* harmony import */ var _typeof_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typeof.js */ "./node_modules/@babel/runtime/helpers/esm/typeof.js"); -/* harmony import */ var _toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./toPrimitive.js */ "./node_modules/@babel/runtime/helpers/esm/toPrimitive.js"); - - -function toPropertyKey(t) { - var i = (0,_toPrimitive_js__WEBPACK_IMPORTED_MODULE_1__["default"])(t, "string"); - return "symbol" == (0,_typeof_js__WEBPACK_IMPORTED_MODULE_0__["default"])(i) ? i : i + ""; -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js": -/*!***********************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***! - \***********************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _typeof) -/* harmony export */ }); -function _typeof(o) { - "@babel/helpers - typeof"; - - return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { - return typeof o; - } : function (o) { - return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; - }, _typeof(o); -} - - -/***/ }), - -/***/ "./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js": -/*!*******************************************************************************!*\ - !*** ./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js ***! - \*******************************************************************************/ -/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { - -"use strict"; -__webpack_require__.r(__webpack_exports__); -/* harmony export */ __webpack_require__.d(__webpack_exports__, { -/* harmony export */ "default": () => (/* binding */ _unsupportedIterableToArray) -/* harmony export */ }); -/* harmony import */ var _arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./arrayLikeToArray.js */ "./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js"); - -function _unsupportedIterableToArray(r, a) { - if (r) { - if ("string" == typeof r) return (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a); - var t = {}.toString.call(r).slice(8, -1); - return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? (0,_arrayLikeToArray_js__WEBPACK_IMPORTED_MODULE_0__["default"])(r, a) : void 0; - } -} - - -/***/ }) - -/******/ }); -/************************************************************************/ -/******/ // The module cache -/******/ var __webpack_module_cache__ = {}; -/******/ -/******/ // The require function -/******/ function __webpack_require__(moduleId) { -/******/ // Check if module is in cache -/******/ var cachedModule = __webpack_module_cache__[moduleId]; -/******/ if (cachedModule !== undefined) { -/******/ return cachedModule.exports; -/******/ } -/******/ // Create a new module (and put it into the cache) -/******/ var module = __webpack_module_cache__[moduleId] = { -/******/ // no module.id needed -/******/ // no module.loaded needed -/******/ exports: {} -/******/ }; -/******/ -/******/ // Execute the module function -/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); -/******/ -/******/ // Return the exports of the module -/******/ return module.exports; -/******/ } -/******/ -/************************************************************************/ -/******/ /* webpack/runtime/compat get default export */ -/******/ (() => { -/******/ // getDefaultExport function for compatibility with non-harmony modules -/******/ __webpack_require__.n = (module) => { -/******/ var getter = module && module.__esModule ? -/******/ () => (module['default']) : -/******/ () => (module); -/******/ __webpack_require__.d(getter, { a: getter }); -/******/ return getter; -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/define property getters */ -/******/ (() => { -/******/ // define getter functions for harmony exports -/******/ __webpack_require__.d = (exports, definition) => { -/******/ for(var key in definition) { -/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { -/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); -/******/ } -/******/ } -/******/ }; -/******/ })(); -/******/ -/******/ /* webpack/runtime/hasOwnProperty shorthand */ -/******/ (() => { -/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) -/******/ })(); -/******/ -/******/ /* webpack/runtime/make namespace object */ -/******/ (() => { -/******/ // define __esModule on exports -/******/ __webpack_require__.r = (exports) => { -/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { -/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); -/******/ } -/******/ Object.defineProperty(exports, '__esModule', { value: true }); -/******/ }; -/******/ })(); -/******/ -/************************************************************************/ -var __webpack_exports__ = {}; -// This entry needs to be wrapped in an IIFE because it needs to be in strict mode. -(() => { -"use strict"; -/*!**************************************!*\ - !*** ./js/src/welcome-tour/index.js ***! - \**************************************/ -__webpack_require__.r(__webpack_exports__); -/* harmony import */ var _wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/dom-ready */ "./node_modules/@wordpress/dom-ready/build-module/index.js"); -/* harmony import */ var _ui__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ui */ "./js/src/welcome-tour/ui/index.js"); -/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./js/src/welcome-tour/events/index.js"); -/** - * WordPress dependencies - */ - - -/** - * Internal dependencies - */ - - -(0,_wordpress_dom_ready__WEBPACK_IMPORTED_MODULE_2__["default"])(function () { - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeModal)(); - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeSpotlight)(); - (0,_ui__WEBPACK_IMPORTED_MODULE_0__.initializeChecklist)(); - (0,_events__WEBPACK_IMPORTED_MODULE_1__.addEventListeners)(); -}); -})(); - -/******/ })() -; -//# sourceMappingURL=welcome-tour.js.map \ No newline at end of file +/*! For license information please see welcome-tour.js.LICENSE.txt */ +(()=>{var t={8616:t=>{t.exports=function(t,e){var r,n,o=0;function i(){var i,a,c=r,s=arguments.length;t:for(;c;){if(c.args.length===arguments.length){for(a=0;a{var n;!function(){"use strict";var o={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\x25]+/,modulo:/^\x25{2}/,placeholder:/^\x25(?:([1-9]\d*)\$|\(([^)]+)\))?(\+)?(0|'[^$])?(-)?(\d+)?(?:\.(\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\d]*)/i,key_access:/^\.([a-z_][a-z_\d]*)/i,index_access:/^\[(\d+)\]/,sign:/^[+-]/};function i(t){return function(t,e){var r,n,a,c,s,u,l,f,p,d=1,h=t.length,m="";for(n=0;n=0),c.type){case"b":r=parseInt(r,10).toString(2);break;case"c":r=String.fromCharCode(parseInt(r,10));break;case"d":case"i":r=parseInt(r,10);break;case"j":r=JSON.stringify(r,null,c.width?parseInt(c.width):0);break;case"e":r=c.precision?parseFloat(r).toExponential(c.precision):parseFloat(r).toExponential();break;case"f":r=c.precision?parseFloat(r).toFixed(c.precision):parseFloat(r);break;case"g":r=c.precision?String(Number(r.toPrecision(c.precision))):parseFloat(r);break;case"o":r=(parseInt(r,10)>>>0).toString(8);break;case"s":r=String(r),r=c.precision?r.substring(0,c.precision):r;break;case"t":r=String(!!r),r=c.precision?r.substring(0,c.precision):r;break;case"T":r=Object.prototype.toString.call(r).slice(8,-1).toLowerCase(),r=c.precision?r.substring(0,c.precision):r;break;case"u":r=parseInt(r,10)>>>0;break;case"v":r=r.valueOf(),r=c.precision?r.substring(0,c.precision):r;break;case"x":r=(parseInt(r,10)>>>0).toString(16);break;case"X":r=(parseInt(r,10)>>>0).toString(16).toUpperCase()}o.json.test(c.type)?m+=r:(!o.number.test(c.type)||f&&!c.sign?p="":(p=f?"+":"-",r=r.toString().replace(o.sign,"")),u=c.pad_char?"0"===c.pad_char?"0":c.pad_char.charAt(1):" ",l=c.width-(p+r).length,s=c.width&&l>0?u.repeat(l):"",m+=c.align?p+r+s:"0"===u?p+s+r:s+p+r)}return m}(function(t){if(c[t])return c[t];for(var e,r=t,n=[],i=0;r;){if(null!==(e=o.text.exec(r)))n.push(e[0]);else if(null!==(e=o.modulo.exec(r)))n.push("%");else{if(null===(e=o.placeholder.exec(r)))throw new SyntaxError("[sprintf] unexpected placeholder");if(e[2]){i|=1;var a=[],s=e[2],u=[];if(null===(u=o.key.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");for(a.push(u[1]);""!==(s=s.substring(u[0].length));)if(null!==(u=o.key_access.exec(s)))a.push(u[1]);else{if(null===(u=o.index_access.exec(s)))throw new SyntaxError("[sprintf] failed to parse named argument key");a.push(u[1])}e[2]=a}else i|=2;if(3===i)throw new Error("[sprintf] mixing positional and named placeholders is not (yet) supported");n.push({placeholder:e[0],param_no:e[1],keys:e[2],sign:e[3],pad_char:e[4],align:e[5],width:e[6],precision:e[7],type:e[8]})}r=r.substring(e[0].length)}return c[t]=n}(t),arguments)}function a(t,e){return i.apply(null,[t].concat(e||[]))}var c=Object.create(null);"undefined"!=typeof window&&(window.sprintf=i,window.vsprintf=a,void 0===(n=function(){return{sprintf:i,vsprintf:a}}.call(e,r,e,t))||(t.exports=n))}()}},e={};function r(n){var o=e[n];if(void 0!==o)return o.exports;var i=e[n]={exports:{}};return t[n](i,i.exports,r),i.exports}r.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return r.d(e,{a:e}),e},r.d=(t,e)=>{for(var n in e)r.o(e,n)&&!r.o(t,n)&&Object.defineProperty(t,n,{enumerable:!0,get:e[n]})},r.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),(()=>{"use strict";function t(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),r.push.apply(r,n)}return r}function e(e){for(var r=1;r0&&void 0!==arguments[0]?arguments[0]:{};if("object"!==o(t)||null===t)throw new Error("createPageElements: initialElements must be a non-null object");var r=t;return{getElements:function(){return r},addElements:function(t){if("object"!==o(t)||null===t)throw new Error("addElements: newElements must be a non-null object");r=e(e({},r),t)}}}(i),p=f.getElements,d=f.addElements,h=r(8616),m=r.n(h);function v(t){return v="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},v(t)}function y(t){var e=function(t){if("object"!=v(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var r=e.call(t,"string");if("object"!=v(r))return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return String(t)}(t);return"symbol"==v(e)?e:e+""}r(7604),m()(console.error),c={"(":9,"!":8,"*":7,"/":7,"%":7,"+":6,"-":6,"<":5,"<=":5,">":5,">=":5,"==":4,"!=":4,"&&":3,"||":2,"?":1,"?:":1},s=["(","?"],u={")":["("],":":["?","?:"]},l=/<=|>=|==|!=|&&|\|\||\?:|\(|!|\*|\/|%|\+|-|<|>|\?|\)|:/;var b={"!":function(t){return!t},"*":function(t,e){return t*e},"/":function(t,e){return t/e},"%":function(t,e){return t%e},"+":function(t,e){return t+e},"-":function(t,e){return t-e},"<":function(t,e){return t":function(t,e){return t>e},">=":function(t,e){return t>=e},"==":function(t,e){return t===e},"!=":function(t,e){return t!==e},"&&":function(t,e){return t&&e},"||":function(t,e){return t||e},"?:":function(t,e,r){if(t)throw e;return r}};var g={contextDelimiter:"",onMissingKey:null};function _(t,e){var r;for(r in this.data=t,this.pluralForms={},this.options={},g)this.options[r]=void 0!==e&&r in e?e[r]:g[r]}function w(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),r.push.apply(r,n)}return r}function x(t){for(var e=1;e=0||c[o]3&&void 0!==arguments[3]?arguments[3]:10,a=t[e];if(j(r)&&S(n))if("function"==typeof o)if("number"==typeof i){var c={callback:o,priority:i,namespace:n};if(a[r]){var s,u=a[r].handlers;for(s=u.length;s>0&&!(i>=u[s-1].priority);s--);s===u.length?u[s]=c:u.splice(s,0,c),a.__current.forEach(function(t){t.name===r&&t.currentIndex>=s&&t.currentIndex++})}else a[r]={handlers:[c],runs:0};"hookAdded"!==r&&t.doAction("hookAdded",r,n,o,i)}else console.error("If specified, the hook priority must be a number.");else console.error("The hook callback must be a function.")}},P=function(t,e){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n,o){var i=t[e];if(j(n)&&(r||S(o))){if(!i[n])return 0;var a=0;if(r)a=i[n].handlers.length,i[n]={runs:i[n].runs,handlers:[]};else for(var c=i[n].handlers,s=function(t){c[t].namespace===o&&(c.splice(t,1),a++,i.__current.forEach(function(e){e.name===n&&e.currentIndex>=t&&e.currentIndex--}))},u=c.length-1;u>=0;u--)s(u);return"hookRemoved"!==n&&t.doAction("hookRemoved",n,o),a}}},F=function(t,e){return function(r,n){var o=t[e];return void 0!==n?r in o&&o[r].handlers.some(function(t){return t.namespace===n}):r in o}},T=function(t,e){var r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return function(n){var o=t[e];o[n]||(o[n]={handlers:[],runs:0}),o[n].runs++;for(var i=o[n].handlers,a=arguments.length,c=new Array(a>1?a-1:0),s=1;s1&&void 0!==arguments[1]?arguments[1]:"default";n.data[e]=x(x(x({},k),n.data[e]),t),n.data[e][""]=x(x({},k[""]),n.data[e][""])},c=function(t,e){a(t,e),i()},s=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default",e=arguments.length>1?arguments[1]:void 0,r=arguments.length>2?arguments[2]:void 0,o=arguments.length>3?arguments[3]:void 0,i=arguments.length>4?arguments[4]:void 0;return n.data[t]||a(void 0,t),n.dcnpgettext(t,e,r,o,i)},u=function(){return arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default"},l=function(t,e,n){var o=s(n,e,t);return r?(o=r.applyFilters("i18n.gettext_with_context",o,t,e,n),r.applyFilters("i18n.gettext_with_context_"+u(n),o,t,e,n)):o};if(r){var f=function(t){O.test(t)&&i()};r.addAction("hookAdded","core/i18n",f),r.addAction("hookRemoved","core/i18n",f)}return{getLocaleData:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"default";return n.data[t]},setLocaleData:c,resetLocaleData:function(t,e){n.data={},n.pluralForms={},c(t,e)},subscribe:function(t){return o.add(t),function(){return o.delete(t)}},__:function(t,e){var n=s(e,void 0,t);return r?(n=r.applyFilters("i18n.gettext",n,t,e),r.applyFilters("i18n.gettext_"+u(e),n,t,e)):n},_x:l,_n:function(t,e,n,o){var i=s(o,void 0,t,e,n);return r?(i=r.applyFilters("i18n.ngettext",i,t,e,n,o),r.applyFilters("i18n.ngettext_"+u(o),i,t,e,n,o)):i},_nx:function(t,e,n,o,i){var a=s(i,o,t,e,n);return r?(a=r.applyFilters("i18n.ngettext_with_context",a,t,e,n,o,i),r.applyFilters("i18n.ngettext_with_context_"+u(i),a,t,e,n,o,i)):a},isRTL:function(){return"rtl"===l("ltr","text direction")},hasTranslation:function(t,e,o){var i,a,c=e?e+""+t:t,s=!(null===(i=n.data)||void 0===i||null===(a=i[null!=o?o:"default"])||void 0===a||!a[c]);return r&&(s=r.applyFilters("i18n.has_translation",s,t,e,o),s=r.applyFilters("i18n.has_translation_"+u(o),s,t,e,o)),s}}}(0,0,C));R.getLocaleData.bind(R),R.setLocaleData.bind(R),R.resetLocaleData.bind(R),R.subscribe.bind(R);var G=R.__.bind(R),N=(R._x.bind(R),R._n.bind(R),R._nx.bind(R),R.isRTL.bind(R),R.hasTranslation.bind(R),Promise.resolve(),frmDom),B=N.div,M=(N.span,N.tag),q=N.a,z=(N.img,N.svg,frmDom.modal),U=z.maybeCreateModal,$=(z.footerButton,frmDom.util),K=$.onClickPreventDefault,Z=($.documentOn,frmDom.ajax.doJsonPost),H=new URL(window.location.href).searchParams,X=window.frmGlobal,J=(X.url,X.nonce,window.frmWelcomeTourVars),W=J.IS_DASHBOARD_PAGE,V=J.IS_WELCOME_TOUR_SEEN,Y=(J.CHECKLIST_STEPS,J.TOUR_URL),Q=J.PROGRESS_BAR_PERCENT;const tt=function(){var t,e;W&&!V&&function(t){p().beginTourModal||d({beginTourModal:t})}(((t=U("frm_get_started_modal",{title:G("Get Started with Formidable Forms","formidable"),content:(e={className:"frm-px-md",text:G("Here's a quick checklist to help you set up and explore the key features of the plugin, so you can start building powerful forms in no time.","formidable")},M("p",e)),footer:B({className:"frmcenter",child:q({className:"button button-primary frm-button-primary",href:Y,text:G("Begin Tour","formidable")})}),width:"440px",dialogClass:"frm-fadein-up-back"})).classList.add("frm_wrap","frm-welcome-tour-modal","frmcenter"),t))};function et(t,e){if(e.offsetParent){var r=e.getBoundingClientRect();if(0!==r.width&&0!==r.height){var n,o=t.dataset.leftPosition;switch(o){case"middle":n=r.left+Math.round(r.width/2);break;case"end":n=r.right;break;default:n=r.left+parseInt(o)}t.style.left="".concat(n||r.left,"px");var i="bottom"===t.dataset.placement?r.top+r.height:r.top+Math.round(r.height/2);t.style.top="".concat(i,"px")}}}function rt(){var t,e,r="function"==typeof Symbol?Symbol:{},n=r.iterator||"@@iterator",o=r.toStringTag||"@@toStringTag";function i(r,n,o,i){var s=n&&n.prototype instanceof c?n:c,u=Object.create(s.prototype);return nt(u,"_invoke",function(r,n,o){var i,c,s,u=0,l=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,r){return i=e,c=0,s=t,p.n=r,a}};function d(r,n){for(c=r,s=n,e=0;!f&&u&&!o&&e3?(o=h===n)&&(s=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=r<2&&dn||n>h)&&(i[4]=r,i[5]=n,p.n=h,c=0))}if(o||r>1)return a;throw f=!0,n}return function(o,l,h){if(u>1)throw TypeError("Generator is already running");for(f&&1===l&&d(l,h),c=l,s=h;(e=c<2?t:s)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,s)):p.n=s:p.v=s);try{if(u=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,s)))throw TypeError("iterator result is not an object");if(!e.done)return e;s=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(s=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?s:r.call(n,p))!==a)break}catch(e){i=t,c=1,s=e}finally{u=1}}return{value:e,done:f}}}(r,o,i),!0),u}var a={};function c(){}function s(){}function u(){}e=Object.getPrototypeOf;var l=[][n]?e(e([][n]())):(nt(e={},n,function(){return this}),e),f=u.prototype=c.prototype=Object.create(l);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,nt(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return s.prototype=u,nt(f,"constructor",u),nt(u,"constructor",s),s.displayName="GeneratorFunction",nt(u,o,"GeneratorFunction"),nt(f),nt(f,o,"Generator"),nt(f,n,function(){return this}),nt(f,"toString",function(){return"[object Generator]"}),(rt=function(){return{w:i,m:p}})()}function nt(t,e,r,n){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}nt=function(t,e,r,n){function i(e,r){nt(t,e,function(t){return this._invoke(e,r,t)})}e?o?o(t,e,{value:r,enumerable:!n,configurable:!n,writable:!n}):t[e]=r:(i("next",0),i("throw",1),i("return",2))},nt(t,e,r,n)}function ot(t,e,r,n,o,i,a){try{var c=t[i](a),s=c.value}catch(t){return void r(t)}c.done?e(s):Promise.resolve(s).then(n,o)}var it="frm-checklist__step";function at(t){return ct.apply(this,arguments)}function ct(){var t;return t=rt().m(function t(e){var r,n,o,i;return rt().w(function(t){for(;;)switch(t.p=t.n){case 0:if(p().checklist){t.n=1;break}return t.a(2);case 1:if(r=document.getElementById("".concat(it,"-").concat(e))){t.n=2;break}return t.a(2);case 2:if(r.classList.contains("".concat(it,"--active"))){t.n=3;break}return t.a(2);case 3:return(n=new FormData).append("step_key",e),t.p=4,t.n=5,Z("mark_checklist_step_as_completed",n);case 5:if(r.classList.remove("".concat(it,"--active")),r.classList.add("".concat(it,"--completed")),o=r.nextElementSibling){t.n=6;break}return t.a(2);case 6:o.classList.add("".concat(it,"--active")),o.dataset.link&&st(o),t.n=8;break;case 7:t.p=7,i=t.v,console.error("Failed to mark step as completed:",i);case 8:return t.a(2)}},t,null,[[4,7]])}),ct=function(){var e=this,r=arguments;return new Promise(function(n,o){var i=t.apply(e,r);function a(t){ot(i,n,o,a,c,"next",t)}function c(t){ot(i,n,o,a,c,"throw",t)}a(void 0)})},ct.apply(this,arguments)}function st(t){var e=t.querySelector(".frm-checklist__step-title");if(null==e||!e.querySelector("a")){var r=q({href:t.dataset.link,className:"frm-h-stack-xs",children:Array.from(e.childNodes)});e.replaceChildren(r)}}function ut(){var t=p(),e=t.welcomeTour,r=t.spotlight;null==e||e.remove(),null==r||r.remove(),Z("dismiss_welcome_tour",new FormData)}function lt(){var t,e,r="function"==typeof Symbol?Symbol:{},n=r.iterator||"@@iterator",o=r.toStringTag||"@@toStringTag";function i(r,n,o,i){var s=n&&n.prototype instanceof c?n:c,u=Object.create(s.prototype);return ft(u,"_invoke",function(r,n,o){var i,c,s,u=0,l=o||[],f=!1,p={p:0,n:0,v:t,a:d,f:d.bind(t,4),d:function(e,r){return i=e,c=0,s=t,p.n=r,a}};function d(r,n){for(c=r,s=n,e=0;!f&&u&&!o&&e3?(o=h===n)&&(s=i[(c=i[4])?5:(c=3,3)],i[4]=i[5]=t):i[0]<=d&&((o=r<2&&dn||n>h)&&(i[4]=r,i[5]=n,p.n=h,c=0))}if(o||r>1)return a;throw f=!0,n}return function(o,l,h){if(u>1)throw TypeError("Generator is already running");for(f&&1===l&&d(l,h),c=l,s=h;(e=c<2?t:s)||!f;){i||(c?c<3?(c>1&&(p.n=-1),d(c,s)):p.n=s:p.v=s);try{if(u=2,i){if(c||(o="next"),e=i[o]){if(!(e=e.call(i,s)))throw TypeError("iterator result is not an object");if(!e.done)return e;s=e.value,c<2&&(c=0)}else 1===c&&(e=i.return)&&e.call(i),c<2&&(s=TypeError("The iterator does not provide a '"+o+"' method"),c=1);i=t}else if((e=(f=p.n<0)?s:r.call(n,p))!==a)break}catch(e){i=t,c=1,s=e}finally{u=1}}return{value:e,done:f}}}(r,o,i),!0),u}var a={};function c(){}function s(){}function u(){}e=Object.getPrototypeOf;var l=[][n]?e(e([][n]())):(ft(e={},n,function(){return this}),e),f=u.prototype=c.prototype=Object.create(l);function p(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,u):(t.__proto__=u,ft(t,o,"GeneratorFunction")),t.prototype=Object.create(f),t}return s.prototype=u,ft(f,"constructor",u),ft(u,"constructor",s),s.displayName="GeneratorFunction",ft(u,o,"GeneratorFunction"),ft(f),ft(f,o,"Generator"),ft(f,n,function(){return this}),ft(f,"toString",function(){return"[object Generator]"}),(lt=function(){return{w:i,m:p}})()}function ft(t,e,r,n){var o=Object.defineProperty;try{o({},"",{})}catch(t){o=0}ft=function(t,e,r,n){function i(e,r){ft(t,e,function(t){return this._invoke(e,r,t)})}e?o?o(t,e,{value:r,enumerable:!n,configurable:!n,writable:!n}):t[e]=r:(i("next",0),i("throw",1),i("return",2))},ft(t,e,r,n)}function pt(t,e,r,n,o,i,a){try{var c=t[i](a),s=c.value}catch(t){return void r(t)}c.done?e(s):Promise.resolve(s).then(n,o)}function dt(){return ht.apply(this,arguments)}function ht(){var t;return t=lt().m(function t(){return lt().w(function(t){for(;;)switch(t.n){case 0:return t.n=1,at("style-form");case 1:window.location.reload();case 2:return t.a(2)}},t)}),ht=function(){var e=this,r=arguments;return new Promise(function(n,o){var i=t.apply(e,r);function a(t){pt(i,n,o,a,c,"next",t)}function c(t){pt(i,n,o,a,c,"throw",t)}a(void 0)})},ht.apply(this,arguments)}var mt;mt=function(){var t,e;tt(),document.querySelectorAll(".frm-spotlight").forEach(function(t){setTimeout(function(){!function(t){var e=document.querySelector(t.dataset.target);e&&(document.body.append(t),function(t){for(var e=[window],r=t.parentElement;r&&document.body!==r;){var n=getComputedStyle(r),o=n.overflow,i=n.overflowY;(["auto","scroll"].includes(o)||["auto","scroll"].includes(i))&&e.push(r),r=r.parentElement}return e}(e).forEach(function(r){r.addEventListener("scroll",function(){et(t,e),function(t){var e=document.getElementById("frm_top_bar");if(e){var r=t.getBoundingClientRect().top+24<=e.getBoundingClientRect().bottom;r&&!t.classList.contains("frm-fadeout")?(t.classList.remove("frm-fadein"),t.classList.add("frm-fadeout")):r||t.classList.contains("frm-fadein")||(t.classList.remove("frm-fadeout"),t.classList.add("frm-fadein"))}}(t)},{passive:!0})}),window.addEventListener("resize",function(){return et(t,e)},{passive:!0}),setTimeout(function(){et(t,e),t.classList.remove("frm-force-hidden")},200))}(t)},0)}),(e=document.querySelector(".frm-welcome-tour .frm-checklist__progress-fill"))&&(e.style.width="".concat(Q,"%")),document.addEventListener("frm_added_field",function(){return at("add-fields")}),function(){var t=p().checklist;t&&t.querySelector(".frm-checklist__header").addEventListener("click",function(){return function(t){t.classList.toggle("frm-checklist--collapsed")}(t)})}(),(t=p().dismiss)&&t.addEventListener("click",ut),"formidable-styles"===H.get("page")&&K(document.getElementById("frm_submit_side_top"),dt)},"undefined"!=typeof document&&("complete"!==document.readyState&&"interactive"!==document.readyState?document.addEventListener("DOMContentLoaded",mt):mt())})()})(); \ No newline at end of file