From 839f0936edcd68c3f2119f3548765a9f7843b462 Mon Sep 17 00:00:00 2001 From: Justin Schroeder Date: Wed, 26 Feb 2020 00:21:10 -0500 Subject: [PATCH] Fixes form submissions, and a bug that prevented value props from populating forms --- dist/formulate.esm.js | 2 +- dist/formulate.min.js | 2 +- dist/formulate.umd.js | 2 +- dist/snow.css | 2 +- dist/snow.min.css | 4 ++-- src/FormSubmission.js | 6 +++--- src/FormulateForm.vue | 17 +++++++++++++---- src/libs/utils.js | 2 +- test/FormulateForm.test.js | 29 +++++++++++++++++++++++++++-- test/utils.test.js | 36 +++++++++++++++++++++++++++++++++++- themes/snow/_inputs.scss | 2 +- 11 files changed, 86 insertions(+), 18 deletions(-) diff --git a/dist/formulate.esm.js b/dist/formulate.esm.js index 2496289..532f4f6 100644 --- a/dist/formulate.esm.js +++ b/dist/formulate.esm.js @@ -1776,7 +1776,7 @@ var script$1 = { this.$emit('submit-raw', submission); submission.hasValidationErrors() .then(function (hasErrors) { return hasErrors ? false : submission.values(); }) - .then(function (json) { return this$1.$emit('submit', json); }); + .then(function (json) { return json !== false ? this$1.$emit('submit', json) : null; }); }, showErrors: function showErrors () { for (var fieldName in this.registry) { diff --git a/dist/formulate.min.js b/dist/formulate.min.js index f752ccd..d952c83 100644 --- a/dist/formulate.min.js +++ b/dist/formulate.min.js @@ -1779,7 +1779,7 @@ var Formulate = (function (exports, isUrl, nanoid, isPlainObject) { this.$emit('submit-raw', submission); submission.hasValidationErrors() .then(function (hasErrors) { return hasErrors ? false : submission.values(); }) - .then(function (json) { return this$1.$emit('submit', json); }); + .then(function (json) { return json !== false ? this$1.$emit('submit', json) : null; }); }, showErrors: function showErrors () { for (var fieldName in this.registry) { diff --git a/dist/formulate.umd.js b/dist/formulate.umd.js index 1aad47c..ceb73c8 100644 --- a/dist/formulate.umd.js +++ b/dist/formulate.umd.js @@ -1782,7 +1782,7 @@ this.$emit('submit-raw', submission); submission.hasValidationErrors() .then(function (hasErrors) { return hasErrors ? false : submission.values(); }) - .then(function (json) { return this$1.$emit('submit', json); }); + .then(function (json) { return json !== false ? this$1.$emit('submit', json) : null; }); }, showErrors: function showErrors () { for (var fieldName in this.registry) { diff --git a/dist/snow.css b/dist/snow.css index 7e0a989..d70e72b 100644 --- a/dist/snow.css +++ b/dist/snow.css @@ -1,5 +1,5 @@ .formulate-input { - margin-bottom: 2em; } + margin-bottom: 1.5em; } .formulate-input .formulate-input-label { display: block; line-height: 1.5; diff --git a/dist/snow.min.css b/dist/snow.min.css index b32c4a7..1d793ba 100644 --- a/dist/snow.min.css +++ b/dist/snow.min.css @@ -1,2 +1,2 @@ -.formulate-input{margin-bottom:2em}.formulate-input .formulate-input-label{display:block;line-height:1.5;font-size:.9em;font-weight:600;margin-bottom:.1em}.formulate-input .formulate-input-element{max-width:20em;margin-bottom:.1em}.formulate-input .formulate-input-help{color:#6d6d6d;font-size:.7em;font-weight:400;line-height:1.5;margin-bottom:.25em}.formulate-input .formulate-input-errors{list-style-type:none;padding:0;margin:0}.formulate-input .formulate-file-upload-error,.formulate-input .formulate-input-error{color:#960505;font-size:.8em;font-weight:300;line-height:1.5;margin-bottom:.25em}.formulate-input .formulate-input-group-item{margin-bottom:.5em}.formulate-input:last-child{margin-bottom:0}.formulate-input[data-classification=text] input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0}.formulate-input[data-classification=text] input::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input::placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=text] input[type=color]{height:1.1em;box-sizing:content-box}.formulate-input[data-classification=text] input[type=color]::-webkit-color-swatch-wrapper{padding:0 0 0 1.5em;display:flex;align-items:center;background-image:url('data:image/svg+xml;utf8,');background-repeat:no-repeat;background-size:.9em .9em;background-position:left .1em}.formulate-input[data-classification=text] input[type=color]::-webkit-color-swatch{display:block;height:1em;border-radius:.2em;border:0;flex:auto}.formulate-input[data-classification=text] input[type=color]::-moz-color-swatch{display:block;height:1em;border-radius:.2em;border:0;flex:auto}.formulate-input[data-classification=slider] input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;font-size:1em;padding:.5em 0}.formulate-input[data-classification=slider] input:focus{outline:0}.formulate-input[data-classification=slider] input::-webkit-slider-thumb{cursor:pointer;-webkit-appearance:none;appearance:none;width:1em;height:1em;border-radius:1em;background-color:#41b883;margin-top:calc(-.5em + 2px)}.formulate-input[data-classification=slider] input::-moz-range-thumb{cursor:pointer;-moz-appearance:none;appearance:none;width:1em;height:1em;border-radius:1em;background-color:#41b883;margin-top:calc(-.5em + 2px)}.formulate-input[data-classification=slider] input::-ms-thumb{cursor:pointer;appearance:none;width:1em;height:1em;border-radius:1em;background-color:#41b883;margin-top:calc(-.5em + 2px)}.formulate-input[data-classification=slider] input::-webkit-slider-runnable-track{-webkit-appearance:none;appearance:none;width:100%;height:4px;background-color:#efefef;border-radius:3px;margin:0;padding:0}.formulate-input[data-classification=textarea] textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0}.formulate-input[data-classification=textarea] textarea::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea::placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=button] button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0;border:1px solid #41b883;background-color:#41b883;color:#fff;min-width:0;width:auto;font-weight:700;cursor:pointer;display:inline-flex;align-items:center}.formulate-input[data-classification=button] button::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button::placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=button] button[disabled]{background-color:#cecece;border-color:#cecece}.formulate-input[data-classification=button] button:active{background-color:#64c89b;border-color:#64c89b}.formulate-input[data-classification=select] .formulate-input-element{position:relative}.formulate-input[data-classification=select] .formulate-input-element:before{content:"";width:0;height:0;border-color:#cecece transparent transparent;border-style:solid;border-width:.3em .3em 0;top:50%;margin-top:-.1em;right:1em;position:absolute}.formulate-input[data-classification=select] select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0;padding:.75em 2em .75em .75em}.formulate-input[data-classification=select] select::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select::placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=select] select[data-placeholder-selected]{color:#a8a8a8}.formulate-input[data-classification=box] .formulate-input-wrapper{display:flex;align-items:center}.formulate-input[data-classification=box] .formulate-input-element{overflow:hidden;display:flex;align-items:center}.formulate-input[data-classification=box] .formulate-input-element input{position:absolute;left:-999px}.formulate-input[data-classification=box] .formulate-input-element-decorator{display:block;width:1em;height:1em;border-radius:.25em;border:1px solid #cecece;position:relative}.formulate-input[data-classification=box] .formulate-input-element-decorator:before{content:"";display:block;background-size:contain;background-position:100%;width:calc(100% - .125em);height:calc(100% - .125em);box-sizing:border-box;position:absolute;top:.0625em;left:.0625em}.formulate-input[data-classification=box] .formulate-input-element[data-type=radio] .formulate-input-element-decorator{border-radius:1em}.formulate-input[data-classification=box] .formulate-input-element[data-type=radio] .formulate-input-element-decorator:before{border-radius:1em;width:calc(100% - .5em);height:calc(100% - .5em);top:.25em;left:.25em}.formulate-input[data-classification=box] .formulate-input-element input[type=checkbox]:checked~.formulate-input-element-decorator{border-color:#41b883}.formulate-input[data-classification=box] .formulate-input-element input[type=checkbox]:checked~.formulate-input-element-decorator:before{background-color:#41b883;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,')}.formulate-input[data-classification=box] .formulate-input-element input[type=radio]:checked~.formulate-input-element-decorator{border-color:#41b883}.formulate-input[data-classification=box] .formulate-input-element input[type=radio]:checked~.formulate-input-element-decorator:before{background-color:#41b883}.formulate-input[data-classification=box] .formulate-input-element input:focus~.formulate-input-element-decorator{border-color:#41b883}.formulate-input[data-classification=box] .formulate-input-label--after{margin-left:.5em}.formulate-input[data-classification=box] .formulate-input-label--before{margin-right:.5em}.formulate-input[data-classification=group]>.formulate-input-wrapper>.formulate-input-label{margin-bottom:.5em}.formulate-input[data-classification=file] .formulate-input-upload-area{width:100%;position:relative;padding:2em 0}.formulate-input[data-classification=file] .formulate-input-upload-area input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;opacity:0;position:absolute;left:0;right:0;bottom:0;top:0;width:100%;height:100%;z-index:5}.formulate-input[data-classification=file] .formulate-input-upload-area[data-has-files]{padding:0}.formulate-input[data-classification=file] .formulate-input-upload-area[data-has-files] input{display:none}.formulate-input[data-classification=file] .formulate-input-upload-area-mask{border-radius:.4em;pointer-events:none;position:absolute;display:flex;justify-content:center;align-items:center;left:0;right:0;top:0;bottom:0;border:2px dashed #a8a8a8;z-index:2}.formulate-input[data-classification=file] .formulate-input-upload-area-mask:before{content:"";background-color:#a8a8a8;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;width:2em;height:2em;position:absolute;pointer-events:none}.formulate-input[data-classification=file] .formulate-input-upload-area input:focus~.formulate-input-upload-area-mask,.formulate-input[data-classification=file] .formulate-input-upload-area input:hover~.formulate-input-upload-area-mask,.formulate-input[data-classification=file] .formulate-input-upload-area input[data-is-drag-hover]~.formulate-input-upload-area-mask{border-color:#41b883}.formulate-input[data-classification=file] .formulate-input-upload-area input:focus~.formulate-input-upload-area-mask:before,.formulate-input[data-classification=file] .formulate-input-upload-area input:hover~.formulate-input-upload-area-mask:before,.formulate-input[data-classification=file] .formulate-input-upload-area input[data-is-drag-hover]~.formulate-input-upload-area-mask:before{background-color:#41b883}.formulate-input[data-classification=file] .formulate-files{list-style-type:none;margin:0;padding:0}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress{background-color:#cecece;height:.3em;border-radius:1.25em;width:5em;overflow:hidden;position:absolute;right:.75em;transition:height .25s,width .25s;z-index:2}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;display:block;opacity:0;transform:scale(.08);background-color:#fff;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-size:77%;mask-size:77%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;z-index:3}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-just-finished]{width:1.25em;height:1.25em}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-just-finished]:before{transition:transform .25s .2s,opacity .25s .2s;transform:scale(1);opacity:1}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-is-finished]{transition:height .25s,width .25s,left .25s,top,.25s,border-radius .25s;width:.3em;height:100%;right:0;border-radius:0 .23em .23em 0}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-is-finished]:before{transition:opacity .1s;opacity:0}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress .formulate-file-progress-inner{background-color:#41b883;width:1%;position:absolute;left:0;bottom:0;top:0;z-index:2}.formulate-input[data-classification=file] .formulate-files .formualte-file-name{padding-left:1.5em;padding-right:2em}.formulate-input[data-classification=file] .formulate-files .formualte-file-name:before{position:absolute;left:.7em;top:50%;margin-top:-.7em;background-color:#a8a8a8;content:"";-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain;width:1.25em;height:1.25em;display:inline-block;margin-right:.5em}.formulate-input[data-classification=file] .formulate-files .formulate-file-remove{width:1.25em;height:1.25em;border-radius:1em;border:1px solid #a8a8a8;background-color:#a8a8a8;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-size:.6em;mask-size:.6em;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;cursor:pointer;position:absolute;right:.75em;z-index:1;transition:transform .25s}@media (pointer:fine){.formulate-input[data-classification=file] .formulate-files .formulate-file-remove:hover{transform:scale(1.5)}}.formulate-input[data-classification=file] .formulate-files li{display:block}.formulate-input[data-classification=file] .formulate-files li[data-has-error] .formulate-file-progress{background-color:#dc2c2c}.formulate-input[data-classification=file] .formulate-files li[data-has-preview] .formualte-file-name:before{display:none}.formulate-input[data-classification=file] .formulate-files li+li{margin-top:.5em}.formulate-input[data-classification=file] .formulate-files .formulate-file{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;font-weight:400;line-height:1.1em;margin:0;display:block;width:100%;display:flex;justify-content:flex-start;align-items:center;position:relative}.formulate-input[data-classification=file] .formulate-files .formulate-file::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file::placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=file] .formulate-files .formulate-file ::-webkit-progress-bar{-webkit-appearance:none;appearance:none;height:.5em;border-radius:.5em;overflow:hidden}.formulate-input[data-classification=file] .formulate-files .formulate-file-image-preview{width:3em;height:3em;position:relative;z-index:2;left:-1px;box-shadow:0 0 0 1px #efefef;transition:transform .25s,box-shadow .25s,background-color .25s}@media (pointer:fine){.formulate-input[data-classification=file] .formulate-files .formulate-file-image-preview:hover{transition-delay:.2s;transform:scale(3);background-color:#fff;box-shadow:0 0 2px 0 rgba(0,0,0,.1)}}.formulate-input[data-classification=file] .formulate-files .formulate-file-image-preview img{display:block;position:absolute;width:100%;height:100%;left:0;right:0;bottom:0;top:0;-o-object-fit:contain;object-fit:contain;transition:all .25s}.formulate-input[data-classification=file] [data-type=image] .formulate-input-upload-area .formulate-input-upload-area-mask:before{-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,')} -/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["stdin"],"names":[],"mappings":"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","file":"stdin","sourcesContent":[".formulate-input {\n  margin-bottom: 2em; }\n  .formulate-input .formulate-input-label {\n    display: block;\n    line-height: 1.5;\n    font-size: .9em;\n    font-weight: 600;\n    margin-bottom: .1em; }\n  .formulate-input .formulate-input-element {\n    max-width: 20em;\n    margin-bottom: .1em; }\n  .formulate-input .formulate-input-help {\n    color: #6d6d6d;\n    font-size: .7em;\n    font-weight: 400;\n    line-height: 1.5;\n    margin-bottom: .25em; }\n  .formulate-input .formulate-input-errors {\n    list-style-type: none;\n    padding: 0;\n    margin: 0; }\n  .formulate-input .formulate-input-error,\n  .formulate-input .formulate-file-upload-error {\n    color: #960505;\n    font-size: .8em;\n    font-weight: 300;\n    line-height: 1.5;\n    margin-bottom: .25em; }\n  .formulate-input .formulate-input-group-item {\n    margin-bottom: .5em; }\n  .formulate-input:last-child {\n    margin-bottom: 0; }\n  .formulate-input[data-classification='text'] input {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0; }\n    .formulate-input[data-classification='text'] input::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='text'] input:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n  .formulate-input[data-classification='text'] input[type=\"color\"] {\n    height: 1.1em;\n    box-sizing: content-box; }\n    .formulate-input[data-classification='text'] input[type=\"color\"]::-webkit-color-swatch-wrapper {\n      padding: 0 0 0 1.5em;\n      display: flex;\n      align-items: center;\n      background-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 79.17 79.17\"><path fill=\"%236d6d6d\" d=\"M40.8,22.92c-3.4-3.4-4.76-8.44-1-12.24s8.84-2.44,12.24,1c5-5,10.69-13.33,18.81-11.31a11,11,0,0,1,7.62,14.34c-1.26,3.45-4.63,6.06-7.16,8.59-.92.93-3,2.26-3.46,3.46-.42,1,1.82,2.63,2.36,4a8,8,0,0,1-12.42,9.19c-.21-.16-1.35-1.51-1.59-1.51s-.83.83-1,1L49.71,44.9,32.43,62.18c-3.37,3.38-6.6,7.14-10.26,10.21a11,11,0,0,1-4.48,2.28c-1.25.3-3.11-.22-4.18.18-1.28.48-2.42,2.65-3.68,3.4-6.05,3.61-12.64-4-8.46-9.57.73-1,2.53-1.92,3-3a14.46,14.46,0,0,0-.09-2.52,10.75,10.75,0,0,1,3.14-6.77c.92-1,1.93-1.93,2.89-2.9Zm4.4-1.5c4.19,4,8.24,8.24,12.36,12.36,2.06,2.06,5,5.59,8,2.61,4.65-4.62-5-6.8-2.42-10.78C66.3,20.7,76.4,16.48,74.84,9.45,73.62,4,67.12,2.78,63.29,6.32c-2.55,2.36-4.93,4.94-7.39,7.4-.79.78-1.8,2.28-2.88,2.73-2.14.88-3.4-1.62-4.79-2.77-2.58-2.14-6.89-.82-6.53,3C41.89,18.68,43.87,20.09,45.2,21.42Zm-1.45,4.44L27.82,41.79C22,47.57,15.89,53.14,10.41,59.2a8.23,8.23,0,0,0-1.44,2c-.93,2,.25,4.14-.5,6S4.92,69.94,4.3,72a2.34,2.34,0,0,0,2.56,3c1.11-.17,2-1.33,2.71-2.07a11.17,11.17,0,0,1,2.08-2c1.68-.94,4,.17,5.93-.57C20,69.41,22,66.73,23.76,65L34.42,54.3,53.3,35.42Z\"/></svg>');\n      background-repeat: no-repeat;\n      background-size: .9em .9em;\n      background-position: left .1em; }\n    .formulate-input[data-classification='text'] input[type=\"color\"]::-webkit-color-swatch {\n      display: block;\n      height: 1em;\n      border-radius: .2em;\n      border: 0;\n      flex: auto; }\n    .formulate-input[data-classification='text'] input[type=\"color\"]::-moz-color-swatch {\n      display: block;\n      height: 1em;\n      border-radius: .2em;\n      border: 0;\n      flex: auto; }\n  .formulate-input[data-classification='slider'] input {\n    appearance: none;\n    width: 100%;\n    font-size: 1em;\n    padding: .5em 0; }\n    .formulate-input[data-classification='slider'] input:focus {\n      outline: 0; }\n    .formulate-input[data-classification='slider'] input::-webkit-slider-thumb {\n      cursor: pointer;\n      appearance: none;\n      width: 1em;\n      height: 1em;\n      border-radius: 1em;\n      background-color: #41b883;\n      margin-top: calc(-.5em + 2px); }\n    .formulate-input[data-classification='slider'] input::-moz-range-thumb {\n      cursor: pointer;\n      appearance: none;\n      width: 1em;\n      height: 1em;\n      border-radius: 1em;\n      background-color: #41b883;\n      margin-top: calc(-.5em + 2px); }\n    .formulate-input[data-classification='slider'] input::-ms-thumb {\n      cursor: pointer;\n      appearance: none;\n      width: 1em;\n      height: 1em;\n      border-radius: 1em;\n      background-color: #41b883;\n      margin-top: calc(-.5em + 2px); }\n    .formulate-input[data-classification='slider'] input::-webkit-slider-runnable-track {\n      appearance: none;\n      width: 100%;\n      height: 4px;\n      background-color: #efefef;\n      border-radius: 3px;\n      margin: 0;\n      padding: 0; }\n  .formulate-input[data-classification='textarea'] textarea {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0; }\n    .formulate-input[data-classification='textarea'] textarea::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='textarea'] textarea:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n  .formulate-input[data-classification='button'] button {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0;\n    border-color: #41b883;\n    background-color: #41b883;\n    color: white;\n    min-width: 0;\n    width: auto;\n    font-weight: bold;\n    cursor: pointer;\n    display: inline-flex;\n    align-items: center; }\n    .formulate-input[data-classification='button'] button::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='button'] button:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n    .formulate-input[data-classification='button'] button[disabled] {\n      background-color: #cecece;\n      border-color: #cecece; }\n    .formulate-input[data-classification='button'] button:active {\n      background-color: #64c89b;\n      border-color: #64c89b; }\n  .formulate-input[data-classification='select'] .formulate-input-element {\n    position: relative; }\n    .formulate-input[data-classification='select'] .formulate-input-element::before {\n      content: '';\n      width: 0;\n      height: 0;\n      border: .3em solid transparent;\n      border-top-color: #cecece;\n      border-bottom-width: 0;\n      top: 50%;\n      margin-top: -.1em;\n      right: 1em;\n      position: absolute; }\n  .formulate-input[data-classification='select'] select {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0;\n    padding-right: 2em; }\n    .formulate-input[data-classification='select'] select::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='select'] select:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n    .formulate-input[data-classification='select'] select[data-placeholder-selected] {\n      color: #a8a8a8; }\n  .formulate-input[data-classification='box'] .formulate-input-wrapper {\n    display: flex;\n    align-items: center; }\n  .formulate-input[data-classification='box'] .formulate-input-element {\n    overflow: hidden;\n    display: flex;\n    align-items: center; }\n    .formulate-input[data-classification='box'] .formulate-input-element input {\n      position: absolute;\n      left: -999px; }\n    .formulate-input[data-classification='box'] .formulate-input-element-decorator {\n      display: block;\n      width: 1em;\n      height: 1em;\n      border-radius: .25em;\n      border: 1px solid #cecece;\n      position: relative; }\n      .formulate-input[data-classification='box'] .formulate-input-element-decorator::before {\n        content: '';\n        display: block;\n        background-size: contain;\n        background-position: right;\n        width: calc(100% - .125em);\n        height: calc(100% - .125em);\n        box-sizing: border-box;\n        position: absolute;\n        top: .0625em;\n        left: .0625em; }\n    .formulate-input[data-classification='box'] .formulate-input-element[data-type=\"radio\"] .formulate-input-element-decorator {\n      border-radius: 1em; }\n      .formulate-input[data-classification='box'] .formulate-input-element[data-type=\"radio\"] .formulate-input-element-decorator::before {\n        border-radius: 1em;\n        width: calc(100% - .5em);\n        height: calc(100% - .5em);\n        top: .25em;\n        left: .25em; }\n    .formulate-input[data-classification='box'] .formulate-input-element input[type=\"checkbox\"]:checked ~ .formulate-input-element-decorator {\n      border-color: #41b883; }\n      .formulate-input[data-classification='box'] .formulate-input-element input[type=\"checkbox\"]:checked ~ .formulate-input-element-decorator::before {\n        background-color: #41b883;\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\"><path d=\"M8.76,56.2c-6.38-6.34,3.26-16,9.64-9.69L38,65.88,80.56,23.29c6.38-6.38,16.07,3.32,9.69,9.69L42.84,80.37a6.83,6.83,0,0,1-9.65,0Z\"/></svg>'); }\n    .formulate-input[data-classification='box'] .formulate-input-element input[type=\"radio\"]:checked ~ .formulate-input-element-decorator {\n      border-color: #41b883; }\n      .formulate-input[data-classification='box'] .formulate-input-element input[type=\"radio\"]:checked ~ .formulate-input-element-decorator::before {\n        background-color: #41b883; }\n    .formulate-input[data-classification='box'] .formulate-input-element input:focus ~ .formulate-input-element-decorator {\n      border-color: #41b883; }\n  .formulate-input[data-classification='box'] .formulate-input-label--after {\n    margin-left: .5em; }\n  .formulate-input[data-classification='box'] .formulate-input-label--before {\n    margin-right: .5em; }\n  .formulate-input[data-classification=\"group\"] > .formulate-input-wrapper > .formulate-input-label {\n    margin-bottom: .5em; }\n  .formulate-input[data-classification=\"file\"] .formulate-input-upload-area {\n    width: 100%;\n    position: relative;\n    padding: 2em 0; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input {\n      cursor: pointer;\n      appearance: none;\n      opacity: 0;\n      position: absolute;\n      left: 0;\n      right: 0;\n      bottom: 0;\n      top: 0;\n      width: 100%;\n      height: 100%;\n      z-index: 5; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area[data-has-files] {\n      padding: 0; }\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area[data-has-files] input {\n        display: none; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area-mask {\n      border-radius: .4em;\n      position: absolute;\n      pointer-events: none;\n      position: absolute;\n      display: flex;\n      justify-content: center;\n      align-items: center;\n      left: 0;\n      right: 0;\n      top: 0;\n      bottom: 0;\n      border: 2px dashed #a8a8a8;\n      z-index: 2; }\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area-mask::before {\n        content: '';\n        background-color: #a8a8a8;\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 58 58\"><path d=\"M29,58A29,29,0,1,0,0,29,29,29,0,0,0,29,58ZM29,4A25,25,0,1,1,4,29,25,25,0,0,1,29,4Z\"/><polygon points=\"27 22 27 44.4 31 44.4 31 22 41.7 31.1 44.3 28.1 29 15 13.7 28.1 16.3 31.1 27 22\"/></svg>');\n        mask-repeat: no-repeat;\n        mask-position: center;\n        width: 2em;\n        height: 2em;\n        position: absolute;\n        pointer-events: none; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:focus ~ .formulate-input-upload-area-mask,\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:hover ~ .formulate-input-upload-area-mask,\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input[data-is-drag-hover] ~ .formulate-input-upload-area-mask {\n      border-color: #41b883; }\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:focus ~ .formulate-input-upload-area-mask::before,\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:hover ~ .formulate-input-upload-area-mask::before,\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input[data-is-drag-hover] ~ .formulate-input-upload-area-mask::before {\n        background-color: #41b883; }\n  .formulate-input[data-classification=\"file\"] .formulate-files {\n    list-style-type: none;\n    margin: 0;\n    padding: 0; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress {\n      background-color: #cecece;\n      height: .3em;\n      border-radius: 1.25em;\n      width: 5em;\n      overflow: hidden;\n      position: absolute;\n      right: .75em;\n      transition: height .25s, width .25s;\n      z-index: 2; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress::before {\n        content: '';\n        position: absolute;\n        top: 0;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        display: block;\n        opacity: 0;\n        transform: scale(0.08);\n        background-color: #ffffff;\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\"><path d=\"M8.76,56.2c-6.38-6.34,3.26-16,9.64-9.69L38,65.88,80.56,23.29c6.38-6.38,16.07,3.32,9.69,9.69L42.84,80.37a6.83,6.83,0,0,1-9.65,0Z\"/></svg>');\n        mask-size: 77%;\n        mask-repeat: no-repeat;\n        mask-position: center;\n        z-index: 3; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-just-finished] {\n        width: 1.25em;\n        height: 1.25em; }\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-just-finished]::before {\n          transition: transform .25s .2s, opacity .25s .2s;\n          transform: scale(1);\n          opacity: 1; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-is-finished] {\n        transition: height .25s, width .25s, left .25s, top, .25s, border-radius .25s;\n        width: .3em;\n        height: 100%;\n        right: 0;\n        border-radius: 0 .23em .23em 0; }\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-is-finished]::before {\n          transition: opacity .1s;\n          opacity: 0; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress .formulate-file-progress-inner {\n        background-color: #41b883;\n        width: 1%;\n        position: absolute;\n        left: 0;\n        bottom: 0;\n        top: 0;\n        z-index: 2; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formualte-file-name {\n      padding-left: 1.5em;\n      padding-right: 2em; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formualte-file-name::before {\n        position: absolute;\n        left: .7em;\n        top: 50%;\n        margin-top: -.7em;\n        background-color: #a8a8a8;\n        content: '';\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 64.06 83.59\"><path d=\"M55.94,83.59a8.16,8.16,0,0,0,8.12-8.16V19.12a1.77,1.77,0,0,0-.52-1.25L46.21.59A1.69,1.69,0,0,0,45.14.08L44.69,0l-.18,0H8.13A8.18,8.18,0,0,0,0,8.16V75.41a8.16,8.16,0,0,0,8.13,8.16H55.94ZM46.68,6,58.11,17.38H46.68ZM3.52,75.43V8.16A4.64,4.64,0,0,1,8.13,3.52h35V19.16a1.75,1.75,0,0,0,1.76,1.74H60.55V75.43a4.65,4.65,0,0,1-4.61,4.65H8.13A4.65,4.65,0,0,1,3.52,75.43Z\"/></svg>');\n        mask-repeat: no-repeat;\n        mask-size: contain;\n        width: 1.25em;\n        height: 1.25em;\n        display: inline-block;\n        margin-right: .5em; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-remove {\n      width: 1.25em;\n      height: 1.25em;\n      border-radius: 1em;\n      border: 1px solid #a8a8a8;\n      background-color: #a8a8a8;\n      mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 59.1 59.2\"><path d=\"M1.6,57.7a5,5,0,0,0,3.5,1.5,4.85,4.85,0,0,0,3.5-1.5l21-21,21,21a5,5,0,0,0,3.5,1.5,4.85,4.85,0,0,0,3.5-1.5,5,5,0,0,0,0-7.1l-21-21,21-21a5,5,0,0,0,0-7.1,5,5,0,0,0-7.1,0l-21,21L8.6,1.7a5,5,0,0,0-7.1,0,5,5,0,0,0,0,7.1l21,21L1.6,50.7A4.83,4.83,0,0,0,1.6,57.7Z\"/></svg>');\n      mask-size: .6em;\n      mask-repeat: no-repeat;\n      mask-position: center;\n      cursor: pointer;\n      position: absolute;\n      right: .75em;\n      z-index: 1;\n      transition: transform .25s; }\n      @media (pointer: fine) {\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-remove:hover {\n          transform: scale(1.5); } }\n    .formulate-input[data-classification=\"file\"] .formulate-files li {\n      display: block; }\n      .formulate-input[data-classification=\"file\"] .formulate-files li[data-has-error] .formulate-file-progress {\n        background-color: #dc2c2c; }\n      .formulate-input[data-classification=\"file\"] .formulate-files li[data-has-preview] .formualte-file-name:before {\n        display: none; }\n      .formulate-input[data-classification=\"file\"] .formulate-files li + li {\n        margin-top: .5em; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file {\n      appearance: none;\n      border-radius: .3em;\n      border: 1px solid #cecece;\n      box-sizing: border-box;\n      background-color: transparent;\n      font-size: .9em;\n      font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n      padding: .75em;\n      display: block;\n      width: 100%;\n      font-weight: 400;\n      line-height: 1.1em;\n      margin: 0;\n      display: block;\n      width: 100%;\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n      position: relative; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file::placeholder {\n        color: #a8a8a8; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file:focus {\n        outline: 0;\n        border: 1px solid #41b883; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file ::-webkit-progress-bar {\n        appearance: none;\n        height: .5em;\n        border-radius: .5em;\n        overflow: hidden; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-image-preview {\n      width: 3em;\n      height: 3em;\n      position: relative;\n      z-index: 2;\n      left: -1px;\n      box-shadow: 0 0 0 1px #efefef;\n      transition: transform .25s, box-shadow .25s, background-color .25s; }\n      @media (pointer: fine) {\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-image-preview:hover {\n          transition-delay: .2s;\n          transform: scale(3);\n          background-color: #ffffff;\n          box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.1); } }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-image-preview img {\n        display: block;\n        position: absolute;\n        width: 100%;\n        height: 100%;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        top: 0;\n        object-fit: contain;\n        transition: all .25s; }\n  .formulate-input[data-classification=\"file\"] [data-type=\"image\"] .formulate-input-upload-area .formulate-input-upload-area-mask::before {\n    mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 90 71.05\"><path d=\"M82.89,0H7.1A7.12,7.12,0,0,0,0,7.11V64a7.11,7.11,0,0,0,7.1,7.1H82.9A7.11,7.11,0,0,0,90,64V7.11A7.12,7.12,0,0,0,82.89,0ZM69.28,39.35a5.44,5.44,0,0,0-8,0L50.58,50.74,32.38,30.88a5.31,5.31,0,0,0-7.92,0L4.74,52.4V7.11A2.37,2.37,0,0,1,7.11,4.74H82.9a2.37,2.37,0,0,1,2.36,2.37V56.3Z\"/><circle cx=\"67.74\" cy=\"22.26\" r=\"8.53\"/></svg>'); }\n"]} */ \ No newline at end of file +.formulate-input{margin-bottom:1.5em}.formulate-input .formulate-input-label{display:block;line-height:1.5;font-size:.9em;font-weight:600;margin-bottom:.1em}.formulate-input .formulate-input-element{max-width:20em;margin-bottom:.1em}.formulate-input .formulate-input-help{color:#6d6d6d;font-size:.7em;font-weight:400;line-height:1.5;margin-bottom:.25em}.formulate-input .formulate-input-errors{list-style-type:none;padding:0;margin:0}.formulate-input .formulate-file-upload-error,.formulate-input .formulate-input-error{color:#960505;font-size:.8em;font-weight:300;line-height:1.5;margin-bottom:.25em}.formulate-input .formulate-input-group-item{margin-bottom:.5em}.formulate-input:last-child{margin-bottom:0}.formulate-input[data-classification=text] input{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0}.formulate-input[data-classification=text] input::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input::placeholder{color:#a8a8a8}.formulate-input[data-classification=text] input:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=text] input[type=color]{height:1.1em;box-sizing:content-box}.formulate-input[data-classification=text] input[type=color]::-webkit-color-swatch-wrapper{padding:0 0 0 1.5em;display:flex;align-items:center;background-image:url('data:image/svg+xml;utf8,');background-repeat:no-repeat;background-size:.9em .9em;background-position:left .1em}.formulate-input[data-classification=text] input[type=color]::-webkit-color-swatch{display:block;height:1em;border-radius:.2em;border:0;flex:auto}.formulate-input[data-classification=text] input[type=color]::-moz-color-swatch{display:block;height:1em;border-radius:.2em;border:0;flex:auto}.formulate-input[data-classification=slider] input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;font-size:1em;padding:.5em 0}.formulate-input[data-classification=slider] input:focus{outline:0}.formulate-input[data-classification=slider] input::-webkit-slider-thumb{cursor:pointer;-webkit-appearance:none;appearance:none;width:1em;height:1em;border-radius:1em;background-color:#41b883;margin-top:calc(-.5em + 2px)}.formulate-input[data-classification=slider] input::-moz-range-thumb{cursor:pointer;-moz-appearance:none;appearance:none;width:1em;height:1em;border-radius:1em;background-color:#41b883;margin-top:calc(-.5em + 2px)}.formulate-input[data-classification=slider] input::-ms-thumb{cursor:pointer;appearance:none;width:1em;height:1em;border-radius:1em;background-color:#41b883;margin-top:calc(-.5em + 2px)}.formulate-input[data-classification=slider] input::-webkit-slider-runnable-track{-webkit-appearance:none;appearance:none;width:100%;height:4px;background-color:#efefef;border-radius:3px;margin:0;padding:0}.formulate-input[data-classification=textarea] textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0}.formulate-input[data-classification=textarea] textarea::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea::placeholder{color:#a8a8a8}.formulate-input[data-classification=textarea] textarea:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=button] button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0;border:1px solid #41b883;background-color:#41b883;color:#fff;min-width:0;width:auto;font-weight:700;cursor:pointer;display:inline-flex;align-items:center}.formulate-input[data-classification=button] button::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button::placeholder{color:#a8a8a8}.formulate-input[data-classification=button] button:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=button] button[disabled]{background-color:#cecece;border-color:#cecece}.formulate-input[data-classification=button] button:active{background-color:#64c89b;border-color:#64c89b}.formulate-input[data-classification=select] .formulate-input-element{position:relative}.formulate-input[data-classification=select] .formulate-input-element:before{content:"";width:0;height:0;border-color:#cecece transparent transparent;border-style:solid;border-width:.3em .3em 0;top:50%;margin-top:-.1em;right:1em;position:absolute}.formulate-input[data-classification=select] select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;display:block;width:100%;font-weight:400;line-height:1.1em;margin:0;padding:.75em 2em .75em .75em}.formulate-input[data-classification=select] select::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select::placeholder{color:#a8a8a8}.formulate-input[data-classification=select] select:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=select] select[data-placeholder-selected]{color:#a8a8a8}.formulate-input[data-classification=box] .formulate-input-wrapper{display:flex;align-items:center}.formulate-input[data-classification=box] .formulate-input-element{overflow:hidden;display:flex;align-items:center}.formulate-input[data-classification=box] .formulate-input-element input{position:absolute;left:-999px}.formulate-input[data-classification=box] .formulate-input-element-decorator{display:block;width:1em;height:1em;border-radius:.25em;border:1px solid #cecece;position:relative}.formulate-input[data-classification=box] .formulate-input-element-decorator:before{content:"";display:block;background-size:contain;background-position:100%;width:calc(100% - .125em);height:calc(100% - .125em);box-sizing:border-box;position:absolute;top:.0625em;left:.0625em}.formulate-input[data-classification=box] .formulate-input-element[data-type=radio] .formulate-input-element-decorator{border-radius:1em}.formulate-input[data-classification=box] .formulate-input-element[data-type=radio] .formulate-input-element-decorator:before{border-radius:1em;width:calc(100% - .5em);height:calc(100% - .5em);top:.25em;left:.25em}.formulate-input[data-classification=box] .formulate-input-element input[type=checkbox]:checked~.formulate-input-element-decorator{border-color:#41b883}.formulate-input[data-classification=box] .formulate-input-element input[type=checkbox]:checked~.formulate-input-element-decorator:before{background-color:#41b883;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,')}.formulate-input[data-classification=box] .formulate-input-element input[type=radio]:checked~.formulate-input-element-decorator{border-color:#41b883}.formulate-input[data-classification=box] .formulate-input-element input[type=radio]:checked~.formulate-input-element-decorator:before{background-color:#41b883}.formulate-input[data-classification=box] .formulate-input-element input:focus~.formulate-input-element-decorator{border-color:#41b883}.formulate-input[data-classification=box] .formulate-input-label--after{margin-left:.5em}.formulate-input[data-classification=box] .formulate-input-label--before{margin-right:.5em}.formulate-input[data-classification=group]>.formulate-input-wrapper>.formulate-input-label{margin-bottom:.5em}.formulate-input[data-classification=file] .formulate-input-upload-area{width:100%;position:relative;padding:2em 0}.formulate-input[data-classification=file] .formulate-input-upload-area input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;opacity:0;position:absolute;left:0;right:0;bottom:0;top:0;width:100%;height:100%;z-index:5}.formulate-input[data-classification=file] .formulate-input-upload-area[data-has-files]{padding:0}.formulate-input[data-classification=file] .formulate-input-upload-area[data-has-files] input{display:none}.formulate-input[data-classification=file] .formulate-input-upload-area-mask{border-radius:.4em;pointer-events:none;position:absolute;display:flex;justify-content:center;align-items:center;left:0;right:0;top:0;bottom:0;border:2px dashed #a8a8a8;z-index:2}.formulate-input[data-classification=file] .formulate-input-upload-area-mask:before{content:"";background-color:#a8a8a8;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;width:2em;height:2em;position:absolute;pointer-events:none}.formulate-input[data-classification=file] .formulate-input-upload-area input:focus~.formulate-input-upload-area-mask,.formulate-input[data-classification=file] .formulate-input-upload-area input:hover~.formulate-input-upload-area-mask,.formulate-input[data-classification=file] .formulate-input-upload-area input[data-is-drag-hover]~.formulate-input-upload-area-mask{border-color:#41b883}.formulate-input[data-classification=file] .formulate-input-upload-area input:focus~.formulate-input-upload-area-mask:before,.formulate-input[data-classification=file] .formulate-input-upload-area input:hover~.formulate-input-upload-area-mask:before,.formulate-input[data-classification=file] .formulate-input-upload-area input[data-is-drag-hover]~.formulate-input-upload-area-mask:before{background-color:#41b883}.formulate-input[data-classification=file] .formulate-files{list-style-type:none;margin:0;padding:0}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress{background-color:#cecece;height:.3em;border-radius:1.25em;width:5em;overflow:hidden;position:absolute;right:.75em;transition:height .25s,width .25s;z-index:2}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;display:block;opacity:0;transform:scale(.08);background-color:#fff;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-size:77%;mask-size:77%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;z-index:3}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-just-finished]{width:1.25em;height:1.25em}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-just-finished]:before{transition:transform .25s .2s,opacity .25s .2s;transform:scale(1);opacity:1}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-is-finished]{transition:height .25s,width .25s,left .25s,top,.25s,border-radius .25s;width:.3em;height:100%;right:0;border-radius:0 .23em .23em 0}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress[data-is-finished]:before{transition:opacity .1s;opacity:0}.formulate-input[data-classification=file] .formulate-files .formulate-file-progress .formulate-file-progress-inner{background-color:#41b883;width:1%;position:absolute;left:0;bottom:0;top:0;z-index:2}.formulate-input[data-classification=file] .formulate-files .formualte-file-name{padding-left:1.5em;padding-right:2em}.formulate-input[data-classification=file] .formulate-files .formualte-file-name:before{position:absolute;left:.7em;top:50%;margin-top:-.7em;background-color:#a8a8a8;content:"";-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain;width:1.25em;height:1.25em;display:inline-block;margin-right:.5em}.formulate-input[data-classification=file] .formulate-files .formulate-file-remove{width:1.25em;height:1.25em;border-radius:1em;border:1px solid #a8a8a8;background-color:#a8a8a8;-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,');-webkit-mask-size:.6em;mask-size:.6em;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;cursor:pointer;position:absolute;right:.75em;z-index:1;transition:transform .25s}@media (pointer:fine){.formulate-input[data-classification=file] .formulate-files .formulate-file-remove:hover{transform:scale(1.5)}}.formulate-input[data-classification=file] .formulate-files li{display:block}.formulate-input[data-classification=file] .formulate-files li[data-has-error] .formulate-file-progress{background-color:#dc2c2c}.formulate-input[data-classification=file] .formulate-files li[data-has-preview] .formualte-file-name:before{display:none}.formulate-input[data-classification=file] .formulate-files li+li{margin-top:.5em}.formulate-input[data-classification=file] .formulate-files .formulate-file{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:.3em;border:1px solid #cecece;box-sizing:border-box;background-color:transparent;font-size:.9em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;padding:.75em;font-weight:400;line-height:1.1em;margin:0;display:block;width:100%;display:flex;justify-content:flex-start;align-items:center;position:relative}.formulate-input[data-classification=file] .formulate-files .formulate-file::-webkit-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file::-moz-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file:-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file::-ms-input-placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file::placeholder{color:#a8a8a8}.formulate-input[data-classification=file] .formulate-files .formulate-file:focus{outline:0;border:1px solid #41b883}.formulate-input[data-classification=file] .formulate-files .formulate-file ::-webkit-progress-bar{-webkit-appearance:none;appearance:none;height:.5em;border-radius:.5em;overflow:hidden}.formulate-input[data-classification=file] .formulate-files .formulate-file-image-preview{width:3em;height:3em;position:relative;z-index:2;left:-1px;box-shadow:0 0 0 1px #efefef;transition:transform .25s,box-shadow .25s,background-color .25s}@media (pointer:fine){.formulate-input[data-classification=file] .formulate-files .formulate-file-image-preview:hover{transition-delay:.2s;transform:scale(3);background-color:#fff;box-shadow:0 0 2px 0 rgba(0,0,0,.1)}}.formulate-input[data-classification=file] .formulate-files .formulate-file-image-preview img{display:block;position:absolute;width:100%;height:100%;left:0;right:0;bottom:0;top:0;-o-object-fit:contain;object-fit:contain;transition:all .25s}.formulate-input[data-classification=file] [data-type=image] .formulate-input-upload-area .formulate-input-upload-area-mask:before{-webkit-mask-image:url('data:image/svg+xml;utf8,');mask-image:url('data:image/svg+xml;utf8,')} +/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["stdin"],"names":[],"mappings":"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","file":"stdin","sourcesContent":[".formulate-input {\n  margin-bottom: 1.5em; }\n  .formulate-input .formulate-input-label {\n    display: block;\n    line-height: 1.5;\n    font-size: .9em;\n    font-weight: 600;\n    margin-bottom: .1em; }\n  .formulate-input .formulate-input-element {\n    max-width: 20em;\n    margin-bottom: .1em; }\n  .formulate-input .formulate-input-help {\n    color: #6d6d6d;\n    font-size: .7em;\n    font-weight: 400;\n    line-height: 1.5;\n    margin-bottom: .25em; }\n  .formulate-input .formulate-input-errors {\n    list-style-type: none;\n    padding: 0;\n    margin: 0; }\n  .formulate-input .formulate-input-error,\n  .formulate-input .formulate-file-upload-error {\n    color: #960505;\n    font-size: .8em;\n    font-weight: 300;\n    line-height: 1.5;\n    margin-bottom: .25em; }\n  .formulate-input .formulate-input-group-item {\n    margin-bottom: .5em; }\n  .formulate-input:last-child {\n    margin-bottom: 0; }\n  .formulate-input[data-classification='text'] input {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0; }\n    .formulate-input[data-classification='text'] input::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='text'] input:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n  .formulate-input[data-classification='text'] input[type=\"color\"] {\n    height: 1.1em;\n    box-sizing: content-box; }\n    .formulate-input[data-classification='text'] input[type=\"color\"]::-webkit-color-swatch-wrapper {\n      padding: 0 0 0 1.5em;\n      display: flex;\n      align-items: center;\n      background-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 79.17 79.17\"><path fill=\"%236d6d6d\" d=\"M40.8,22.92c-3.4-3.4-4.76-8.44-1-12.24s8.84-2.44,12.24,1c5-5,10.69-13.33,18.81-11.31a11,11,0,0,1,7.62,14.34c-1.26,3.45-4.63,6.06-7.16,8.59-.92.93-3,2.26-3.46,3.46-.42,1,1.82,2.63,2.36,4a8,8,0,0,1-12.42,9.19c-.21-.16-1.35-1.51-1.59-1.51s-.83.83-1,1L49.71,44.9,32.43,62.18c-3.37,3.38-6.6,7.14-10.26,10.21a11,11,0,0,1-4.48,2.28c-1.25.3-3.11-.22-4.18.18-1.28.48-2.42,2.65-3.68,3.4-6.05,3.61-12.64-4-8.46-9.57.73-1,2.53-1.92,3-3a14.46,14.46,0,0,0-.09-2.52,10.75,10.75,0,0,1,3.14-6.77c.92-1,1.93-1.93,2.89-2.9Zm4.4-1.5c4.19,4,8.24,8.24,12.36,12.36,2.06,2.06,5,5.59,8,2.61,4.65-4.62-5-6.8-2.42-10.78C66.3,20.7,76.4,16.48,74.84,9.45,73.62,4,67.12,2.78,63.29,6.32c-2.55,2.36-4.93,4.94-7.39,7.4-.79.78-1.8,2.28-2.88,2.73-2.14.88-3.4-1.62-4.79-2.77-2.58-2.14-6.89-.82-6.53,3C41.89,18.68,43.87,20.09,45.2,21.42Zm-1.45,4.44L27.82,41.79C22,47.57,15.89,53.14,10.41,59.2a8.23,8.23,0,0,0-1.44,2c-.93,2,.25,4.14-.5,6S4.92,69.94,4.3,72a2.34,2.34,0,0,0,2.56,3c1.11-.17,2-1.33,2.71-2.07a11.17,11.17,0,0,1,2.08-2c1.68-.94,4,.17,5.93-.57C20,69.41,22,66.73,23.76,65L34.42,54.3,53.3,35.42Z\"/></svg>');\n      background-repeat: no-repeat;\n      background-size: .9em .9em;\n      background-position: left .1em; }\n    .formulate-input[data-classification='text'] input[type=\"color\"]::-webkit-color-swatch {\n      display: block;\n      height: 1em;\n      border-radius: .2em;\n      border: 0;\n      flex: auto; }\n    .formulate-input[data-classification='text'] input[type=\"color\"]::-moz-color-swatch {\n      display: block;\n      height: 1em;\n      border-radius: .2em;\n      border: 0;\n      flex: auto; }\n  .formulate-input[data-classification='slider'] input {\n    appearance: none;\n    width: 100%;\n    font-size: 1em;\n    padding: .5em 0; }\n    .formulate-input[data-classification='slider'] input:focus {\n      outline: 0; }\n    .formulate-input[data-classification='slider'] input::-webkit-slider-thumb {\n      cursor: pointer;\n      appearance: none;\n      width: 1em;\n      height: 1em;\n      border-radius: 1em;\n      background-color: #41b883;\n      margin-top: calc(-.5em + 2px); }\n    .formulate-input[data-classification='slider'] input::-moz-range-thumb {\n      cursor: pointer;\n      appearance: none;\n      width: 1em;\n      height: 1em;\n      border-radius: 1em;\n      background-color: #41b883;\n      margin-top: calc(-.5em + 2px); }\n    .formulate-input[data-classification='slider'] input::-ms-thumb {\n      cursor: pointer;\n      appearance: none;\n      width: 1em;\n      height: 1em;\n      border-radius: 1em;\n      background-color: #41b883;\n      margin-top: calc(-.5em + 2px); }\n    .formulate-input[data-classification='slider'] input::-webkit-slider-runnable-track {\n      appearance: none;\n      width: 100%;\n      height: 4px;\n      background-color: #efefef;\n      border-radius: 3px;\n      margin: 0;\n      padding: 0; }\n  .formulate-input[data-classification='textarea'] textarea {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0; }\n    .formulate-input[data-classification='textarea'] textarea::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='textarea'] textarea:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n  .formulate-input[data-classification='button'] button {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0;\n    border-color: #41b883;\n    background-color: #41b883;\n    color: white;\n    min-width: 0;\n    width: auto;\n    font-weight: bold;\n    cursor: pointer;\n    display: inline-flex;\n    align-items: center; }\n    .formulate-input[data-classification='button'] button::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='button'] button:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n    .formulate-input[data-classification='button'] button[disabled] {\n      background-color: #cecece;\n      border-color: #cecece; }\n    .formulate-input[data-classification='button'] button:active {\n      background-color: #64c89b;\n      border-color: #64c89b; }\n  .formulate-input[data-classification='select'] .formulate-input-element {\n    position: relative; }\n    .formulate-input[data-classification='select'] .formulate-input-element::before {\n      content: '';\n      width: 0;\n      height: 0;\n      border: .3em solid transparent;\n      border-top-color: #cecece;\n      border-bottom-width: 0;\n      top: 50%;\n      margin-top: -.1em;\n      right: 1em;\n      position: absolute; }\n  .formulate-input[data-classification='select'] select {\n    appearance: none;\n    border-radius: .3em;\n    border: 1px solid #cecece;\n    box-sizing: border-box;\n    background-color: transparent;\n    font-size: .9em;\n    font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n    padding: .75em;\n    display: block;\n    width: 100%;\n    font-weight: 400;\n    line-height: 1.1em;\n    margin: 0;\n    padding-right: 2em; }\n    .formulate-input[data-classification='select'] select::placeholder {\n      color: #a8a8a8; }\n    .formulate-input[data-classification='select'] select:focus {\n      outline: 0;\n      border: 1px solid #41b883; }\n    .formulate-input[data-classification='select'] select[data-placeholder-selected] {\n      color: #a8a8a8; }\n  .formulate-input[data-classification='box'] .formulate-input-wrapper {\n    display: flex;\n    align-items: center; }\n  .formulate-input[data-classification='box'] .formulate-input-element {\n    overflow: hidden;\n    display: flex;\n    align-items: center; }\n    .formulate-input[data-classification='box'] .formulate-input-element input {\n      position: absolute;\n      left: -999px; }\n    .formulate-input[data-classification='box'] .formulate-input-element-decorator {\n      display: block;\n      width: 1em;\n      height: 1em;\n      border-radius: .25em;\n      border: 1px solid #cecece;\n      position: relative; }\n      .formulate-input[data-classification='box'] .formulate-input-element-decorator::before {\n        content: '';\n        display: block;\n        background-size: contain;\n        background-position: right;\n        width: calc(100% - .125em);\n        height: calc(100% - .125em);\n        box-sizing: border-box;\n        position: absolute;\n        top: .0625em;\n        left: .0625em; }\n    .formulate-input[data-classification='box'] .formulate-input-element[data-type=\"radio\"] .formulate-input-element-decorator {\n      border-radius: 1em; }\n      .formulate-input[data-classification='box'] .formulate-input-element[data-type=\"radio\"] .formulate-input-element-decorator::before {\n        border-radius: 1em;\n        width: calc(100% - .5em);\n        height: calc(100% - .5em);\n        top: .25em;\n        left: .25em; }\n    .formulate-input[data-classification='box'] .formulate-input-element input[type=\"checkbox\"]:checked ~ .formulate-input-element-decorator {\n      border-color: #41b883; }\n      .formulate-input[data-classification='box'] .formulate-input-element input[type=\"checkbox\"]:checked ~ .formulate-input-element-decorator::before {\n        background-color: #41b883;\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\"><path d=\"M8.76,56.2c-6.38-6.34,3.26-16,9.64-9.69L38,65.88,80.56,23.29c6.38-6.38,16.07,3.32,9.69,9.69L42.84,80.37a6.83,6.83,0,0,1-9.65,0Z\"/></svg>'); }\n    .formulate-input[data-classification='box'] .formulate-input-element input[type=\"radio\"]:checked ~ .formulate-input-element-decorator {\n      border-color: #41b883; }\n      .formulate-input[data-classification='box'] .formulate-input-element input[type=\"radio\"]:checked ~ .formulate-input-element-decorator::before {\n        background-color: #41b883; }\n    .formulate-input[data-classification='box'] .formulate-input-element input:focus ~ .formulate-input-element-decorator {\n      border-color: #41b883; }\n  .formulate-input[data-classification='box'] .formulate-input-label--after {\n    margin-left: .5em; }\n  .formulate-input[data-classification='box'] .formulate-input-label--before {\n    margin-right: .5em; }\n  .formulate-input[data-classification=\"group\"] > .formulate-input-wrapper > .formulate-input-label {\n    margin-bottom: .5em; }\n  .formulate-input[data-classification=\"file\"] .formulate-input-upload-area {\n    width: 100%;\n    position: relative;\n    padding: 2em 0; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input {\n      cursor: pointer;\n      appearance: none;\n      opacity: 0;\n      position: absolute;\n      left: 0;\n      right: 0;\n      bottom: 0;\n      top: 0;\n      width: 100%;\n      height: 100%;\n      z-index: 5; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area[data-has-files] {\n      padding: 0; }\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area[data-has-files] input {\n        display: none; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area-mask {\n      border-radius: .4em;\n      position: absolute;\n      pointer-events: none;\n      position: absolute;\n      display: flex;\n      justify-content: center;\n      align-items: center;\n      left: 0;\n      right: 0;\n      top: 0;\n      bottom: 0;\n      border: 2px dashed #a8a8a8;\n      z-index: 2; }\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area-mask::before {\n        content: '';\n        background-color: #a8a8a8;\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 58 58\"><path d=\"M29,58A29,29,0,1,0,0,29,29,29,0,0,0,29,58ZM29,4A25,25,0,1,1,4,29,25,25,0,0,1,29,4Z\"/><polygon points=\"27 22 27 44.4 31 44.4 31 22 41.7 31.1 44.3 28.1 29 15 13.7 28.1 16.3 31.1 27 22\"/></svg>');\n        mask-repeat: no-repeat;\n        mask-position: center;\n        width: 2em;\n        height: 2em;\n        position: absolute;\n        pointer-events: none; }\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:focus ~ .formulate-input-upload-area-mask,\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:hover ~ .formulate-input-upload-area-mask,\n    .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input[data-is-drag-hover] ~ .formulate-input-upload-area-mask {\n      border-color: #41b883; }\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:focus ~ .formulate-input-upload-area-mask::before,\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input:hover ~ .formulate-input-upload-area-mask::before,\n      .formulate-input[data-classification=\"file\"] .formulate-input-upload-area input[data-is-drag-hover] ~ .formulate-input-upload-area-mask::before {\n        background-color: #41b883; }\n  .formulate-input[data-classification=\"file\"] .formulate-files {\n    list-style-type: none;\n    margin: 0;\n    padding: 0; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress {\n      background-color: #cecece;\n      height: .3em;\n      border-radius: 1.25em;\n      width: 5em;\n      overflow: hidden;\n      position: absolute;\n      right: .75em;\n      transition: height .25s, width .25s;\n      z-index: 2; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress::before {\n        content: '';\n        position: absolute;\n        top: 0;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        display: block;\n        opacity: 0;\n        transform: scale(0.08);\n        background-color: #ffffff;\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 100 100\"><path d=\"M8.76,56.2c-6.38-6.34,3.26-16,9.64-9.69L38,65.88,80.56,23.29c6.38-6.38,16.07,3.32,9.69,9.69L42.84,80.37a6.83,6.83,0,0,1-9.65,0Z\"/></svg>');\n        mask-size: 77%;\n        mask-repeat: no-repeat;\n        mask-position: center;\n        z-index: 3; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-just-finished] {\n        width: 1.25em;\n        height: 1.25em; }\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-just-finished]::before {\n          transition: transform .25s .2s, opacity .25s .2s;\n          transform: scale(1);\n          opacity: 1; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-is-finished] {\n        transition: height .25s, width .25s, left .25s, top, .25s, border-radius .25s;\n        width: .3em;\n        height: 100%;\n        right: 0;\n        border-radius: 0 .23em .23em 0; }\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress[data-is-finished]::before {\n          transition: opacity .1s;\n          opacity: 0; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-progress .formulate-file-progress-inner {\n        background-color: #41b883;\n        width: 1%;\n        position: absolute;\n        left: 0;\n        bottom: 0;\n        top: 0;\n        z-index: 2; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formualte-file-name {\n      padding-left: 1.5em;\n      padding-right: 2em; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formualte-file-name::before {\n        position: absolute;\n        left: .7em;\n        top: 50%;\n        margin-top: -.7em;\n        background-color: #a8a8a8;\n        content: '';\n        mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 64.06 83.59\"><path d=\"M55.94,83.59a8.16,8.16,0,0,0,8.12-8.16V19.12a1.77,1.77,0,0,0-.52-1.25L46.21.59A1.69,1.69,0,0,0,45.14.08L44.69,0l-.18,0H8.13A8.18,8.18,0,0,0,0,8.16V75.41a8.16,8.16,0,0,0,8.13,8.16H55.94ZM46.68,6,58.11,17.38H46.68ZM3.52,75.43V8.16A4.64,4.64,0,0,1,8.13,3.52h35V19.16a1.75,1.75,0,0,0,1.76,1.74H60.55V75.43a4.65,4.65,0,0,1-4.61,4.65H8.13A4.65,4.65,0,0,1,3.52,75.43Z\"/></svg>');\n        mask-repeat: no-repeat;\n        mask-size: contain;\n        width: 1.25em;\n        height: 1.25em;\n        display: inline-block;\n        margin-right: .5em; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-remove {\n      width: 1.25em;\n      height: 1.25em;\n      border-radius: 1em;\n      border: 1px solid #a8a8a8;\n      background-color: #a8a8a8;\n      mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 59.1 59.2\"><path d=\"M1.6,57.7a5,5,0,0,0,3.5,1.5,4.85,4.85,0,0,0,3.5-1.5l21-21,21,21a5,5,0,0,0,3.5,1.5,4.85,4.85,0,0,0,3.5-1.5,5,5,0,0,0,0-7.1l-21-21,21-21a5,5,0,0,0,0-7.1,5,5,0,0,0-7.1,0l-21,21L8.6,1.7a5,5,0,0,0-7.1,0,5,5,0,0,0,0,7.1l21,21L1.6,50.7A4.83,4.83,0,0,0,1.6,57.7Z\"/></svg>');\n      mask-size: .6em;\n      mask-repeat: no-repeat;\n      mask-position: center;\n      cursor: pointer;\n      position: absolute;\n      right: .75em;\n      z-index: 1;\n      transition: transform .25s; }\n      @media (pointer: fine) {\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-remove:hover {\n          transform: scale(1.5); } }\n    .formulate-input[data-classification=\"file\"] .formulate-files li {\n      display: block; }\n      .formulate-input[data-classification=\"file\"] .formulate-files li[data-has-error] .formulate-file-progress {\n        background-color: #dc2c2c; }\n      .formulate-input[data-classification=\"file\"] .formulate-files li[data-has-preview] .formualte-file-name:before {\n        display: none; }\n      .formulate-input[data-classification=\"file\"] .formulate-files li + li {\n        margin-top: .5em; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file {\n      appearance: none;\n      border-radius: .3em;\n      border: 1px solid #cecece;\n      box-sizing: border-box;\n      background-color: transparent;\n      font-size: .9em;\n      font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";\n      padding: .75em;\n      display: block;\n      width: 100%;\n      font-weight: 400;\n      line-height: 1.1em;\n      margin: 0;\n      display: block;\n      width: 100%;\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n      position: relative; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file::placeholder {\n        color: #a8a8a8; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file:focus {\n        outline: 0;\n        border: 1px solid #41b883; }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file ::-webkit-progress-bar {\n        appearance: none;\n        height: .5em;\n        border-radius: .5em;\n        overflow: hidden; }\n    .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-image-preview {\n      width: 3em;\n      height: 3em;\n      position: relative;\n      z-index: 2;\n      left: -1px;\n      box-shadow: 0 0 0 1px #efefef;\n      transition: transform .25s, box-shadow .25s, background-color .25s; }\n      @media (pointer: fine) {\n        .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-image-preview:hover {\n          transition-delay: .2s;\n          transform: scale(3);\n          background-color: #ffffff;\n          box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.1); } }\n      .formulate-input[data-classification=\"file\"] .formulate-files .formulate-file-image-preview img {\n        display: block;\n        position: absolute;\n        width: 100%;\n        height: 100%;\n        left: 0;\n        right: 0;\n        bottom: 0;\n        top: 0;\n        object-fit: contain;\n        transition: all .25s; }\n  .formulate-input[data-classification=\"file\"] [data-type=\"image\"] .formulate-input-upload-area .formulate-input-upload-area-mask::before {\n    mask-image: url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 90 71.05\"><path d=\"M82.89,0H7.1A7.12,7.12,0,0,0,0,7.11V64a7.11,7.11,0,0,0,7.1,7.1H82.9A7.11,7.11,0,0,0,90,64V7.11A7.12,7.12,0,0,0,82.89,0ZM69.28,39.35a5.44,5.44,0,0,0-8,0L50.58,50.74,32.38,30.88a5.31,5.31,0,0,0-7.92,0L4.74,52.4V7.11A2.37,2.37,0,0,1,7.11,4.74H82.9a2.37,2.37,0,0,1,2.36,2.37V56.3Z\"/><circle cx=\"67.74\" cy=\"22.26\" r=\"8.53\"/></svg>'); }\n"]} */ \ No newline at end of file diff --git a/src/FormSubmission.js b/src/FormSubmission.js index 74f2cab..54f8292 100644 --- a/src/FormSubmission.js +++ b/src/FormSubmission.js @@ -26,10 +26,10 @@ export default class FormSubmission { values () { return new Promise((resolve, reject) => { const pending = [] - const values = cloneDeep(this.form.internalModelProxy) + const values = cloneDeep(this.form.internalFormModelProxy) for (const key in values) { - if (typeof this.form.internalModelProxy[key] === 'object' && this.form.internalModelProxy[key] instanceof FileUpload) { - pending.push(this.form.internalModelProxy[key].upload()) + if (typeof this.form.internalFormModelProxy[key] === 'object' && this.form.internalFormModelProxy[key] instanceof FileUpload) { + pending.push(this.form.internalFormModelProxy[key].upload()) } } /** diff --git a/src/FormulateForm.vue b/src/FormulateForm.vue index cf024ba..2f9de8e 100644 --- a/src/FormulateForm.vue +++ b/src/FormulateForm.vue @@ -85,11 +85,20 @@ export default { }, register (field, component) { this.registry[field] = component - if (!component.$options.propsData.hasOwnProperty('formulateValue') && this.hasFormulateValue && this.formulateValue[field]) { + const hasVModelValue = Object.prototype.hasOwnProperty.call(component.$options.propsData, 'formulateValue') + const hasValue = Object.prototype.hasOwnProperty.call(component.$options.propsData, 'value') + if ( + !hasVModelValue && + this.hasFormulateValue && + this.formulateValue[field] + ) { // In the case that the form is carrying an initial value and the // element is not, set it directly. component.context.model = this.formulateValue[field] - } else if (component.$options.propsData.hasOwnProperty('formulateValue') && !shallowEqualObjects(component.internalModelProxy, this.formulateValue[field])) { + } else if ( + (hasVModelValue || hasValue) && + !shallowEqualObjects(component.internalModelProxy, this.formulateValue[field]) + ) { this.setFieldValue(field, component.internalModelProxy) } }, @@ -98,9 +107,9 @@ export default { this.showErrors() const submission = new FormSubmission(this) this.$emit('submit-raw', submission) - submission.hasValidationErrors() + return submission.hasValidationErrors() .then(hasErrors => hasErrors ? false : submission.values()) - .then(json => this.$emit('submit', json)) + .then(json => json !== false ? this.$emit('submit', json) : null) }, showErrors () { for (const fieldName in this.registry) { diff --git a/src/libs/utils.js b/src/libs/utils.js index 03c81d8..28e770b 100644 --- a/src/libs/utils.js +++ b/src/libs/utils.js @@ -203,7 +203,7 @@ export function cloneDeep (obj) { const newObj = {} for (const key in obj) { if (obj[key] instanceof FileUpload || isValueType(obj[key])) { - newObj[key] = obj + newObj[key] = obj[key] } else { newObj[key] = cloneDeep(obj[key]) } diff --git a/test/FormulateForm.test.js b/test/FormulateForm.test.js index 94e96b1..f5a0bc7 100644 --- a/test/FormulateForm.test.js +++ b/test/FormulateForm.test.js @@ -61,6 +61,20 @@ describe('FormulateForm', () => { expect(wrapper.find('input').element.value).toBe('123') }) + it('lets fields set form initial value with value prop', () => { + const wrapper = mount({ + data () { + return { + formValues: {} + } + }, + template: ` + + ` + }) + expect(wrapper.vm.formValues).toEqual({ name: '123' }) + }) + it('receives updates to form model when individual fields are edited', () => { const wrapper = mount({ data () { @@ -132,7 +146,7 @@ describe('FormulateForm', () => { }) - it('it emits an instance of FormSubmission', async () => { + it('emits an instance of FormSubmission', async () => { const wrapper = mount(FormulateForm, { slots: { default: '' } }) @@ -141,7 +155,7 @@ describe('FormulateForm', () => { expect(wrapper.emitted('submit-raw')[0][0]).toBeInstanceOf(FormSubmission) }) - it('it resolves hasValidationErrors to true', async () => { + it('resolves hasValidationErrors to true', async () => { const wrapper = mount(FormulateForm, { slots: { default: '' } }) @@ -150,4 +164,15 @@ describe('FormulateForm', () => { const submission = wrapper.emitted('submit-raw')[0][0] expect(await submission.hasValidationErrors()).toBe(true) }) + + it('resolves submitted form values to an object', async () => { + const wrapper = mount(FormulateForm, { + slots: { default: '' } + }) + wrapper.find('form').trigger('submit') + await flushPromises() + const submission = await wrapper.vm.formSubmitted() + await flushPromises() + expect(submission).toEqual({testinput: 'Justin'}) + }) }) diff --git a/test/utils.test.js b/test/utils.test.js index 5cdca70..73089f8 100644 --- a/test/utils.test.js +++ b/test/utils.test.js @@ -1,5 +1,6 @@ -import { parseRules, regexForFormat } from '@/libs/utils' +import { parseRules, regexForFormat, cloneDeep, isValueType } from '@/libs/utils' import rules from '@/libs/rules' +import FileUpload from '@/FileUpload'; describe('parseRules', () => { it('parses single string rules, returning empty arguments array', () => { @@ -83,3 +84,36 @@ describe('regexForFormat', () => { it('fails date like YYYY-MM-DD with out of bounds day', () => expect(regexForFormat('YYYY-MM-DD').test('1987-01-32')).toBe(false)) }) + +describe('isValueType', () => { + it('passes on strings', () => expect(isValueType('hello')).toBe(true)) + + it('passes on numbers', () => expect(isValueType(123)).toBe(true)) + + it('passes on booleans', () => expect(isValueType(false)).toBe(true)) + + it('passes on symbols', () => expect(isValueType(Symbol(123))).toBe(true)) + + it('passes on null', () => expect(isValueType(null)).toBe(true)) + + it('passes on undefined', () => expect(isValueType(undefined)).toBe(true)) + + it('fails on pojo', () => expect(isValueType({})).toBe(false)) + + it('fails on custom type', () => expect(isValueType(FileUpload)).toBe(false)) +}) + +describe('cloneDeep', () => { + it('basic objects stay the same', () => expect(cloneDeep({ a: 123, b: 'hello' })).toEqual({ a: 123, b: 'hello' })) + + it('basic nested objects stay the same', () => { + expect(cloneDeep({ a: 123, b: { c: 'hello-world' } })) + .toEqual({ a: 123, b: { c: 'hello-world' } }) + }) + + it('simple pojo reference types are re-created', () => { + const c = { c: 'hello-world' } + const clone = cloneDeep({ a: 123, b: c }) + expect(clone.b === c).toBe(false) + }) +}) diff --git a/themes/snow/_inputs.scss b/themes/snow/_inputs.scss index d266247..3c1ba09 100644 --- a/themes/snow/_inputs.scss +++ b/themes/snow/_inputs.scss @@ -2,7 +2,7 @@ // ----------------------------------------------------------------------------- .formulate-input { - margin-bottom: 2em; + margin-bottom: 1.5em; .formulate-input-label { display: block;