@hbuesing/ui-library 1.4.0 → 1.4.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.css +1 -1
- package/dist/index.css.map +1 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs.map +1 -1
- package/dist/index.modern.mjs.map +1 -1
- package/dist/index.umd.js.map +1 -1
- package/package.json +1 -1
package/dist/index.css
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
.uil-button{background-color:var(--uil-white);border:1px solid var(--uil-black);border-radius:2px;box-shadow:0 0 3px 0 var(--uil-black-alt);color:var(--uil-black);cursor:pointer;font-size:var(--uil-font-base);letter-spacing:1px;line-height:var(--uil-font-base);padding:var(--uil-xs) var(--uil-s);width:-moz-fit-content;width:fit-content}.uil-button.uil-disabled{background-color:var(--uil-grey-dark);border:transparent;color:var(--uil-grey)}.uil-button.uil-small{font-size:var(--uil-m);line-height:var(--uil-m);padding:var(--uil-xxs) var(--uil-xs)}@media (min-width:1025px){.uil-button.uil-small{font-size:1.125rem;line-height:1.125rem;padding:var(--uil-xs) var(--uil-s)}}.uil-check-wrapper{align-items:center;display:flex;font-size:var(--uil-font-base);gap:var(--uil-s);line-height:var(--uil-font-base)}.uil-check-wrapper .uil-checkbox{border:2px solid var(--uil-black-alt);border-radius:2px;cursor:pointer;display:block;font-size:var(--uil-m);min-height:var(--uil-m);min-width:var(--uil-m);position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.uil-check-wrapper .uil-checkbox input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.uil-check-wrapper .uil-checkbox input:checked~.uil-checkmark{transform:scale(1)}.uil-check-wrapper .uil-checkbox .uil-checkmark{background-color:var(--uil-black-alt);height:var(--uil-xs);left:25%;position:absolute;top:25%;transform:scale(0);transition:.1s ease;width:var(--uil-xs)}.uil-svg{height:var(--uil-xxxl);width:var(--uil-xxxl)}.uil-input-wrapper{display:block;position:relative}.uil-input-wrapper .uil-label{background:linear-gradient(0deg,var(--uil-white) 9px,transparent 0);cursor:text;font-weight:700;left:var(--uil-xxs);opacity:.6;padding:0 var(--uil-xxxs);position:absolute;top:25%;transition:top .25s ease-in-out}.uil-input-wrapper .uil-input,.uil-input-wrapper .uil-label{color:var(--uil-black);font-size:var(--uil-font-base);line-height:var(--uil-font-base)}.uil-input-wrapper .uil-input{background-color:var(--uil-white);border:1px solid var(--uil-black);border-radius:0;box-sizing:border-box;padding:var(--uil-xs);width:100%}.uil-input-wrapper .uil-input::-moz-placeholder{color:transparent;height:0;width:0}.uil-input-wrapper .uil-input::placeholder{color:transparent;height:0;width:0}.uil-input-wrapper .uil-input:focus{outline:1px solid var(--uil-outline-focus)}.uil-input-wrapper .uil-input:disabled{background-color:var(--uil-grey);border:2px solid var(--uil-outline-disabled);color:var(--uil-grey-dark);cursor:not-allowed}.uil-input-wrapper .uil-input:disabled~.uil-label{background:transparent;color:var(--uil-grey-dark);cursor:not-allowed}.uil-input-wrapper .uil-input:disabled~.uil-icon{fill:var(--uil-grey-dark);cursor:not-allowed}.uil-input-wrapper .uil-input:disabled:not(:-moz-placeholder-shown)~.uil-label{background:linear-gradient(0deg,var(--uil-grey) 8px,transparent 0)}.uil-input-wrapper .uil-input:disabled:not(:placeholder-shown)~.uil-label{background:linear-gradient(0deg,var(--uil-grey) 8px,transparent 0)}.uil-input-wrapper .uil-icon{fill:var(--uil-black);opacity:.5;position:absolute;right:var(--uil-xs);top:50%;transform:translateY(-50%)}.uil-input-wrapper .uil-input:not(:-moz-placeholder-shown)~.uil-label{opacity:1;top:-30%}.uil-input-wrapper .uil-input:focus~.uil-label,.uil-input-wrapper .uil-input:not(:placeholder-shown)~.uil-label{opacity:1;top:-30%}.uil-input-wrapper .uil-input:not(:-moz-placeholder-shown)~.uil-icon{opacity:1}.uil-input-wrapper .uil-input:focus~.uil-icon,.uil-input-wrapper .uil-input:not(:placeholder-shown)~.uil-icon{opacity:1}.uil-tooltip-wrapper{position:relative}.uil-tooltip-wrapper .uil-tooltip-icon{fill:var(--uil-black-alt);cursor:pointer;height:-moz-fit-content;height:fit-content;width:-moz-fit-content;width:fit-content}.uil-tooltip-wrapper .uil-tooltip-icon:has(~.uil-input-wrapper>.uil-input:not(:-moz-placeholder-shown),~.uil-input-wrapper:focus-within){visibility:hidden}.uil-tooltip-wrapper .uil-tooltip-icon:has(~.uil-input-wrapper>.uil-input:not(:placeholder-shown),~.uil-input-wrapper:focus-within){visibility:hidden}.uil-tooltip-wrapper .uil-tooltip{background-color:rgba(34,34,34,.9);border-radius:3px;box-sizing:border-box;color:var(--uil-white);font-size:var(--uil-font-small);left:0;line-height:var(--uil-font-small);padding:var(--uil-s);position:absolute;top:0;width:100%;z-index:1}.uil-tooltip-wrapper .uil-tooltip .uil-tooltip-button{background-color:transparent;border:none;border-bottom:1px solid var(--uil-white);color:var(--uil-white);cursor:pointer;display:block;margin-bottom:var(--uil-m);margin-left:auto;padding:0;width:-moz-fit-content;width:fit-content}.uil-password-rules{display:flex;flex-direction:column;gap:var(--uil-xs);margin-left:var(--uil-xs);margin-top:var(--uil-m)}.uil-password-rules .uil-password-rule{align-items:center;display:flex;font-size:var(--uil-font-small);gap:var(--uil-xxs);line-height:var(--uil-font-small)}:root{--uil-black:#000;--uil-black-alt:#222;--uil-white:#fff;--uil-grey:#f3f3f3;--uil-grey-alt:#cfcfcf;--uil-grey-dark:#878787;--uil-outline-focus:#1e90ff;--uil-outline-disabled:#8b0000;--uil-success:#006a4e;--uil-error:#800020;--uil-question:#00416a;--uil-xxxs:.125rem;--uil-xxs:.25rem;--uil-xs:.5rem;--uil-s:.75rem;--uil-m:1rem;--uil-l:1.25rem;--uil-xl:1.5rem;--uil-xxl:1.75rem;--uil-xxxl:2rem;--uil-font-base:var(--uil-l);--uil-font-small:var(--uil-m)}.uil-modal-wrapper{background-color:rgba(0,0,0,.5);height:100%;left:0;position:fixed;top:0;width:100
|
|
1
|
+
.uil-button{background-color:var(--uil-white);border:1px solid var(--uil-black);border-radius:2px;box-shadow:0 0 3px 0 var(--uil-black-alt);color:var(--uil-black);cursor:pointer;font-size:var(--uil-font-base);letter-spacing:1px;line-height:var(--uil-font-base);padding:var(--uil-xs) var(--uil-s);width:-moz-fit-content;width:fit-content}.uil-button.uil-disabled{background-color:var(--uil-grey-dark);border:transparent;color:var(--uil-grey)}.uil-button.uil-small{font-size:var(--uil-m);line-height:var(--uil-m);padding:var(--uil-xxs) var(--uil-xs)}@media (min-width:1025px){.uil-button.uil-small{font-size:1.125rem;line-height:1.125rem;padding:var(--uil-xs) var(--uil-s)}}.uil-check-wrapper{align-items:center;display:flex;font-size:var(--uil-font-base);gap:var(--uil-s);line-height:var(--uil-font-base)}.uil-check-wrapper .uil-checkbox{border:2px solid var(--uil-black-alt);border-radius:2px;cursor:pointer;display:block;font-size:var(--uil-m);min-height:var(--uil-m);min-width:var(--uil-m);position:relative;-webkit-user-select:none;-moz-user-select:none;user-select:none}.uil-check-wrapper .uil-checkbox input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.uil-check-wrapper .uil-checkbox input:checked~.uil-checkmark{transform:scale(1)}.uil-check-wrapper .uil-checkbox .uil-checkmark{background-color:var(--uil-black-alt);height:var(--uil-xs);left:25%;position:absolute;top:25%;transform:scale(0);transition:.1s ease;width:var(--uil-xs)}.uil-svg{height:var(--uil-xxxl);width:var(--uil-xxxl)}.uil-input-wrapper{display:block;position:relative}.uil-input-wrapper .uil-label{background:linear-gradient(0deg,var(--uil-white) 9px,transparent 0);cursor:text;font-weight:700;left:var(--uil-xxs);opacity:.6;padding:0 var(--uil-xxxs);position:absolute;top:25%;transition:top .25s ease-in-out}.uil-input-wrapper .uil-input,.uil-input-wrapper .uil-label{color:var(--uil-black);font-size:var(--uil-font-base);line-height:var(--uil-font-base)}.uil-input-wrapper .uil-input{background-color:var(--uil-white);border:1px solid var(--uil-black);border-radius:0;box-sizing:border-box;padding:var(--uil-xs);width:100%}.uil-input-wrapper .uil-input::-moz-placeholder{color:transparent;height:0;width:0}.uil-input-wrapper .uil-input::placeholder{color:transparent;height:0;width:0}.uil-input-wrapper .uil-input:focus{outline:1px solid var(--uil-outline-focus)}.uil-input-wrapper .uil-input:disabled{background-color:var(--uil-grey);border:2px solid var(--uil-outline-disabled);color:var(--uil-grey-dark);cursor:not-allowed}.uil-input-wrapper .uil-input:disabled~.uil-label{background:transparent;color:var(--uil-grey-dark);cursor:not-allowed}.uil-input-wrapper .uil-input:disabled~.uil-icon{fill:var(--uil-grey-dark);cursor:not-allowed}.uil-input-wrapper .uil-input:disabled:not(:-moz-placeholder-shown)~.uil-label{background:linear-gradient(0deg,var(--uil-grey) 8px,transparent 0)}.uil-input-wrapper .uil-input:disabled:not(:placeholder-shown)~.uil-label{background:linear-gradient(0deg,var(--uil-grey) 8px,transparent 0)}.uil-input-wrapper .uil-icon{fill:var(--uil-black);opacity:.5;position:absolute;right:var(--uil-xs);top:50%;transform:translateY(-50%)}.uil-input-wrapper .uil-input:not(:-moz-placeholder-shown)~.uil-label{opacity:1;top:-30%}.uil-input-wrapper .uil-input:focus~.uil-label,.uil-input-wrapper .uil-input:not(:placeholder-shown)~.uil-label{opacity:1;top:-30%}.uil-input-wrapper .uil-input:not(:-moz-placeholder-shown)~.uil-icon{opacity:1}.uil-input-wrapper .uil-input:focus~.uil-icon,.uil-input-wrapper .uil-input:not(:placeholder-shown)~.uil-icon{opacity:1}.uil-tooltip-wrapper{position:relative}.uil-tooltip-wrapper .uil-tooltip-icon{fill:var(--uil-black-alt);cursor:pointer;height:-moz-fit-content;height:fit-content;width:-moz-fit-content;width:fit-content}.uil-tooltip-wrapper .uil-tooltip-icon:has(~.uil-input-wrapper>.uil-input:not(:-moz-placeholder-shown),~.uil-input-wrapper:focus-within){visibility:hidden}.uil-tooltip-wrapper .uil-tooltip-icon:has(~.uil-input-wrapper>.uil-input:not(:placeholder-shown),~.uil-input-wrapper:focus-within){visibility:hidden}.uil-tooltip-wrapper .uil-tooltip{background-color:rgba(34,34,34,.9);border-radius:3px;box-sizing:border-box;color:var(--uil-white);font-size:var(--uil-font-small);left:0;line-height:var(--uil-font-small);padding:var(--uil-s);position:absolute;top:0;width:100%;z-index:1}.uil-tooltip-wrapper .uil-tooltip .uil-tooltip-button{background-color:transparent;border:none;border-bottom:1px solid var(--uil-white);color:var(--uil-white);cursor:pointer;display:block;margin-bottom:var(--uil-m);margin-left:auto;padding:0;width:-moz-fit-content;width:fit-content}.uil-password-rules{display:flex;flex-direction:column;gap:var(--uil-xs);margin-left:var(--uil-xs);margin-top:var(--uil-m)}.uil-password-rules .uil-password-rule{align-items:center;display:flex;font-size:var(--uil-font-small);gap:var(--uil-xxs);line-height:var(--uil-font-small)}:root{--uil-black:#000;--uil-black-alt:#222;--uil-white:#fff;--uil-grey:#f3f3f3;--uil-grey-alt:#cfcfcf;--uil-grey-dark:#878787;--uil-outline-focus:#1e90ff;--uil-outline-disabled:#8b0000;--uil-success:#006a4e;--uil-error:#800020;--uil-question:#00416a;--uil-xxxs:.125rem;--uil-xxs:.25rem;--uil-xs:.5rem;--uil-s:.75rem;--uil-m:1rem;--uil-l:1.25rem;--uil-xl:1.5rem;--uil-xxl:1.75rem;--uil-xxxl:2rem;--uil-font-base:var(--uil-l);--uil-font-small:var(--uil-m)}.uil-modal-wrapper{background-color:rgba(0,0,0,.5);height:100%;left:0;position:fixed;top:0;width:100%;z-index:99}.uil-modal-wrapper .uil-modal{border-radius:5px;box-shadow:0 0 6px 0 var(--uil-black);left:50%;position:absolute;top:30%;transform:translateX(-50%);width:95%;z-index:999}@media (min-width:1025px){.uil-modal-wrapper .uil-modal{width:75%}}@media (min-width:1250px){.uil-modal-wrapper .uil-modal{width:55%}}@media (min-width:1920px){.uil-modal-wrapper .uil-modal{width:35%}}.uil-modal-wrapper .uil-modal .uil-progress-wrapper{background-color:var(--uil-grey-alt)}.uil-modal-wrapper .uil-modal .uil-progress-wrapper .uil-progress-bar{animation-duration:2s;animation-iteration-count:1;animation-name:uil-progress;border:2px solid var(--uil-grey-dark)}@keyframes uil-progress{0%{width:100%}to{width:0}}.uil-modal-wrapper .uil-modal .uil-header{background-color:var(--uil-question);border-top-left-radius:3px;border-top-right-radius:3px;color:var(--uil-white);display:flex;font-size:var(--uil-xl);font-weight:700;justify-content:space-between;line-height:var(--uil-xl);margin:0;min-height:var(--uil-xl);padding:var(--uil-xs)}@media (min-width:1025px){.uil-modal-wrapper .uil-modal .uil-header{font-size:var(--uil-xxl);line-height:var(--uil-xxl);padding:var(--uil-s)}}.uil-modal-wrapper .uil-modal .uil-header.uil-success{background-color:var(--uil-success)}.uil-modal-wrapper .uil-modal .uil-header.uil-error{background-color:var(--uil-error)}.uil-modal-wrapper .uil-modal .uil-content{background-color:var(--uil-white);border-bottom-left-radius:3px;border-bottom-right-radius:3px;display:flex;flex-direction:column;gap:var(--uil-m);padding:var(--uil-m)}@media (min-width:1025px){.uil-modal-wrapper .uil-modal .uil-content{gap:var(--uil-xxxl);padding:var(--uil-l)}}.uil-modal-wrapper .uil-modal .uil-content .uil-modal-text{color:var(--uil-black);font-size:var(--uil-l);line-height:var(--uil-l);margin:var(--uil-s) 0}@media (min-width:1025px){.uil-modal-wrapper .uil-modal .uil-content .uil-modal-text{font-size:var(--uil-l);line-height:var(--uil-l)}}.uil-modal-wrapper .uil-modal .uil-content .uil-button-wrapper{display:flex;justify-content:space-between}.uil-modal-wrapper .uil-modal .uil-content .uil-button-wrapper.uil-single{justify-content:end}
|
|
2
2
|
/*# sourceMappingURL=index.css.map */
|
package/dist/index.css.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["button.scss","checkbox.scss","images.scss","input.scss","modal.scss"],"names":[],"mappings":"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F,CACA,0BACE,8BACE,SACF,CACF,CACA,0BACE,8BACE,SACF,CACF,CACA,oDACE,oCACF,CACA,sEAEE,qBAAsB,CACtB,2BAAkC,CAClC,2BAA4B,CAH5B,qCAIF,CACA,wBACE,GACE,UACF,CACA,GACE,OACF,CACF,CACA,0CAEE,oCAAqC,CASrC,0BAA2B,CAC3B,2BAA4B,CAX5B,sBAAuB,CAEvB,YAAa,CAEb,uBAAwB,CAExB,eAAiB,CAHjB,6BAA8B,CAE9B,yBAA0B,CAG1B,QAAS,CADT,wBAAyB,CAEzB,qBAGF,CACA,0BACE,0CACE,wBAAyB,CACzB,0BAA2B,CAC3B,oBACF,CACF,CACA,sDACE,mCACF,CACA,oDACE,iCACF,CACA,2CACE,iCAAkC,CAElC,6BAA8B,CAC9B,8BAA+B,CAC/B,YAAa,CACb,qBAAsB,CACtB,gBAAiB,CALjB,oBAMF,CACA,0BACE,2CAEE,mBAAoB,CADpB,oBAEF,CACF,CACA,2DAGE,sBAAuB,CAFvB,sBAAuB,CACvB,wBAAyB,CAEzB,qBACF,CACA,0BACE,2DACE,sBAAuB,CACvB,wBACF,CACF,CACA,+DACE,YAAa,CACb,6BACF,CACA,0EACE,mBACF","file":"index.css","sourcesContent":[":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-button {\n font-size: var(--uil-font-base);\n line-height: var(--uil-font-base);\n letter-spacing: 1px;\n color: var(--uil-black);\n background-color: var(--uil-white);\n border: 1px solid var(--uil-black);\n border-radius: 2px;\n width: fit-content;\n cursor: pointer;\n padding: var(--uil-xs) var(--uil-s);\n -webkit-box-shadow: 0 0 3px 0 var(--uil-black-alt);\n box-shadow: 0 0 3px 0 var(--uil-black-alt);\n}\n.uil-button.uil-disabled {\n background-color: var(--uil-grey-dark);\n color: var(--uil-grey);\n border: transparent;\n}\n.uil-button.uil-small {\n font-size: var(--uil-m);\n line-height: var(--uil-m);\n padding: var(--uil-xxs) var(--uil-xs);\n}\n@media (min-width: 1025px) {\n .uil-button.uil-small {\n font-size: 1.125rem;\n line-height: 1.125rem;\n padding: var(--uil-xs) var(--uil-s);\n }\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-check-wrapper {\n display: flex;\n align-items: center;\n gap: var(--uil-s);\n font-size: var(--uil-font-base);\n line-height: var(--uil-font-base);\n}\n.uil-check-wrapper .uil-checkbox {\n position: relative;\n display: block;\n cursor: pointer;\n font-size: var(--uil-m);\n min-width: var(--uil-m);\n min-height: var(--uil-m);\n user-select: none;\n border: 2px solid var(--uil-black-alt);\n border-radius: 2px;\n}\n.uil-check-wrapper .uil-checkbox input {\n position: absolute;\n cursor: pointer;\n height: 0;\n width: 0;\n opacity: 0;\n}\n.uil-check-wrapper .uil-checkbox input:checked ~ .uil-checkmark {\n transform: scale(1);\n}\n.uil-check-wrapper .uil-checkbox .uil-checkmark {\n position: absolute;\n top: 25%;\n left: 25%;\n background-color: var(--uil-black-alt);\n width: var(--uil-xs);\n height: var(--uil-xs);\n transform: scale(0);\n transition: 0.1s ease;\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-svg {\n height: var(--uil-xxxl);\n width: var(--uil-xxxl);\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-input-wrapper {\n position: relative;\n display: block;\n}\n.uil-input-wrapper .uil-label {\n position: absolute;\n top: 25%;\n left: var(--uil-xxs);\n cursor: text;\n font-size: var(--uil-font-base);\n font-weight: bold;\n line-height: var(--uil-font-base);\n color: var(--uil-black);\n background: linear-gradient(0deg, var(--uil-white) 9px, rgba(0, 0, 0, 0) 0%);\n opacity: 0.6;\n padding: 0 var(--uil-xxxs);\n transition: top 0.25s ease-in-out;\n}\n.uil-input-wrapper .uil-input {\n box-sizing: border-box;\n font-size: var(--uil-font-base);\n line-height: var(--uil-font-base);\n width: 100%;\n color: var(--uil-black);\n background-color: var(--uil-white);\n border: 1px solid var(--uil-black);\n border-radius: 0;\n padding: var(--uil-xs);\n}\n.uil-input-wrapper .uil-input::placeholder {\n color: transparent;\n width: 0;\n height: 0;\n}\n.uil-input-wrapper .uil-input:focus {\n outline: 1px solid var(--uil-outline-focus);\n}\n.uil-input-wrapper .uil-input:disabled {\n cursor: not-allowed;\n border: 2px solid var(--uil-outline-disabled);\n background-color: var(--uil-grey);\n color: var(--uil-grey-dark);\n}\n.uil-input-wrapper .uil-input:disabled ~ .uil-label {\n cursor: not-allowed;\n background: transparent;\n color: var(--uil-grey-dark);\n}\n.uil-input-wrapper .uil-input:disabled ~ .uil-icon {\n cursor: not-allowed;\n fill: var(--uil-grey-dark);\n}\n.uil-input-wrapper .uil-input:disabled:not(:placeholder-shown) ~ .uil-label {\n background: linear-gradient(0deg, var(--uil-grey) 8px, rgba(0, 0, 0, 0) 0%);\n}\n.uil-input-wrapper .uil-icon {\n position: absolute;\n top: 50%;\n right: var(--uil-xs);\n transform: translate(0%, -50%);\n fill: var(--uil-black);\n opacity: 0.5;\n}\n.uil-input-wrapper .uil-input:focus ~ .uil-label, .uil-input-wrapper .uil-input:not(:placeholder-shown) ~ .uil-label {\n top: -30%;\n opacity: 1;\n}\n.uil-input-wrapper .uil-input:focus ~ .uil-icon, .uil-input-wrapper .uil-input:not(:placeholder-shown) ~ .uil-icon {\n opacity: 1;\n}\n\n.uil-tooltip-wrapper {\n position: relative;\n}\n.uil-tooltip-wrapper .uil-tooltip-icon {\n cursor: pointer;\n height: fit-content;\n width: fit-content;\n fill: var(--uil-black-alt);\n}\n.uil-tooltip-wrapper .uil-tooltip-icon:has(~ .uil-input-wrapper > .uil-input:not(:placeholder-shown), ~ .uil-input-wrapper:focus-within) {\n visibility: hidden;\n}\n.uil-tooltip-wrapper .uil-tooltip {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n box-sizing: border-box;\n z-index: 1;\n color: var(--uil-white);\n background-color: rgba(34, 34, 34, 0.9);\n padding: var(--uil-s);\n border-radius: 3px;\n font-size: var(--uil-font-small);\n line-height: var(--uil-font-small);\n}\n.uil-tooltip-wrapper .uil-tooltip .uil-tooltip-button {\n display: block;\n width: fit-content;\n margin-left: auto;\n margin-bottom: var(--uil-m);\n color: var(--uil-white);\n background-color: transparent;\n border: none;\n padding: 0;\n border-bottom: 1px solid var(--uil-white);\n cursor: pointer;\n}\n\n.uil-password-rules {\n margin-top: var(--uil-m);\n display: flex;\n flex-direction: column;\n gap: var(--uil-xs);\n margin-left: var(--uil-xs);\n}\n.uil-password-rules .uil-password-rule {\n display: flex;\n align-items: center;\n gap: var(--uil-xxs);\n font-size: var(--uil-font-small);\n line-height: var(--uil-font-small);\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-modal-wrapper {\n position: fixed;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.5);\n}\n.uil-modal-wrapper .uil-modal {\n position: absolute;\n top: 30%;\n left: 50%;\n transform: translateX(-50%);\n width: 95%;\n -webkit-box-shadow: 0 0 6px 0 var(--uil-black);\n box-shadow: 0 0 6px 0 var(--uil-black);\n border-radius: 5px;\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal {\n width: 75%;\n }\n}\n@media (min-width: 1250px) {\n .uil-modal-wrapper .uil-modal {\n width: 55%;\n }\n}\n@media (min-width: 1920px) {\n .uil-modal-wrapper .uil-modal {\n width: 35%;\n }\n}\n.uil-modal-wrapper .uil-modal .uil-progress-wrapper {\n background-color: var(--uil-grey-alt);\n}\n.uil-modal-wrapper .uil-modal .uil-progress-wrapper .uil-progress-bar {\n border: 2px solid var(--uil-grey-dark);\n animation-duration: 2s;\n animation-iteration-count: initial;\n animation-name: uil-progress;\n}\n@keyframes uil-progress {\n 0% {\n width: 100%;\n }\n 100% {\n width: 0;\n }\n}\n.uil-modal-wrapper .uil-modal .uil-header {\n color: var(--uil-white);\n background-color: var(--uil-question);\n display: flex;\n justify-content: space-between;\n font-size: var(--uil-xl);\n line-height: var(--uil-xl);\n font-weight: bold;\n min-height: var(--uil-xl);\n margin: 0;\n padding: var(--uil-xs);\n border-top-left-radius: 3px;\n border-top-right-radius: 3px;\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal .uil-header {\n font-size: var(--uil-xxl);\n line-height: var(--uil-xxl);\n padding: var(--uil-s);\n }\n}\n.uil-modal-wrapper .uil-modal .uil-header.uil-success {\n background-color: var(--uil-success);\n}\n.uil-modal-wrapper .uil-modal .uil-header.uil-error {\n background-color: var(--uil-error);\n}\n.uil-modal-wrapper .uil-modal .uil-content {\n background-color: var(--uil-white);\n padding: var(--uil-m);\n border-bottom-left-radius: 3px;\n border-bottom-right-radius: 3px;\n display: flex;\n flex-direction: column;\n gap: var(--uil-m);\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal .uil-content {\n padding: var(--uil-l);\n gap: var(--uil-xxxl);\n }\n}\n.uil-modal-wrapper .uil-modal .uil-content .uil-modal-text {\n font-size: var(--uil-l);\n line-height: var(--uil-l);\n color: var(--uil-black);\n margin: var(--uil-s) 0;\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal .uil-content .uil-modal-text {\n font-size: var(--uil-l);\n line-height: var(--uil-l);\n }\n}\n.uil-modal-wrapper .uil-modal .uil-content .uil-button-wrapper {\n display: flex;\n justify-content: space-between;\n}\n.uil-modal-wrapper .uil-modal .uil-content .uil-button-wrapper.uil-single {\n justify-content: end;\n}"]}
|
|
1
|
+
{"version":3,"sources":["button.scss","checkbox.scss","images.scss","input.scss","modal.scss"],"names":[],"mappings":"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0BACE,8BACE,SACF,CACF,CACA,0BACE,8BACE,SACF,CACF,CACA,0BACE,8BACE,SACF,CACF,CACA,oDACE,oCACF,CACA,sEAEE,qBAAsB,CACtB,2BAAkC,CAClC,2BAA4B,CAH5B,qCAIF,CACA,wBACE,GACE,UACF,CACA,GACE,OACF,CACF,CACA,0CAEE,oCAAqC,CASrC,0BAA2B,CAC3B,2BAA4B,CAX5B,sBAAuB,CAEvB,YAAa,CAEb,uBAAwB,CAExB,eAAiB,CAHjB,6BAA8B,CAE9B,yBAA0B,CAG1B,QAAS,CADT,wBAAyB,CAEzB,qBAGF,CACA,0BACE,0CACE,wBAAyB,CACzB,0BAA2B,CAC3B,oBACF,CACF,CACA,sDACE,mCACF,CACA,oDACE,iCACF,CACA,2CACE,iCAAkC,CAElC,6BAA8B,CAC9B,8BAA+B,CAC/B,YAAa,CACb,qBAAsB,CACtB,gBAAiB,CALjB,oBAMF,CACA,0BACE,2CAEE,mBAAoB,CADpB,oBAEF,CACF,CACA,2DAGE,sBAAuB,CAFvB,sBAAuB,CACvB,wBAAyB,CAEzB,qBACF,CACA,0BACE,2DACE,sBAAuB,CACvB,wBACF,CACF,CACA,+DACE,YAAa,CACb,6BACF,CACA,0EACE,mBACF","file":"index.css","sourcesContent":[":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-button {\n font-size: var(--uil-font-base);\n line-height: var(--uil-font-base);\n letter-spacing: 1px;\n color: var(--uil-black);\n background-color: var(--uil-white);\n border: 1px solid var(--uil-black);\n border-radius: 2px;\n width: fit-content;\n cursor: pointer;\n padding: var(--uil-xs) var(--uil-s);\n -webkit-box-shadow: 0 0 3px 0 var(--uil-black-alt);\n box-shadow: 0 0 3px 0 var(--uil-black-alt);\n}\n.uil-button.uil-disabled {\n background-color: var(--uil-grey-dark);\n color: var(--uil-grey);\n border: transparent;\n}\n.uil-button.uil-small {\n font-size: var(--uil-m);\n line-height: var(--uil-m);\n padding: var(--uil-xxs) var(--uil-xs);\n}\n@media (min-width: 1025px) {\n .uil-button.uil-small {\n font-size: 1.125rem;\n line-height: 1.125rem;\n padding: var(--uil-xs) var(--uil-s);\n }\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-check-wrapper {\n display: flex;\n align-items: center;\n gap: var(--uil-s);\n font-size: var(--uil-font-base);\n line-height: var(--uil-font-base);\n}\n.uil-check-wrapper .uil-checkbox {\n position: relative;\n display: block;\n cursor: pointer;\n font-size: var(--uil-m);\n min-width: var(--uil-m);\n min-height: var(--uil-m);\n user-select: none;\n border: 2px solid var(--uil-black-alt);\n border-radius: 2px;\n}\n.uil-check-wrapper .uil-checkbox input {\n position: absolute;\n cursor: pointer;\n height: 0;\n width: 0;\n opacity: 0;\n}\n.uil-check-wrapper .uil-checkbox input:checked ~ .uil-checkmark {\n transform: scale(1);\n}\n.uil-check-wrapper .uil-checkbox .uil-checkmark {\n position: absolute;\n top: 25%;\n left: 25%;\n background-color: var(--uil-black-alt);\n width: var(--uil-xs);\n height: var(--uil-xs);\n transform: scale(0);\n transition: 0.1s ease;\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-svg {\n height: var(--uil-xxxl);\n width: var(--uil-xxxl);\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-input-wrapper {\n position: relative;\n display: block;\n}\n.uil-input-wrapper .uil-label {\n position: absolute;\n top: 25%;\n left: var(--uil-xxs);\n cursor: text;\n font-size: var(--uil-font-base);\n font-weight: bold;\n line-height: var(--uil-font-base);\n color: var(--uil-black);\n background: linear-gradient(0deg, var(--uil-white) 9px, rgba(0, 0, 0, 0) 0%);\n opacity: 0.6;\n padding: 0 var(--uil-xxxs);\n transition: top 0.25s ease-in-out;\n}\n.uil-input-wrapper .uil-input {\n box-sizing: border-box;\n font-size: var(--uil-font-base);\n line-height: var(--uil-font-base);\n width: 100%;\n color: var(--uil-black);\n background-color: var(--uil-white);\n border: 1px solid var(--uil-black);\n border-radius: 0;\n padding: var(--uil-xs);\n}\n.uil-input-wrapper .uil-input::placeholder {\n color: transparent;\n width: 0;\n height: 0;\n}\n.uil-input-wrapper .uil-input:focus {\n outline: 1px solid var(--uil-outline-focus);\n}\n.uil-input-wrapper .uil-input:disabled {\n cursor: not-allowed;\n border: 2px solid var(--uil-outline-disabled);\n background-color: var(--uil-grey);\n color: var(--uil-grey-dark);\n}\n.uil-input-wrapper .uil-input:disabled ~ .uil-label {\n cursor: not-allowed;\n background: transparent;\n color: var(--uil-grey-dark);\n}\n.uil-input-wrapper .uil-input:disabled ~ .uil-icon {\n cursor: not-allowed;\n fill: var(--uil-grey-dark);\n}\n.uil-input-wrapper .uil-input:disabled:not(:placeholder-shown) ~ .uil-label {\n background: linear-gradient(0deg, var(--uil-grey) 8px, rgba(0, 0, 0, 0) 0%);\n}\n.uil-input-wrapper .uil-icon {\n position: absolute;\n top: 50%;\n right: var(--uil-xs);\n transform: translate(0%, -50%);\n fill: var(--uil-black);\n opacity: 0.5;\n}\n.uil-input-wrapper .uil-input:focus ~ .uil-label, .uil-input-wrapper .uil-input:not(:placeholder-shown) ~ .uil-label {\n top: -30%;\n opacity: 1;\n}\n.uil-input-wrapper .uil-input:focus ~ .uil-icon, .uil-input-wrapper .uil-input:not(:placeholder-shown) ~ .uil-icon {\n opacity: 1;\n}\n\n.uil-tooltip-wrapper {\n position: relative;\n}\n.uil-tooltip-wrapper .uil-tooltip-icon {\n cursor: pointer;\n height: fit-content;\n width: fit-content;\n fill: var(--uil-black-alt);\n}\n.uil-tooltip-wrapper .uil-tooltip-icon:has(~ .uil-input-wrapper > .uil-input:not(:placeholder-shown), ~ .uil-input-wrapper:focus-within) {\n visibility: hidden;\n}\n.uil-tooltip-wrapper .uil-tooltip {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n box-sizing: border-box;\n z-index: 1;\n color: var(--uil-white);\n background-color: rgba(34, 34, 34, 0.9);\n padding: var(--uil-s);\n border-radius: 3px;\n font-size: var(--uil-font-small);\n line-height: var(--uil-font-small);\n}\n.uil-tooltip-wrapper .uil-tooltip .uil-tooltip-button {\n display: block;\n width: fit-content;\n margin-left: auto;\n margin-bottom: var(--uil-m);\n color: var(--uil-white);\n background-color: transparent;\n border: none;\n padding: 0;\n border-bottom: 1px solid var(--uil-white);\n cursor: pointer;\n}\n\n.uil-password-rules {\n margin-top: var(--uil-m);\n display: flex;\n flex-direction: column;\n gap: var(--uil-xs);\n margin-left: var(--uil-xs);\n}\n.uil-password-rules .uil-password-rule {\n display: flex;\n align-items: center;\n gap: var(--uil-xxs);\n font-size: var(--uil-font-small);\n line-height: var(--uil-font-small);\n}",":root {\n --uil-black: #000000;\n --uil-black-alt: #222222;\n --uil-white: #ffffff;\n --uil-grey: #f3f3f3;\n --uil-grey-alt: #cfcfcf;\n --uil-grey-dark: #878787;\n --uil-outline-focus: #1E90FFFF;\n --uil-outline-disabled: #8B0000FF;\n --uil-success: #006A4E;\n --uil-error: #800020;\n --uil-question: #00416A;\n --uil-xxxs: .125rem;\n --uil-xxs: .25rem;\n --uil-xs: .5rem;\n --uil-s: .75rem;\n --uil-m: 1rem;\n --uil-l: 1.25rem;\n --uil-xl: 1.5rem;\n --uil-xxl: 1.75rem;\n --uil-xxxl: 2rem;\n --uil-font-base: var(--uil-l);\n --uil-font-small: var(--uil-m);\n}\n\n.uil-modal-wrapper {\n position: fixed;\n left: 0;\n top: 0;\n width: 100%;\n height: 100%;\n background-color: rgba(0, 0, 0, 0.5);\n z-index: 99;\n}\n.uil-modal-wrapper .uil-modal {\n position: absolute;\n top: 30%;\n left: 50%;\n transform: translateX(-50%);\n width: 95%;\n -webkit-box-shadow: 0 0 6px 0 var(--uil-black);\n box-shadow: 0 0 6px 0 var(--uil-black);\n border-radius: 5px;\n z-index: 999;\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal {\n width: 75%;\n }\n}\n@media (min-width: 1250px) {\n .uil-modal-wrapper .uil-modal {\n width: 55%;\n }\n}\n@media (min-width: 1920px) {\n .uil-modal-wrapper .uil-modal {\n width: 35%;\n }\n}\n.uil-modal-wrapper .uil-modal .uil-progress-wrapper {\n background-color: var(--uil-grey-alt);\n}\n.uil-modal-wrapper .uil-modal .uil-progress-wrapper .uil-progress-bar {\n border: 2px solid var(--uil-grey-dark);\n animation-duration: 2s;\n animation-iteration-count: initial;\n animation-name: uil-progress;\n}\n@keyframes uil-progress {\n 0% {\n width: 100%;\n }\n 100% {\n width: 0;\n }\n}\n.uil-modal-wrapper .uil-modal .uil-header {\n color: var(--uil-white);\n background-color: var(--uil-question);\n display: flex;\n justify-content: space-between;\n font-size: var(--uil-xl);\n line-height: var(--uil-xl);\n font-weight: bold;\n min-height: var(--uil-xl);\n margin: 0;\n padding: var(--uil-xs);\n border-top-left-radius: 3px;\n border-top-right-radius: 3px;\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal .uil-header {\n font-size: var(--uil-xxl);\n line-height: var(--uil-xxl);\n padding: var(--uil-s);\n }\n}\n.uil-modal-wrapper .uil-modal .uil-header.uil-success {\n background-color: var(--uil-success);\n}\n.uil-modal-wrapper .uil-modal .uil-header.uil-error {\n background-color: var(--uil-error);\n}\n.uil-modal-wrapper .uil-modal .uil-content {\n background-color: var(--uil-white);\n padding: var(--uil-m);\n border-bottom-left-radius: 3px;\n border-bottom-right-radius: 3px;\n display: flex;\n flex-direction: column;\n gap: var(--uil-m);\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal .uil-content {\n padding: var(--uil-l);\n gap: var(--uil-xxxl);\n }\n}\n.uil-modal-wrapper .uil-modal .uil-content .uil-modal-text {\n font-size: var(--uil-l);\n line-height: var(--uil-l);\n color: var(--uil-black);\n margin: var(--uil-s) 0;\n}\n@media (min-width: 1025px) {\n .uil-modal-wrapper .uil-modal .uil-content .uil-modal-text {\n font-size: var(--uil-l);\n line-height: var(--uil-l);\n }\n}\n.uil-modal-wrapper .uil-modal .uil-content .uil-button-wrapper {\n display: flex;\n justify-content: space-between;\n}\n.uil-modal-wrapper .uil-modal .uil-content .uil-button-wrapper.uil-single {\n justify-content: end;\n}"]}
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../src/components/button/customButton.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/enums/passwordRuleTypes.ts","../src/components/input/customInput.tsx","../src/enums/ModalType.ts","../src/components/modal/baseModal.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/modal/notifyModal.tsx","../src/components/input/passwordInput.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>;\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","_props$disabled","disabled","label","_props$small","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","jsx","_extends","className","SVG","src","height","width","includes","Error","fill","children","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","_jsxs","htmlFor","id","onChange","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","PasswordRuleTypes","CustomInput","tooltipClose","tooltipIcon","tooltipText","_useState","useState","tooltipVisible","setTooltipVisible","closeTooltip","_Fragment","Fragment","jsxs","ModalType","BaseModal","_props$cancelLabel","cancelLabel","closeLabel","confirm","_props$confirmLabel","confirmLabel","message","timeout","title","type","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","idx","question","checkColor","checked","onCheck","checkProps","isSuccess","modalProps","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","setCapsLockState","getModifierState","_objectDestructuringEmpty"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/components/button/customButton.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/enums/passwordRuleTypes.ts","../src/components/input/customInput.tsx","../src/enums/ModalType.ts","../src/components/modal/baseModal.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/modal/notifyModal.tsx","../src/components/input/passwordInput.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return (visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>\n );\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","_props$disabled","disabled","label","_props$small","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","jsx","_extends","className","SVG","src","height","width","includes","Error","fill","children","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","_jsxs","htmlFor","id","onChange","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","PasswordRuleTypes","CustomInput","tooltipClose","tooltipIcon","tooltipText","_useState","useState","tooltipVisible","setTooltipVisible","closeTooltip","_Fragment","Fragment","jsxs","ModalType","BaseModal","_props$cancelLabel","cancelLabel","closeLabel","confirm","_props$confirmLabel","confirmLabel","message","timeout","title","type","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","idx","question","checkColor","checked","onCheck","checkProps","isSuccess","modalProps","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","setCapsLockState","getModifierState","_objectDestructuringEmpty"],"mappings":"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"}
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../src/components/button/customButton.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/enums/passwordRuleTypes.ts","../src/components/input/customInput.tsx","../src/enums/ModalType.ts","../src/components/input/passwordInput.tsx","../src/components/modal/baseModal.tsx","../src/components/modal/notifyModal.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>;\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","_props$disabled","disabled","label","_props$small","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","_extends","className","CustomCheckBox","checkColor","checked","onCheck","children","checkProps","_Fragment","_jsxs","type","onChange","SVG","src","height","width","includes","Error","fill","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","htmlFor","id","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","PasswordRuleTypes","CustomInput","tooltipClose","tooltipIcon","tooltipText","_useState","useState","tooltipVisible","setTooltipVisible","closeTooltip","ModalType","PasswordInput","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","setCapsLockState","getModifierState","idx","BaseModal","_props$cancelLabel","cancelLabel","closeLabel","confirm","_props$confirmLabel","confirmLabel","message","timeout","title","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","question","NotifyModal","isSuccess","modalProps","QuestionModal","_objectDestructuringEmpty"],"mappings":"0gBAUM,SAAUA,EAAaC,GAC3B,IAAAC,EAMID,EALFE,SAAAA,WAAQD,GAAQA,EAChBE,EAIEH,EAJFG,MAAKC,EAIHJ,EAHFK,MAAAA,OAAQ,IAAHD,GAAQA,EACbE,EAEEN,EAFFM,MACGC,EAAWC,EACZR,EAAKS,GAmBHC,EAAuB,CAC3BC,MAlBF,SAAkBC,GAChB,IAAKN,GAASJ,EAAU,OAAW,KAEnC,IAAMS,EAA+B,MAAtBC,EAAQC,OAAO,GAAcD,EAAQE,UAAU,EAAG,GAAKF,EAMhEG,EALW,CACfC,SAASL,EAAMG,UAAU,EAAG,GAAI,IAAM,IACtCE,SAASL,EAAMG,UAAU,EAAG,GAAI,IAAM,IACtCE,SAASL,EAAMG,UAAU,EAAG,GAAI,IAAM,KAErBG,IAAI,SAAAC,GACrB,OAAOA,GAAO,OAAUA,EAAM,MAASC,KAAKC,KAAKF,EAAM,MAAS,MAAO,IACzE,GAGA,MAFW,MAASH,EAAE,GAAO,MAASA,EAAE,GAAO,MAASA,EAAE,GAE/C,KAAQ,UAAY,SACjC,CAGSM,CAASf,GAChBgB,gBAAiBpB,EAAU,KAAOI,EAClCiB,OAAQjB,EAAO,OAAQ,MAGzB,OACEkB,EAAQ,SAAAC,GAAAC,UAAS,eAAgBxB,EAAW,eAAiB,IAAMG,KAAAA,EAAQ,YAAc,IAAMK,MAAOA,EAAOR,SAAUA,GAAcK,YAClIJ,IAGP,6DCpCM,SAAUwB,EAAe3B,GAC7B,IACE4B,EAME5B,EANF4B,WACAC,EAKE7B,EALF6B,QACAC,EAIE9B,EAJF8B,QACA3B,EAGEH,EAHFG,MACA4B,EAEE/B,EAFF+B,SACGC,EAAUxB,EACXR,EAAKS,GAET,OACEe,EAAAS,EAAA,CAAAF,SACEG,EAAK,MAAA,CAAAR,UAAW,oBACdK,SAAA,CAAAG,EAAA,QAAA,CAAOR,UAAW,eAAcK,SAAA,CAC9BP,YAAOW,CAAAA,KAAM,WAAYN,QAASA,EAASO,SAAU,WAAON,GAASD,EAAQ,GAAOG,IACpFR,EAAA,MAAA,CAAKE,UAAW,gBAAiBhB,MAAO,CAACY,gBAAiBM,QAG3DG,GAAsBP,EAAA,OAAA,CAAAO,SAAO5B,QAItC,CCvBM,SAAUkC,EAAIrC,GAClB,IACEsC,EAIEtC,EAJFsC,IACA3B,EAGEX,EAHFW,MACA4B,EAEEvC,EAFFuC,OACAC,EACExC,EADFwC,MAGF,IAAKF,EAAIG,SAAS,QAChB,MAAU,IAAAC,MAAM,oCASlB,OACElB,EAAkB,MAAA,CAAA,eAAA,EAAME,UAAW,UAAWhB,MAPnB,CAC3BiC,KAAMhC,EACN4B,OAAWA,EAAU,KACrBC,MAAUA,EAAK,MAI2CT,SACxDP,SAAKoB,KAAMN,KAGjB,4ECnBgB,SAAAO,EAAU7C,GACxB,IACE8C,EAOE9C,EAPF8C,UACAC,EAME/C,EANF+C,QACAC,EAKEhD,EALFgD,WACA7C,EAIEH,EAJFG,MACA8C,EAGEjD,EAHFiD,OACAC,EAEElD,EAFFkD,aACGC,EAAU3C,EACXR,EAAKS,GAET,OACEyB,WAAOR,UAAW,oBAAqB0B,QAASD,EAAWE,aACzD7B,EACE,QAAAC,EAAAC,CAAAA,UAAW,YACXU,SAAU,SAACkB,GAAC,OAAKJ,EAAaI,EAAEC,OAAOC,MAAM,EAC7CC,YAAatD,EACbO,MAAO,CAACC,MAAOqC,IACXG,IAGLJ,GACCvB,EAAK,MAAA,CAAAE,UAAW,WAAYgC,QAAST,WACnCzB,EAACa,GAAIC,IAAKS,EAASP,MAAO,GAAID,OAAQ,GAAI5B,MAAOmC,MAIrDtB,UAAME,UAAW,YAAahB,MAAO,CAACC,MAAOqC,YAAc7C,MAGjE,CC1CgB,SAAAwD,EAAiBC,GAC/B,IAAMC,EAAMC,EAAuB,MAmBnC,OAjBAC,EAAU,WACR,SAASC,EAAoBC,GACvBJ,EAAIK,UAAYL,EAAIK,QAAQC,SAASF,EAAMV,SAC7CK,GAEJ,CAMA,OAJAQ,SAASC,iBAAiB,QAASL,GACnCI,SAASC,iBAAiB,WAAYL,GAG/B,WACLI,SAASE,oBAAoB,QAASN,GACtCI,SAASE,oBAAoB,WAAYN,EAC3C,CACF,EAAG,CAACJ,IAEGC,CACT,KCvBYU,iDCYN,SAAUC,EAAYxE,GAC1B,IACEyE,EAIEzE,EAJFyE,aACAC,EAGE1E,EAHF0E,YACAC,EAEE3E,EAFF2E,YACGxB,EAAU3C,EACXR,EAAKS,GAETmE,EAA4CC,GAAS,GAA9CC,EAAcF,EAAA,GAAEG,EAAiBH,EAAA,GAClCf,EAAMF,EAAgBqB,GAE5B,SAASA,IACPD,GAAkB,EACpB,CAEA,OACEvD,EAAAS,EAAA,CAAAF,SACG2C,EACCxC,EAAA,MAAA,CAAKR,UAAW,sBAAqBK,SAAA,CAClC+C,GACC5C,EAAK,MAAA,CAAAR,UAAW,cAAemC,IAAKA,YACjCY,GACCjD,EAAQ,SAAA,CAAAE,UAAW,qBAAsBgC,QAASsB,EAC/CjD,SAAA0C,IAILjD,EAAO,OAAA,CAAAO,SAAA4C,OAIXnD,EAAK,MAAA,CAAAE,UAAW,mBAAoBgC,QAAS,WAAA,OAAMqB,GAAmBD,EAAe,EACnF/C,SAAAP,EAACa,EAAG,CAACC,IAAKoC,EAAanC,OAAQ,GAAIC,MAAO,OAG5ChB,EAACqB,EAASpB,EAAA,CAAA,EAAK0B,OAGjB3B,EAACqB,EAASpB,EAAK0B,CAAAA,EAAAA,KAIvB,EDtDA,SAAYoB,GACVA,EAAAA,EAAA,UAAA,GAAA,YACAA,EAAAA,EAAA,UAAA,GAAA,YACAA,EAAAA,EAAA,QAAA,GAAA,UACAA,EAAAA,EAAA,QAAA,GAAA,UACAA,EAAAA,EAAA,QAAA,GAAA,UACAA,EAAAA,EAAA,MAAA,GAAA,OACD,CAPD,CAAYA,IAAAA,EAOX,CAAA,QEPWU,+ECqBI,SAAAC,EAAclF,GAC5B,IACEmF,EAMEnF,EANFmF,gBACAC,EAKEpF,EALFoF,MACAC,EAIErF,EAJFqF,YACAC,EAGEtF,EAHFsF,cACAC,EAEEvF,EAFFuF,eACGpC,EAAU3C,EACXR,EAAKS,GAETmE,EAAgCC,GAAS,GAAlCW,EAAQZ,EAAEa,GAAAA,EAAWb,EAE5Bb,GA4BA,SAAS2B,EAAUC,GACjB,IAAIC,EAEJ,OAAQD,EAAKxD,MACX,KAAKoC,EAAkBsB,UACrBD,EAA6FD,mFAAAA,EAAKG,MAAS,KAC3G,MACF,KAAKvB,EAAkBwB,UACrBH,EAAO,qFAAwFD,EAAKG,MAAK,KACzG,MACF,KAAKvB,EAAkByB,QACrBJ,EAA6BD,mBAAAA,EAAKG,MAAS,KAC3C,MACF,KAAKvB,EAAkB0B,QACrBL,EAAO,SAAYD,EAAKG,MAAK,KAC7B,MACF,KAAKvB,EAAkB2B,QACrBN,EAAO,mEAAsED,EAAKG,MAAK,KACvF,MACF,KAAKvB,EAAkB4B,MACrBP,EAAsBD,YAAAA,EAAKG,MAAS,KACpC,MACF,QACgBF,EAAdD,EAAKC,QAAmBD,EAAKC,QAAoB,GAGrD,MAAgB,KAAZA,GAEQ,IAAIQ,OAAOR,GACZS,KAAKrG,EAAMwD,MACxB,CAEA,OA5DAO,EAAU,WAgBV,IACQuC,IAA8B,GAEpClB,EAAMmB,QAAQ,SAAAZ,GACPD,EAAUC,IACbW,EAAYE,KAAKb,EAErB,GAEAJ,EAAee,EAvBjB,EAAE,CAACtG,EAAMwD,QAETO,EAAU,WACR,SAAS0C,EAAiBxC,GACxBwB,EAAYxB,EAAMyC,kBAAoBzC,EAAMyC,iBAAiB,YAC/D,CAIA,OAFAtC,SAASC,iBAAiB,UAAWoC,GAEzB,WACVrC,SAASE,oBAAoB,UAAWmC,EAC1C,CACF,EAAE,IA+CAjF,EAAAS,EAAA,CAAAF,SACEG,EACE,MAAA,CAAAH,SAAA,CAAAP,EAACgD,EAAW/C,EAAK0B,GAAAA,IAEjBjB,EAAK,MAAA,CAAAR,UAAW,+BACb8D,GACChE,EAAA,MAAA,CAAKE,UAAW,oBAAmBK,SAAGoD,IAGvCC,EAAMnE,IAAI,SAAC0E,EAAMgB,GAAG,OACnBzE,EAAe,MAAA,CAAAR,UAAW,oBACxBK,SAAA,CAAAP,EAACa,EAAG,CAACC,IAAKoD,EAAUC,GAAON,EAAcC,EAAe/C,OAAQ,GAAIC,MAAO,KAE3EhB,EAAO,OAAA,CAAAO,SAAA4D,EAAKxF,UAHJwG,EAIJ,UAMlB,CClGM,SAAUC,EAAU5G,GACxB,IAAA6G,EASI7G,EARF8G,YAAAA,OAAW,IAAAD,EAAG,GAAEA,EAChBE,EAOE/G,EAPF+G,WACAC,EAMEhH,EANFgH,QAAOC,EAMLjH,EALFkH,aAAAA,OAAY,IAAAD,EAAG,GAAEA,EACjBE,EAIEnH,EAJFmH,QACAC,EAGEpH,EAHFoH,QACAC,EAEErH,EAFFqH,MACAlF,EACEnC,EADFmC,KAGFyC,EAA8BC,GAAS,GAAhCyC,EAAO1C,EAAA,GAAE2C,EAAU3C,EAAA,GAU1B,OARAb,EAAU,WACHqD,GAELI,WAAW,WACTD,GAAW,EACb,EAAGH,EACL,EAAE,IAEKE,EACL9F,EAAK,MAAA,CAAAE,UAAW,oBAAmBK,SACjCG,SAAKR,UAAW,YACdK,SAAA,CAAAP,EAAA,MAAA,CAAKE,UAAS,eAAgBS,GAAQ8C,EAAUwC,QAAU,cAAgB,IAAMtF,KAAAA,GAAQ8C,EAAUyC,MAAQ,YAAc,IACrH3F,SAAAsF,IAGFD,GACC5F,EAAA,MAAA,CAAKE,UAAW,gCACdF,EAAK,MAAA,CAAAE,UAAW,mBAAoBhB,MAAO,CAACiH,kBAAuB3H,EAAMoH,QAAU,IAAQ,EAAI,SAInGlF,SAAKR,UAAW,cACdK,SAAA,CAAAP,EAAA,MAAA,CAAAO,SACG6F,MAAMC,QAAQV,GACbA,EAAQlG,IAAI,SAAC6G,EAAGnB,GACd,OAAAnF,EAAa,IAAA,CAAAE,UAAW,iBAAgBK,SAAG+F,GAAnCnB,EAAyC,GAC/CnF,EAAG,IAAA,CAAAE,UAAW,0BAAmByF,MAIzCjF,EAAK,MAAA,CAAAR,UAAiCS,uBAAAA,IAAS8C,EAAU8C,SAAW,aAAe,IAAIhG,SAAA,CACpFI,IAAS8C,EAAU8C,UAClBvG,EAACzB,EAAY,CAACI,MAAO4G,EAAY1G,OAAO,EAAMqD,QAAS,WAAA,OAAM6D,GAAW,EAAM,EAAEpF,KAAM,WAGvFA,GAAQ8C,EAAU8C,UAAY/H,EAAMgH,SACnC9E,EAAAD,EAAA,CAAAF,SAAA,CACEP,EAACzB,EAAa,CAAAI,MAAO+G,EAAc5G,MAAO,UAAWD,OAAO,EAAMqD,QAAS,WAAA,OAAMsD,CAAO,EAAE7E,KAAM,WAChGX,EAACzB,EAAY,CAACI,MAAO2G,EAAazG,OAAO,EAAMqD,QAAS,WAAM,OAAA6D,GAAW,EAAM,EAAEpF,KAAM,yBAM1FX,OACb,EF3EA,SAAYyD,GACVA,EAAAA,EAAA,MAAA,GAAA,QACAA,EAAAA,EAAA,SAAA,GAAA,WACAA,EAAAA,EAAA,QAAA,GAAA,SACD,CAJD,CAAYA,IAAAA,EAIX,CAAA,wBGQe,SAAA+C,EAAYhI,GAC1B,IACEiI,EAEEjI,EAFFiI,UACGC,EAAU1H,EACXR,EAAKS,GAET,OACEe,EAACoF,EAASnF,EAACU,CAAAA,KAAM8F,EAAWhD,EAAUwC,QAAUxC,EAAUyC,OAAWQ,GAEzE,CCRM,SAAUC,EAAcnI,GAC5B,IACKkI,EAAUzG,EAAA,wEAAA2G,CACXpI,GAAAA,IAEJ,OACEwB,EAACoF,EAASnF,EAAA,CAACU,KAAM8C,EAAU8C,UAAcG,GAE7C"}
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../src/components/button/customButton.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/enums/passwordRuleTypes.ts","../src/components/input/customInput.tsx","../src/enums/ModalType.ts","../src/components/input/passwordInput.tsx","../src/components/modal/baseModal.tsx","../src/components/modal/notifyModal.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return (visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","_props$disabled","disabled","label","_props$small","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","_extends","className","CustomCheckBox","checkColor","checked","onCheck","children","checkProps","_Fragment","_jsxs","type","onChange","SVG","src","height","width","includes","Error","fill","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","htmlFor","id","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","PasswordRuleTypes","CustomInput","tooltipClose","tooltipIcon","tooltipText","_useState","useState","tooltipVisible","setTooltipVisible","closeTooltip","ModalType","PasswordInput","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","setCapsLockState","getModifierState","idx","BaseModal","_props$cancelLabel","cancelLabel","closeLabel","confirm","_props$confirmLabel","confirmLabel","message","timeout","title","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","question","NotifyModal","isSuccess","modalProps","QuestionModal","_objectDestructuringEmpty"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.modern.mjs","sources":["../src/components/button/customButton.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/components/input/customInput.tsx","../src/enums/passwordRuleTypes.ts","../src/components/input/passwordInput.tsx","../src/enums/ModalType.ts","../src/components/modal/baseModal.tsx","../src/components/modal/notifyModal.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>;\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","disabled","label","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","_extends","className","CustomCheckBox","checkColor","checked","onCheck","children","checkProps","_Fragment","_jsxs","type","onChange","SVG","src","height","width","includes","Error","fill","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","htmlFor","id","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","CustomInput","tooltipClose","tooltipIcon","tooltipText","tooltipVisible","setTooltipVisible","useState","closeTooltip","PasswordRuleTypes","PasswordInput","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","validateInput","setCapsLockState","getModifierState","idx","ModalType","BaseModal","cancelLabel","closeLabel","confirm","confirmLabel","message","timeout","title","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","question","NotifyModal","isSuccess","modalProps","QuestionModal","_objectDestructuringEmpty"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.modern.mjs","sources":["../src/components/button/customButton.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/components/input/customInput.tsx","../src/enums/passwordRuleTypes.ts","../src/components/input/passwordInput.tsx","../src/enums/ModalType.ts","../src/components/modal/baseModal.tsx","../src/components/modal/notifyModal.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return (visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","disabled","label","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","_extends","className","CustomCheckBox","checkColor","checked","onCheck","children","checkProps","_Fragment","_jsxs","type","onChange","SVG","src","height","width","includes","Error","fill","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","htmlFor","id","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","CustomInput","tooltipClose","tooltipIcon","tooltipText","tooltipVisible","setTooltipVisible","useState","closeTooltip","PasswordRuleTypes","PasswordInput","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","validateInput","setCapsLockState","getModifierState","idx","ModalType","BaseModal","cancelLabel","closeLabel","confirm","confirmLabel","message","timeout","title","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","question","NotifyModal","isSuccess","modalProps","QuestionModal","_objectDestructuringEmpty"],"mappings":"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"}
|
package/dist/index.umd.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.umd.js","sources":["../src/components/button/customButton.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/enums/passwordRuleTypes.ts","../src/components/input/customInput.tsx","../src/enums/ModalType.ts","../src/components/modal/baseModal.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/modal/notifyModal.tsx","../src/components/input/passwordInput.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>;\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","_props$disabled","disabled","label","_props$small","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","jsx","_extends","className","SVG","src","height","width","includes","Error","fill","children","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","_jsxs","htmlFor","id","onChange","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","PasswordRuleTypes","CustomInput","tooltipClose","tooltipIcon","tooltipText","_useState","useState","tooltipVisible","setTooltipVisible","closeTooltip","_Fragment","Fragment","jsxs","ModalType","BaseModal","_props$cancelLabel","cancelLabel","closeLabel","confirm","_props$confirmLabel","confirmLabel","message","timeout","title","type","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","idx","question","checkColor","checked","onCheck","checkProps","isSuccess","modalProps","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","setCapsLockState","getModifierState","_objectDestructuringEmpty"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.umd.js","sources":["../src/components/button/customButton.tsx","../src/components/images/svgIcon.tsx","../src/components/input/baseInput.tsx","../src/hooks/clickOutside.ts","../src/enums/passwordRuleTypes.ts","../src/components/input/customInput.tsx","../src/enums/ModalType.ts","../src/components/modal/baseModal.tsx","../src/components/checkbox/customCheckBox.tsx","../src/components/modal/notifyModal.tsx","../src/components/input/passwordInput.tsx","../src/components/modal/questionModal.tsx"],"sourcesContent":["import React, {ComponentPropsWithoutRef, CSSProperties} from 'react';\nimport './button.scss';\n\ninterface ICustomButton extends ComponentPropsWithoutRef<'button'> {\n label : string;\n disabled?: boolean;\n small? : boolean;\n theme? : string;\n}\n\nexport function CustomButton(props: ICustomButton) {\n const {\n disabled = false,\n label,\n small = false,\n theme,\n ...buttonProps\n } = props;\n\n function setColor(bgColor: string) {\n if (!theme || disabled) return null;\n\n const color = (bgColor.charAt(0) === '#') ? bgColor.substring(1, 7) : bgColor;\n const uiColors = [\n parseInt(color.substring(0, 2), 16) / 255,\n parseInt(color.substring(2, 4), 16) / 255,\n parseInt(color.substring(4, 6), 16) / 255\n ];\n const c = uiColors.map(col => {\n return col <= 0.03928? (col / 12.92) : Math.pow((col + 0.055) / 1.055, 2.4);\n });\n const L = (0.2126 * c[0]) + (0.7152 * c[1]) + (0.0722 * c[2]);\n\n return L > 0.179 ? '#000000' : '#ffffff';\n }\n\n const style: CSSProperties = {\n color: setColor(theme),\n backgroundColor: disabled? null : theme,\n border: theme? 'none': null,\n }\n\n return (\n <button className={`uil-button ${disabled ? 'uil-disabled' : ''} ${small ? 'uil-small' : ''}`} style={style} disabled={disabled} {...buttonProps}>\n {label}\n </button>\n );\n}","import React, {CSSProperties} from 'react';\nimport './images.scss';\n\ninterface ISvgIcon {\n src : string;\n color? : string;\n height?: number;\n width? : number;\n}\n\nexport function SVG(props: ISvgIcon) {\n const {\n src,\n color,\n height,\n width\n } = props;\n\n if (!src.includes('.svg')) {\n throw new Error('Provided src is not an svg image');\n }\n\n const style: CSSProperties = {\n fill: color,\n height: `${height}px`,\n width: `${width}px`\n }\n\n return (\n <svg aria-hidden={true} className={'uil-svg'} style={style}>\n <use href={src}/>\n </svg>\n );\n}","import React, {ComponentPropsWithoutRef} from 'react';\nimport {SVG} from 'components/images/svgIcon';\nimport './input.scss';\n\nexport interface IBaseInput extends ComponentPropsWithoutRef<'input'> {\n label : string;\n value : string;\n valueChanged: (value: string) => void;\n iconColor? : string;\n iconSrc? : string;\n inputColor? : string;\n toggle? : () => void;\n}\n\nexport function BaseInput(props: IBaseInput) {\n const {\n iconColor,\n iconSrc,\n inputColor,\n label,\n toggle,\n valueChanged,\n ...inputProps\n } = props;\n\n return (\n <label className={'uil-input-wrapper'} htmlFor={inputProps.id}>\n <input\n className={'uil-input'}\n onChange={(e) => valueChanged(e.target.value)}\n placeholder={label}\n style={{color: inputColor}}\n {...inputProps}\n />\n\n {iconSrc &&\n <div className={'uil-icon'} onClick={toggle}>\n <SVG src={iconSrc} width={24} height={24} color={iconColor}/>\n </div>\n }\n\n <span className={'uil-label'} style={{color: inputColor}}>{label}</span>\n </label>\n );\n}","import {useEffect, useRef} from 'react';\n\nexport function useOutsideClick (callback: () => void) {\n const ref = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n function handleClickOutside (event: MouseEvent | TouchEvent) {\n if (ref.current && !ref.current.contains(event.target as Node)) {\n callback();\n }\n }\n\n document.addEventListener('click', handleClickOutside);\n document.addEventListener('touchend', handleClickOutside);\n\n\n return () => {\n document.removeEventListener('click', handleClickOutside);\n document.removeEventListener('touchend', handleClickOutside);\n };\n }, [callback]);\n\n return ref;\n}","export enum PasswordRuleTypes {\n minLength,\n maxLength,\n letters,\n numbers,\n special,\n upper\n}","import React, {useState} from 'react';\nimport {BaseInput, IBaseInput} from './baseInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {useOutsideClick} from 'hooks/clickOutside';\nimport './input.scss';\n\nexport interface ICustomInput extends IBaseInput {\n tooltipClose?: string;\n tooltipIcon? : string;\n tooltipText? : string;\n}\n\nexport function CustomInput(props: ICustomInput) {\n const {\n tooltipClose,\n tooltipIcon,\n tooltipText,\n ...inputProps\n } = props;\n\n const [tooltipVisible, setTooltipVisible] = useState(false);\n const ref = useOutsideClick(closeTooltip);\n\n function closeTooltip() {\n setTooltipVisible(false);\n }\n\n return (\n <>\n {tooltipIcon ?\n <div className={'uil-tooltip-wrapper'}>\n {tooltipVisible &&\n <div className={'uil-tooltip'} ref={ref}>\n {tooltipClose &&\n <button className={'uil-tooltip-button'} onClick={closeTooltip}>\n {tooltipClose}\n </button>\n }\n\n <span>{tooltipText}</span>\n </div>\n }\n\n <div className={'uil-tooltip-icon'} onClick={() => setTooltipVisible(!tooltipVisible)}>\n <SVG src={tooltipIcon} height={16} width={16}/>\n </div>\n\n <BaseInput {...inputProps}/>\n </div> :\n\n <BaseInput {...inputProps}/>\n }\n </>\n );\n}","export enum ModalType {\n error,\n question,\n success\n}","import React, {useEffect, useState} from 'react';\nimport {ModalType} from 'enums/ModalType';\nimport {CustomButton} from 'components/button';\nimport './modal.scss';\n\ninterface IBaseModal {\n message : string | string[];\n title : string;\n type : ModalType;\n cancelLabel? : string;\n closeLabel? : string;\n confirm? : () => void;\n confirmLabel?: string;\n timeout? : number;\n}\n\nexport function BaseModal(props: IBaseModal) {\n const {\n cancelLabel = '',\n closeLabel,\n confirm,\n confirmLabel = '',\n message,\n timeout,\n title,\n type\n } = props;\n\n const [visible, setVisible] = useState(true);\n\n useEffect(() => {\n if (!timeout) return;\n\n setTimeout(() => {\n setVisible(false);\n }, timeout);\n },[]);\n\n return (visible ?\n <div className={'uil-modal-wrapper'}>\n <div className={'uil-modal'}>\n <div className={`uil-header ${type == ModalType.success ? 'uil-success' : ''} ${type == ModalType.error ? 'uil-error' : ''}`}>\n {title}\n </div>\n\n {timeout &&\n <div className={'uil-progress-wrapper'}>\n <div className={'uil-progress-bar'} style={{animationDuration: `${(props.timeout / 1000) + 1}s`}}/>\n </div>\n }\n\n <div className={'uil-content'}>\n <div>\n {Array.isArray(message) ?\n message.map((m, idx) =>\n <p key={idx} className={'uil-modal-text'}>{m}</p>\n ) : <p className={'uil-modal-text'}>{message}</p>\n }\n </div>\n\n <div className={`uil-button-wrapper ${type !== ModalType.question ? 'uil-single' : ''}`}>\n {type !== ModalType.question &&\n <CustomButton label={closeLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n }\n\n {type == ModalType.question && props.confirm &&\n <>\n <CustomButton label={confirmLabel} theme={'#00416A'} small={true} onClick={() => confirm} type={'button'}/>\n <CustomButton label={cancelLabel} small={true} onClick={() => setVisible(false)} type={'button'}/>\n </>\n }\n </div>\n </div>\n </div>\n </div> : <></>\n );\n}","import React, {ComponentPropsWithoutRef, ReactNode} from 'react';\nimport './checkbox.scss';\n\ninterface ICustomCheckbox extends ComponentPropsWithoutRef<'input'> {\n checked : boolean;\n label? : string;\n onCheck : (value: boolean) => void;\n checkColor? : string;\n children? : ReactNode;\n}\n\nexport function CustomCheckBox(props: ICustomCheckbox) {\n const {\n checkColor,\n checked,\n onCheck,\n label,\n children,\n ...checkProps\n } = props;\n\n return (\n <>\n <div className={'uil-check-wrapper'}>\n <label className={'uil-checkbox'}>\n <input type={'checkbox'} checked={checked} onChange={() => {onCheck(!checked)}} {...checkProps}/>\n <div className={'uil-checkmark'} style={{backgroundColor: checkColor}}/>\n </label>\n\n {children ? children : <span>{label}</span>}\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface INotifyModal {\n closeLabel: string;\n isSuccess : boolean;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function NotifyModal(props: INotifyModal) {\n const {\n isSuccess,\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={isSuccess? ModalType.success : ModalType.error} {...modalProps}/>\n );\n}","import React, {useEffect, useState} from 'react';\nimport {CustomInput, ICustomInput} from './customInput';\nimport {SVG} from 'components/images/svgIcon';\nimport {PasswordRuleTypes} from 'enums/passwordRuleTypes';\nimport './input.scss';\n\ninterface IPasswordInput extends ICustomInput {\n capsLockWarning: string;\n setFailedRules : (value: PasswordRule[]) => void;\n ruleChecked : string;\n rules : PasswordRule[];\n ruleUnchecked : string;\n}\n\nexport interface PasswordRule {\n count : number;\n label : string;\n type : PasswordRuleTypes | string;\n pattern?: string;\n}\n\nexport function PasswordInput(props: IPasswordInput) {\n const {\n capsLockWarning,\n rules,\n ruleChecked,\n ruleUnchecked,\n setFailedRules,\n ...inputProps\n } = props;\n\n const [capsLock, setCapsLock] = useState(false);\n\n useEffect(() => {\n validateInput();\n },[props.value]);\n\n useEffect(() => {\n function setCapsLockState(event: globalThis.KeyboardEvent) {\n setCapsLock(event.getModifierState && event.getModifierState('CapsLock'));\n }\n\n document.addEventListener('keydown', setCapsLockState);\n\n return () => {\n document.removeEventListener('keydown', setCapsLockState);\n };\n },[]);\n\n function validateInput() {\n const failedRules: PasswordRule[] = [];\n \n rules.forEach(rule => {\n if (!checkRule(rule)) {\n failedRules.push(rule);\n }\n });\n\n setFailedRules(failedRules);\n }\n\n function checkRule(rule: PasswordRule) {\n let pattern: string;\n\n switch (rule.type) {\n case PasswordRuleTypes.minLength:\n pattern = `[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.maxLength:\n pattern = `^[a-zA-Z0-9ßÄäÖöÜü._!\"\\`'#%&,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{0,${rule.count}}$`;\n break;\n case PasswordRuleTypes.letters:\n pattern = `[a-zA-ZßÄäÖöÜü]{${rule.count},}`;\n break;\n case PasswordRuleTypes.numbers:\n pattern = `[0-9]{${rule.count},}`;\n break;\n case PasswordRuleTypes.special:\n pattern = `[._!\"\\`'#%&§,:;<>=@{}~\\\\$\\\\(\\\\)\\\\*\\\\+\\\\/\\\\\\\\\\\\?\\\\[\\\\]\\\\^\\\\|\\\\-]{${rule.count},}`;\n break;\n case PasswordRuleTypes.upper:\n pattern = `[A-ZÄÖÜ]{${rule.count},}`;\n break;\n default:\n rule.pattern? pattern = rule.pattern : pattern = '';\n }\n\n if (pattern === '') return false;\n\n const reg = new RegExp(pattern);\n return reg.test(props.value);\n }\n\n return (\n <>\n <div>\n <CustomInput {...inputProps}/>\n\n <div className={'uil-password-rules'}>\n {capsLock &&\n <div className={'uil-password-rule'}>{capsLockWarning}</div>\n }\n\n {rules.map((rule, idx) =>\n <div key={idx} className={'uil-password-rule'}>\n <SVG src={checkRule(rule)? ruleChecked : ruleUnchecked} height={12} width={12}/>\n\n <span>{rule.label}</span>\n </div>\n )}\n </div>\n </div>\n </>\n );\n}","import React from 'react';\nimport {BaseModal} from './baseModal';\nimport {ModalType} from 'enums/ModalType';\n\nexport interface IQuestionModal {\n cancelLabel : string;\n confirm : () => void;\n confirmLabel: string;\n message : string | string[];\n title : string;\n timeout? : number;\n}\n\nexport function QuestionModal(props: IQuestionModal) {\n const {\n ...modalProps\n } = props;\n\n return (\n <BaseModal type={ModalType.question} {...modalProps}/>\n );\n}"],"names":["CustomButton","props","_props$disabled","disabled","label","_props$small","small","theme","buttonProps","_objectWithoutPropertiesLoose","_excluded","style","color","bgColor","charAt","substring","c","parseInt","map","col","Math","pow","setColor","backgroundColor","border","_jsx","jsx","_extends","className","SVG","src","height","width","includes","Error","fill","children","href","BaseInput","iconColor","iconSrc","inputColor","toggle","valueChanged","inputProps","_jsxs","htmlFor","id","onChange","e","target","value","placeholder","onClick","useOutsideClick","callback","ref","useRef","useEffect","handleClickOutside","event","current","contains","document","addEventListener","removeEventListener","PasswordRuleTypes","CustomInput","tooltipClose","tooltipIcon","tooltipText","_useState","useState","tooltipVisible","setTooltipVisible","closeTooltip","_Fragment","Fragment","jsxs","ModalType","BaseModal","_props$cancelLabel","cancelLabel","closeLabel","confirm","_props$confirmLabel","confirmLabel","message","timeout","title","type","visible","setVisible","setTimeout","success","error","animationDuration","Array","isArray","m","idx","question","checkColor","checked","onCheck","checkProps","isSuccess","modalProps","capsLockWarning","rules","ruleChecked","ruleUnchecked","setFailedRules","capsLock","setCapsLock","checkRule","rule","pattern","minLength","count","maxLength","letters","numbers","special","upper","RegExp","test","failedRules","forEach","push","setCapsLockState","getModifierState","_objectDestructuringEmpty"],"mappings":"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"}
|