summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRohan Raj Gupta <78433013+rohan09-raj@users.noreply.github.com>2022-08-20 09:34:57 +0530
committerGitHub <noreply@github.com>2022-08-20 09:34:57 +0530
commit8eed2904d141d7c0b530cb0551364a0b226cf65a (patch)
tree1ce1fa3561dc6935f4f3aab521773145cdd3f7ec
parentf47c3f4349cb68460dadf1fc381e3ceb52fe009a (diff)
parent856728cfae03da554d4db91b0635a53f1c9f915c (diff)
Merge pull request #9 from Blaster4385/develop
ok
-rw-r--r--client/public/assets/images/agreement.svg13
-rw-r--r--client/public/assets/images/back_inverse.svg4
-rw-r--r--client/public/assets/images/next_inverse.svg5
-rw-r--r--client/public/assets/images/slip.svg13
-rw-r--r--client/src/components/Card/CardAgreement.jsx2
-rw-r--r--client/src/components/Card/CardAgreement.module.css2
-rw-r--r--client/src/pages/Enrollment/Agreement/Agreement.jsx1
-rw-r--r--client/src/pages/Enrollment/DocumentScanner/DocumentScanner.jsx175
-rw-r--r--client/src/pages/Enrollment/DocumentScanner/DocumentScanner.module.css40
-rw-r--r--client/src/pages/Enrollment/Enrollment.jsx18
-rw-r--r--client/src/services/apiservice.js5
-rw-r--r--server/controllers/message.js29
-rw-r--r--server/controllers/otp.js17
-rw-r--r--server/index.js4
-rw-r--r--server/routes/message.js9
-rw-r--r--server/routes/otp.js8
-rw-r--r--server/services/twilio.js4
17 files changed, 202 insertions, 147 deletions
diff --git a/client/public/assets/images/agreement.svg b/client/public/assets/images/agreement.svg
index abd76a6..0b15196 100644
--- a/client/public/assets/images/agreement.svg
+++ b/client/public/assets/images/agreement.svg
@@ -1,9 +1,4 @@
-<svg width="203" height="209" viewBox="0 0 203 209" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
-<rect width="203" height="209" fill="url(#pattern0)"/>
-<defs>
-<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
-<use xlink:href="#image0_63_7" transform="translate(-0.0147783) scale(0.00457581 0.00444444)"/>
-</pattern>
-<image id="image0_63_7" width="225" height="225" xlink:href=""/>
-</defs>
-</svg>
+<svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px"
+width="200" height="200"
+viewBox="0 0 100 100"
+style=" fill:#000000;"><circle cx="77" cy="13" r="1" fill="#f1bc19"></circle><circle cx="50" cy="50" r="37" fill="#000000"></circle><circle cx="83" cy="15" r="4" fill="#f1bc19"></circle><circle cx="87" cy="24" r="2" fill="#88ae45"></circle><circle cx="81" cy="76" r="2" fill="#fbcd59"></circle><circle cx="15" cy="63" r="4" fill="#fbcd59"></circle><circle cx="25" cy="87" r="2" fill="#88ae45"></circle><circle cx="18.5" cy="51.5" r="2.5" fill="#fff"></circle><circle cx="79.5" cy="33.5" r="1.5" fill="#fff"></circle><path fill="#edf7f5" d="M36.013,75.3c-2.929,0-5.313-2.265-5.313-5.048V29.748c0-2.783,2.383-5.048,5.313-5.048h21.765 L71.3,37.627v32.625c0,2.783-2.383,5.048-5.313,5.048H36.013z"></path><path fill="#472b29" d="M57.497,25.4l6.517,6.23l6.586,6.296v32.326c0,2.397-2.069,4.348-4.613,4.348H36.013 c-2.543,0-4.613-1.951-4.613-4.348V29.748c0-2.397,2.069-4.348,4.613-4.348h0.873h8.262H57.497 M58.059,24H45.148h-8.262h-0.873 C32.705,24,30,26.586,30,29.748v40.504C30,73.413,32.705,76,36.013,76h29.975C69.295,76,72,73.414,72,70.252V37.328 C66.578,32.145,63.481,29.183,58.059,24L58.059,24z"></path><path fill="#85cfcc" d="M57.5,25.208v7.994c0,2.914,2.396,5.298,5.325,5.298H71"></path><path fill="#472b29" d="M71,39h-8.175C59.613,39,57,36.399,57,33.202v-7.994h1v7.994C58,35.848,60.165,38,62.825,38H71V39z"></path><path fill="#472b29" d="M55.5,28.75H41.75c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25H55.5 c0.138,0,0.25,0.112,0.25,0.25S55.638,28.75,55.5,28.75z"></path><path fill="#472b29" d="M64.693,71.75H37.307c-1.686,0-3.057-1.362-3.057-3.035v-37.43c0-1.674,1.371-3.035,3.057-3.035 H39.5c0.138,0,0.25,0.112,0.25,0.25s-0.112,0.25-0.25,0.25h-2.193c-1.41,0-2.557,1.137-2.557,2.535v37.43 c0,1.398,1.147,2.535,2.557,2.535h27.387c1.41,0,2.557-1.137,2.557-2.535V57.5c0-0.138,0.112-0.25,0.25-0.25s0.25,0.112,0.25,0.25 v11.215C67.75,70.388,66.379,71.75,64.693,71.75z"></path><path fill="#472b29" d="M67.5,54.75c-0.138,0-0.25-0.112-0.25-0.25v-5c0-0.138,0.112-0.25,0.25-0.25s0.25,0.112,0.25,0.25v5 C67.75,54.638,67.638,54.75,67.5,54.75z"></path><g><path fill="#472b29" d="M67.5,48.333c-0.138,0-0.25-0.112-0.25-0.25v-2.25c0-0.138,0.112-0.25,0.25-0.25 s0.25,0.112,0.25,0.25v2.25C67.75,48.221,67.638,48.333,67.5,48.333z"></path></g><g><path fill="#472b29" d="M62.5,42.75h-23c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h23 c0.138,0,0.25,0.112,0.25,0.25S62.638,42.75,62.5,42.75z"></path></g><g><path fill="#472b29" d="M47.5,45.75h-8c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h8c0.138,0,0.25,0.112,0.25,0.25 S47.638,45.75,47.5,45.75z"></path></g><g><path fill="#472b29" d="M51.5,48.75h-12c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h12 c0.138,0,0.25,0.112,0.25,0.25S51.638,48.75,51.5,48.75z"></path></g><g><path fill="#472b29" d="M62.5,48.75h-8c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h8c0.138,0,0.25,0.112,0.25,0.25 S62.638,48.75,62.5,48.75z"></path></g><g><path fill="#472b29" d="M62.5,45.75h-13c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h13 c0.138,0,0.25,0.112,0.25,0.25S62.638,45.75,62.5,45.75z"></path></g><g><path fill="#472b29" d="M62.5,51.75h-23c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h23 c0.138,0,0.25,0.112,0.25,0.25S62.638,51.75,62.5,51.75z"></path></g><g><path fill="#472b29" d="M47.5,54.75h-8c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h8c0.138,0,0.25,0.112,0.25,0.25 S47.638,54.75,47.5,54.75z"></path></g><g><path fill="#472b29" d="M62.5,54.75h-13c-0.138,0-0.25-0.112-0.25-0.25s0.112-0.25,0.25-0.25h13 c0.138,0,0.25,0.112,0.25,0.25S62.638,54.75,62.5,54.75z"></path></g><g><path fill="#472b29" d="M44.159,68.642c-0.176,0-0.347-0.094-0.438-0.259c-0.133-0.242-0.045-0.546,0.197-0.679 c1.039-0.572,1.986-1.293,2.818-2.128c-0.478-2.956,0.251-6.033,2.007-8.459c0.626-0.864,1.446-1.177,2.086-0.796 c0.492,0.292,0.694,0.866,0.602,1.708c-0.317,2.928-1.626,5.705-3.611,7.86c0.123,0.465,0.341,0.928,0.729,1.061 c0.308,0.104,0.728-0.007,1.246-0.328c0.564-0.35,1.074-0.79,1.511-1.295c-0.011-0.173-0.004-0.358,0.021-0.552 c0.174-1.325,0.806-2.557,1.779-3.47c0.152-0.144,0.378-0.176,0.565-0.083c0.187,0.094,0.296,0.294,0.273,0.501 c-0.152,1.393-0.714,2.744-1.568,3.867c0.032,0.074,0.077,0.128,0.134,0.154c0.111,0.051,0.316,0.008,0.604-0.124 c1.59-0.729,2.872-2.154,3.431-3.811c0.082-0.246,0.337-0.388,0.593-0.326c0.253,0.062,0.416,0.308,0.375,0.564l-0.026,0.162 c-0.21,1.27-0.206,2.011,0.013,2.201c0.05,0.044,0.185,0.039,0.353-0.013c0.649-0.2,0.91-1.24,1.211-2.444l0.075-0.298 c0.062-0.243,0.288-0.404,0.546-0.374c0.25,0.031,0.438,0.243,0.438,0.495c0.002,0.673,0.225,1.319,0.408,1.406 c0.051,0.021,0.196-0.025,0.401-0.194c0.229-0.188,0.5-0.784,0.661-1.139l0.113-0.247c0.068-0.143,0.199-0.245,0.354-0.276 c0.156-0.031,0.315,0.014,0.433,0.119c0.124,0.112,0.319,0.163,0.52,0.133c0.202-0.029,0.375-0.132,0.463-0.275 c0.144-0.236,0.451-0.308,0.688-0.164c0.235,0.145,0.309,0.452,0.164,0.688c-0.245,0.399-0.672,0.669-1.172,0.741 c-0.263,0.038-0.527,0.017-0.765-0.058c-0.216,0.462-0.479,0.967-0.824,1.252c-0.65,0.533-1.154,0.471-1.463,0.326 c-0.201-0.095-0.361-0.245-0.488-0.424c-0.293,0.811-0.706,1.454-1.469,1.689c-0.67,0.205-1.078,0.01-1.306-0.189 c-0.26-0.227-0.4-0.555-0.464-0.94c-0.745,0.985-1.73,1.794-2.846,2.306c-0.363,0.167-0.908,0.361-1.428,0.128 c-0.156-0.069-0.291-0.167-0.403-0.29c-0.416,0.421-0.879,0.793-1.38,1.104c-0.796,0.493-1.48,0.632-2.094,0.425 c-0.391-0.133-0.867-0.456-1.193-1.22c-0.796,0.736-1.68,1.379-2.634,1.905C44.323,68.622,44.241,68.642,44.159,68.642z M50.246,57.163c-0.17,0-0.462,0.222-0.693,0.54c-1.415,1.955-2.108,4.469-1.928,6.884c1.539-1.897,2.546-4.225,2.811-6.667 c0.051-0.464-0.028-0.686-0.118-0.74C50.298,57.169,50.274,57.163,50.246,57.163z"></path></g></svg> \ No newline at end of file
diff --git a/client/public/assets/images/back_inverse.svg b/client/public/assets/images/back_inverse.svg
new file mode 100644
index 0000000..bf136de
--- /dev/null
+++ b/client/public/assets/images/back_inverse.svg
@@ -0,0 +1,4 @@
+<svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px"
+width="208" height="208"
+viewBox="0 0 26 26"
+style=" fill:#000000;"><path d="M 10.59375 13 L 19.179688 4.234375 C 19.5625 3.84375 19.558594 3.21875 19.171875 2.828125 L 17.636719 1.292969 C 17.242188 0.902344 16.609375 0.902344 16.21875 1.296875 L 5.292969 12.292969 C 5.097656 12.488281 5 12.742188 5 13 C 5 13.257813 5.097656 13.511719 5.292969 13.707031 L 16.21875 24.703125 C 16.609375 25.097656 17.242188 25.097656 17.636719 24.707031 L 19.171875 23.171875 C 19.558594 22.78125 19.5625 22.15625 19.179688 21.765625 Z"></path></svg> \ No newline at end of file
diff --git a/client/public/assets/images/next_inverse.svg b/client/public/assets/images/next_inverse.svg
new file mode 100644
index 0000000..bc69c5d
--- /dev/null
+++ b/client/public/assets/images/next_inverse.svg
@@ -0,0 +1,5 @@
+<svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px"
+width="208" height="208"
+viewBox="0 0 26 26"
+transform="rotate(180)"
+style=" fill:#000000;"><path d="M 10.59375 13 L 19.179688 4.234375 C 19.5625 3.84375 19.558594 3.21875 19.171875 2.828125 L 17.636719 1.292969 C 17.242188 0.902344 16.609375 0.902344 16.21875 1.296875 L 5.292969 12.292969 C 5.097656 12.488281 5 12.742188 5 13 C 5 13.257813 5.097656 13.511719 5.292969 13.707031 L 16.21875 24.703125 C 16.609375 25.097656 17.242188 25.097656 17.636719 24.707031 L 19.171875 23.171875 C 19.558594 22.78125 19.5625 22.15625 19.179688 21.765625 Z"></path></svg> \ No newline at end of file
diff --git a/client/public/assets/images/slip.svg b/client/public/assets/images/slip.svg
index f8c5103..cb797bb 100644
--- a/client/public/assets/images/slip.svg
+++ b/client/public/assets/images/slip.svg
@@ -1,9 +1,4 @@
-<svg width="150" height="219" viewBox="0 0 150 219" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
-<rect width="150" height="218.101" fill="url(#pattern0)"/>
-<defs>
-<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1">
-<use xlink:href="#image0_60_279" transform="scale(0.00148368 0.00102041)"/>
-</pattern>
-<image id="image0_60_279" width="674" height="980" xlink:href=""/>
-</defs>
-</svg>
+<svg xmlns="http://www.w3.org/2000/svg" x="0px" y="0px"
+width="200" height="200"
+viewBox="0 0 256 256"
+style=" fill:#000000;"><path fill="#edf4fc" d="M174.5,86.9c0-13.1,6.4-25.3,17.2-32.6V28.9c0-4.3-3.5-7.8-7.8-7.8l0,0h-144c-4.3,0-7.8,3.5-7.8,7.8v83.9 l70.3,60.7c4.9,4.3,12.2,4.3,17.2,0l67.6-57.7C179.1,108.4,174.5,97.9,174.5,86.9z"></path><path fill="#f48e1e" d="M132.9,21L119.6,9.7c-5-4.2-12.2-4.2-17.2,0L89.3,21L132.9,21z"></path><path fill="#f48e1e" d="M32.1,70.5L12,87.8c2.1-0.9,4.3-1.4,6.5-1.4h13.5V70.5z"></path><path fill="#fcac27" d="M214,126.4c-10,0-19.5-3.8-26.8-10.5l-67.6,57.7c-5,4.2-12.2,4.2-17.2,0l-70.3-60.7V86.4H18.6 c-8.9,0-16.1,7.2-16.1,16.1v130.9c0,8.9,7.2,16.1,16.1,16.1h186.1c8.9,0,16.1-7.2,16.1-16.1V125.8 C218.5,126.2,216.3,126.4,214,126.4z"></path><path fill="#facb35" d="M119.6,173.6c-5,4.2-12.2,4.2-17.2,0l-6.5-5.6L7.1,244.7c3,3.1,7.1,4.8,11.4,4.8h186.1 c4.3,0,8.4-1.7,11.4-4.8l-89.9-76.8L119.6,173.6z"></path><path fill="#f48e1e" d="M18.6,86.4c-4.3,0-8.4,1.7-11.4,4.8l25,21.6V86.4H18.6z"></path><circle cx="214" cy="86.9" r="39.5" fill="#fc3850"></circle><path fill="#edf4fc" d="M219.2,67h-12.6c-1.5,0-2.8,1.2-2.8,2.8v5.3c0,1.5,1.2,2.8,2.8,2.8h3.9V106c0,1.5,1.2,2.8,2.8,2.8h6 c1.5,0,2.8-1.2,2.8-2.8V69.7C221.9,68.2,220.7,67,219.2,67C219.2,67,219.2,67,219.2,67z"></path><path d="M214,128.9c-23.2,0-42-18.8-42-42s18.8-42,42-42s42,18.8,42,42c0,0,0,0,0,0C256,110.1,237.2,128.9,214,128.9z M214,49.9 c-20.4,0-37,16.6-37,37s16.6,37,37,37c20.4,0,37-16.6,37-37C251,66.5,234.4,49.9,214,49.9L214,49.9z"></path><path d="M162.8,117.7H61.4c-1.4,0-2.5-1.1-2.5-2.5s1.1-2.5,2.5-2.5h101.4c1.4,0,2.5,1.1,2.5,2.5S164.2,117.7,162.8,117.7z"></path><path d="M162.8,136.7H61.4c-1.4,0-2.5-1.1-2.5-2.5s1.1-2.5,2.5-2.5h101.4c1.4,0,2.5,1.1,2.5,2.5S164.2,136.7,162.8,136.7z"></path><path d="M162.8,60.8H61.4c-1.4,0-2.5-1.1-2.5-2.5s1.1-2.5,2.5-2.5h101.4c1.4,0,2.5,1.1,2.5,2.5S164.2,60.8,162.8,60.8z"></path><path d="M162.8,79.8H61.4c-1.4,0-2.5-1.1-2.5-2.5s1.1-2.5,2.5-2.5h101.4c1.4,0,2.5,1.1,2.5,2.5S164.2,79.8,162.8,79.8z"></path><path d="M162.8,98.7H61.4c-1.4,0-2.5-1.1-2.5-2.5s1.1-2.5,2.5-2.5h101.4c1.4,0,2.5,1.1,2.5,2.5S164.2,98.7,162.8,98.7z"></path><path d="M132.9,23.5H89.3c-1.4,0-2.5-1.1-2.5-2.5c0-0.7,0.3-1.4,0.9-1.9l13.1-11.3c5.8-5.1,14.6-5.1,20.4-0.1l13.3,11.3 c1,0.9,1.2,2.5,0.3,3.5C134.3,23.2,133.6,23.5,132.9,23.5L132.9,23.5z M96.1,18.5h30.1l-8.1-6.9c-4-3.5-9.9-3.4-13.9,0L96.1,18.5z"></path><path d="M12,90.3c-1.4,0-2.5-1.1-2.5-2.5c0-0.7,0.3-1.4,0.9-1.9l20.1-17.3c1-0.9,2.6-0.8,3.5,0.3c0.4,0.5,0.6,1,0.6,1.6v15.9 c0,1.4-1.1,2.5-2.5,2.5H18.6c-1.9,0-3.8,0.4-5.5,1.2C12.7,90.2,12.4,90.3,12,90.3z M20.4,83.9h9.2v-8L20.4,83.9z"></path><path d="M143.5,155.7H78.9c-1.4,0-2.5-1.1-2.5-2.5s1.1-2.5,2.5-2.5h64.6c1.4,0,2.5,1.1,2.5,2.5S144.9,155.7,143.5,155.7z"></path><path d="M204.7,252H18.6C8.3,251.9,0,243.6,0,233.4V102.5c0-10.2,8.3-18.5,18.6-18.6h13.5c1.4,0,2.5,1.1,2.5,2.5v25.2l69.5,60 c4,3.5,9.9,3.5,13.9,0l67.6-57.7c1-0.8,2.4-0.8,3.3,0.1c8.4,7.9,20.1,11.3,31.4,9.3c1.4-0.2,2.7,0.7,2.9,2c0,0.1,0,0.3,0,0.4 v107.6C223.2,243.6,214.9,251.9,204.7,252z M18.6,88.9C11.1,88.9,5,95,5,102.5v130.9c0,7.5,6.1,13.5,13.6,13.6h186.1 c7.5,0,13.5-6.1,13.6-13.6V128.7c-11.2,1.2-22.4-2.3-31.1-9.5l-65.9,56.3c-5.9,5.1-14.6,5-20.4-0.1l-70.3-60.8 c-0.5-0.5-0.9-1.2-0.9-1.9V88.9H18.6z"></path><path d="M111,179.3c-3.8,0-7.4-1.4-10.3-3.8l-70.3-60.7c-0.5-0.5-0.9-1.2-0.9-1.9V28.9c0-5.7,4.6-10.3,10.3-10.3h144 c5.7,0,10.3,4.6,10.3,10.3v25.4c0,0.8-0.4,1.6-1.1,2.1c-16.9,11.5-21.2,34.5-9.7,51.4c1.6,2.3,3.4,4.4,5.4,6.3 c1,0.9,1.1,2.5,0.1,3.5c-0.1,0.1-0.1,0.1-0.2,0.2l-67.6,57.7C118.4,177.9,114.8,179.3,111,179.3z M34.6,111.6l69.5,60 c4,3.5,9.9,3.5,13.9,0l65.5-55.9c-15.9-16.8-15.2-43.4,1.7-59.3c1.3-1.2,2.7-2.4,4.1-3.4V28.9c0-2.9-2.4-5.3-5.3-5.3h-144 c-2.9,0-5.3,2.4-5.3,5.3V111.6z"></path><path d="M219.2,111.3h-6c-2.9,0-5.3-2.4-5.3-5.3V80.3h-1.4c-2.9,0-5.3-2.4-5.3-5.3v-5.3c0-2.9,2.4-5.3,5.3-5.3h12.6 c2.9,0,5.3,2.4,5.3,5.3V106C224.4,108.9,222.1,111.3,219.2,111.3z M206.5,69.5c-0.1,0-0.3,0.1-0.3,0.3v5.3c0,0.1,0.1,0.3,0.3,0.3 h3.9c1.4,0,2.5,1.1,2.5,2.5V106c0,0.1,0.1,0.3,0.3,0.3h6c0.1,0,0.3-0.1,0.3-0.3V69.7c0-0.1-0.1-0.3-0.3-0.3H206.5z"></path><path d="M204.7,252H18.6c-5,0-9.7-2-13.2-5.5c-1-1-1-2.6,0-3.5c0,0,0.1-0.1,0.1-0.1l88.8-76.7c0.9-0.8,2.3-0.8,3.3,0l6.5,5.6 c4,3.5,9.9,3.5,13.9,0l0,0l6.6-5.6c0.9-0.8,2.3-0.8,3.2,0l89.9,76.8c1,0.9,1.2,2.5,0.3,3.5c0,0-0.1,0.1-0.1,0.1 C214.4,250,209.6,252,204.7,252z M11,244.6c2.2,1.5,4.9,2.3,7.6,2.3h186.1c2.7,0,5.3-0.8,7.5-2.3l-86-73.4l-5,4.2 c-5.9,5.1-14.6,5-20.4-0.1l-4.8-4.2L11,244.6z"></path><path d="M32.1,115.3c-0.6,0-1.2-0.2-1.6-0.6l-25-21.6c-1-0.9-1.2-2.5-0.3-3.5c0,0,0.1-0.1,0.1-0.1c3.5-3.6,8.2-5.5,13.2-5.5h13.5 c1.4,0,2.5,1.1,2.5,2.5v26.4C34.6,114.2,33.5,115.3,32.1,115.3L32.1,115.3z M11,91.2l18.6,16.1V88.9h-11 C15.9,88.9,13.2,89.7,11,91.2z"></path></svg> \ No newline at end of file
diff --git a/client/src/components/Card/CardAgreement.jsx b/client/src/components/Card/CardAgreement.jsx
index da35c91..77bb1a0 100644
--- a/client/src/components/Card/CardAgreement.jsx
+++ b/client/src/components/Card/CardAgreement.jsx
@@ -10,7 +10,7 @@ const CardAgreement = ({ title, image }) => {
<>
<div className={styles.card}>
<img className={styles.card__image} src={image} alt="" />
- <Typography>
+ <Typography align='center'>
{t('I_HEREBY_CONFIRM_THE_IDENTITY_AND_ADDRESS')}
</Typography>
</div>
diff --git a/client/src/components/Card/CardAgreement.module.css b/client/src/components/Card/CardAgreement.module.css
index c9bdae8..c6b76cb 100644
--- a/client/src/components/Card/CardAgreement.module.css
+++ b/client/src/components/Card/CardAgreement.module.css
@@ -27,5 +27,5 @@
}
.card__image {
- padding-bottom: 32px;
+ height: 80%;
}
diff --git a/client/src/pages/Enrollment/Agreement/Agreement.jsx b/client/src/pages/Enrollment/Agreement/Agreement.jsx
index cf74d46..d3a5b90 100644
--- a/client/src/pages/Enrollment/Agreement/Agreement.jsx
+++ b/client/src/pages/Enrollment/Agreement/Agreement.jsx
@@ -68,6 +68,7 @@ const Agreement = ({ unverified, setUnverified }) => {
type="submit"
variant="contained"
disabled={disabled}
+ sx={{ marginTop: '1rem' }}
onClick={() => {
mutate()
setDisabled(true)
diff --git a/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.jsx b/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.jsx
index 20ea7d2..86f53f4 100644
--- a/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.jsx
+++ b/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.jsx
@@ -3,15 +3,7 @@ import React, { useState } from 'react'
import Webcam from 'react-webcam'
import Header from '../../../components/Header/Header'
import styles from './DocumentScanner.module.css'
-import {
- Button,
- Grid,
- Typography,
- StepLabel,
- Step,
- Stepper,
- Box
-} from '@mui/material'
+import { Button, Typography, StepLabel, Step, Stepper } from '@mui/material'
import SubmitButton from '../../../components/SubmitButton/SubmitButton'
import { useTranslation } from 'react-i18next'
import { userContext } from '../../../context/User'
@@ -45,15 +37,15 @@ const DocumentScanner = () => {
DOB: doccu.DOB
})
})
-
+ console.log(activeStep)
const handleNext = () => {
if (activeStep === steps.length - 1) {
setUserData({ ...userData, documents: documents })
}
if (
- !userData.documents.POI ||
- !userData.documents.POA ||
- !userData.documents.DOB
+ (!documents.POI && activeStep === 0) ||
+ (!documents.POA && activeStep === 1) ||
+ (!documents.DOB && activeStep === 2)
) {
toast.error(t('SCAN_YOUR_DOCUMENT'))
} else {
@@ -68,67 +60,85 @@ const DocumentScanner = () => {
const WebcamComponent = ({ doc }) => {
return (
<>
- <div className={styles.card__container}>
- {documents[doc] === '' ? (
- <Webcam
- audio={false}
- height={400}
- ref={webcamRef}
- screenshotFormat="image/jpeg"
- width={600}
- videoConstraints={{
- height: 400,
- width: 600,
- facingMode: 'user'
- }}
+ <div className={styles.container}>
+ <button
+ className={styles.button}
+ disabled={activeStep === 0}
+ onClick={handleBack}
+ >
+ <img
+ src={`${process.env.PUBLIC_URL}/assets/images/back_inverse.svg`}
+ alt=""
+ className={styles.image}
/>
- ) : (
- <img src={documents[doc]} />
- )}
+ </button>
+ <div className={styles.card__container}>
+ {documents[doc] === '' ? (
+ <Webcam
+ audio={false}
+ height={400}
+ ref={webcamRef}
+ screenshotFormat="image/jpeg"
+ width={600}
+ videoConstraints={{
+ height: 400,
+ width: 600,
+ facingMode: 'user'
+ }}
+ />
+ ) : (
+ <img src={documents[doc]} />
+ )}
+ </div>
+ <button onClick={handleNext} className={styles.button}>
+ <img
+ src={`${process.env.PUBLIC_URL}/assets/images/next_inverse.svg`}
+ alt=""
+ className={styles.image}
+ />
+ </button>
+ </div>
+ <div className={styles.button__container}>
+ <Button
+ color="primary"
+ size="large"
+ type="submit"
+ variant="contained"
+ sx={{ margin: '0px 20px' }}
+ onClick={(e) => {
+ e.preventDefault()
+ capture(doc)
+ }}
+ >
+ {t('SCAN')}
+ </Button>
+ <Button
+ color="primary"
+ size="large"
+ type="submit"
+ variant="contained"
+ sx={{ margin: '0px 20px' }}
+ onClick={(e) => {
+ e.preventDefault()
+ doccu[doc] = ''
+ setDocuments({
+ ...documents,
+ POI: doccu.POI,
+ POA: doccu.POA,
+ DOB: doccu.DOB
+ })
+ }}
+ >
+ {t('RESET')}
+ </Button>
</div>
- <Grid container columnSpacing={10} justifyContent="center">
- <Grid item sx={{}}>
- <Button
- color="primary"
- size="large"
- type="submit"
- variant="contained"
- onClick={(e) => {
- e.preventDefault()
- capture(doc)
- }}
- >
- {t('SCAN')}
- </Button>
- </Grid>
- <Grid item>
- <Button
- color="primary"
- size="large"
- type="submit"
- variant="contained"
- onClick={(e) => {
- e.preventDefault()
- doccu[doc] = ''
- setDocuments({
- ...documents,
- POI: doccu.POI,
- POA: doccu.POA,
- DOB: doccu.DOB
- })
- }}
- >
- {t('RESET')}
- </Button>
- </Grid>
- </Grid>
<br></br>
<div>
- <Grid container justifyContent="center">
+ <div>
<Typography align="center">
{t('KINDLY_CLICK_THE_PICTURE_OF_YOUR_DOCUMENTS')}
</Typography>
- </Grid>
+ </div>
</div>
</>
)
@@ -139,8 +149,8 @@ const DocumentScanner = () => {
<Header subheading={t('ENROLLMENT')} />
<SubmitButton />
<div className={styles.stepper__container}>
- <Box sx={{ width: '60%', fontSize: '100px !important' }}>
- <Stepper activeStep={activeStep}>
+ <div className={styles.box}>
+ <Stepper activeStep={activeStep} sx={{ width: '60%' }}>
{steps.map((label, index) => {
const stepProps = {}
const labelProps = {}
@@ -157,14 +167,9 @@ const DocumentScanner = () => {
})}
</Stepper>
{activeStep === steps.length ? (
- <React.Fragment>
- <Typography sx={{ mt: 2, mb: 1 }}>
- {t('ALL_STEPS_COMPLETED')}
- </Typography>
- <Box sx={{ display: 'flex', flexDirection: 'row', pt: 2 }}>
- <Box sx={{ flex: '1 1 auto' }} />
- </Box>
- </React.Fragment>
+ <Typography variant="h3" sx={{ mt: 8, mb: 1 }}>
+ {t('ALL_STEPS_COMPLETED')}
+ </Typography>
) : (
<React.Fragment>
{activeStep === 0 ? (
@@ -174,23 +179,9 @@ const DocumentScanner = () => {
) : (
activeStep === 2 && <WebcamComponent doc="DOB" />
)}
- <Box sx={{ display: 'flex', flexDirection: 'row', pt: 2 }}>
- <Button
- color="inherit"
- disabled={activeStep === 0}
- onClick={handleBack}
- sx={{ mr: 1 }}
- >
- {t('BACK')}
- </Button>
- <Box sx={{ flex: '1 1 auto' }} />
- <Button onClick={handleNext}>
- {activeStep === steps.length - 1 ? t('FINISH') : t('NEXT')}
- </Button>
- </Box>
</React.Fragment>
)}
- </Box>
+ </div>
</div>
</>
)
diff --git a/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.module.css b/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.module.css
index 58baaa8..11cd176 100644
--- a/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.module.css
+++ b/client/src/pages/Enrollment/DocumentScanner/DocumentScanner.module.css
@@ -1,6 +1,7 @@
.card__container {
display: flex;
justify-content: center;
+ align-items: center;
margin: 20px;
}
@@ -8,3 +9,42 @@
display: flex;
justify-content: center;
}
+
+.button__container {
+ display: flex;
+ justify-content: space-evenly;
+ align-items: center;
+}
+
+.button {
+ background: transparent;
+ border: none;
+}
+
+.image {
+ height: 50px;
+ width: 50px;
+}
+
+.image:hover {
+ cursor: pointer;
+ transform: scale(1.1);
+}
+
+.image:active {
+ transform: scale(0.98);
+}
+
+.box {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ flex-direction: column;
+ width: 100%;
+ height: 100%;
+}
+
+.container {
+ display: flex;
+ align-items: center;
+} \ No newline at end of file
diff --git a/client/src/pages/Enrollment/Enrollment.jsx b/client/src/pages/Enrollment/Enrollment.jsx
index f180667..e0cfd84 100644
--- a/client/src/pages/Enrollment/Enrollment.jsx
+++ b/client/src/pages/Enrollment/Enrollment.jsx
@@ -33,7 +33,9 @@ const Enrollment = () => {
const navigate = useNavigate()
const [unverified, setUnverified] = useState(true)
- const { mutate } = useMutation((payload) => createUser(payload))
+ const pushUser = useMutation((payload) => createUser(payload))
+
+ // const setConfirm = useMutation((payload) => sendMessage(payload))
const handleSubmit = () => {
if (page === 0) {
@@ -107,9 +109,7 @@ const Enrollment = () => {
} else if (page === 6) {
setPage(page + 1)
} else if (page === 7) {
- setPage(page + 1)
- } else if (page === 8) {
- mutate(
+ pushUser.mutate(
{
indianResident: userData.indianResident,
name: userData.name,
@@ -127,11 +127,17 @@ const Enrollment = () => {
},
{
onSuccess: () => {
- setUserData(initialUserData)
- navigate('/')
+ // setConfirm.mutate({
+ // mobile: `+91${userData.mobile}`,
+ // id: pushUser.data._id
+ // })
+ setPage(page + 1)
}
}
)
+ } else if (page === 8) {
+ setUserData(initialUserData)
+ navigate('/')
}
}
diff --git a/client/src/services/apiservice.js b/client/src/services/apiservice.js
index 0aa9337..e989c01 100644
--- a/client/src/services/apiservice.js
+++ b/client/src/services/apiservice.js
@@ -23,3 +23,8 @@ export const sendOTP = async (payload) => {
const response = await apiClient.post('/otp', payload)
return response
}
+
+export const sendMessage = async (payload) => {
+ const response = await apiClient.post('/message', payload)
+ return response
+}
diff --git a/server/controllers/message.js b/server/controllers/message.js
new file mode 100644
index 0000000..efba38b
--- /dev/null
+++ b/server/controllers/message.js
@@ -0,0 +1,29 @@
+import generateOTP from '../utils/otp';
+import sendSMS from '../services/twilio';
+
+const sendOTP = async (req, res) => {
+ const {mobile} = req.body;
+
+ try {
+ const otp = generateOTP();
+ const message = `Your OTP for Aadhaar verification is : ${otp}`;
+ sendSMS(mobile, message);
+ res.status(200).json({message: 'OTP sent successfully', otpCode: otp});
+ } catch (error) {
+ res.status(404).json({message: error});
+ }
+};
+
+const sendMessage = async (req, res) => {
+ const {mobile, id} = req.body;
+
+ try {
+ const message = `Your request for aadhaar card has been successfully submitted. Please use the id: ${id} for future reference.`;
+ sendSMS(mobile, message);
+ res.status(200).json({message: 'Message sent successfully'});
+ } catch (error) {
+ res.status(404).json({message: error});
+ }
+};
+
+export default {sendOTP, sendMessage}; \ No newline at end of file
diff --git a/server/controllers/otp.js b/server/controllers/otp.js
deleted file mode 100644
index 5b4bd82..0000000
--- a/server/controllers/otp.js
+++ /dev/null
@@ -1,17 +0,0 @@
-import generateOTP from '../utils/otp';
-import sendMessage from '../services/twilio';
-
-const sendOTP = async (req, res) => {
- const {mobile} = req.body;
-
- try {
- const otp = generateOTP();
- const message = `Your OTP for Aadhaar verification is : ${otp}`;
- sendMessage(mobile, message);
- res.status(200).json({message: 'OTP sent successfully', otpCode: otp});
- } catch (error) {
- res.status(404).json({message: error});
- }
-};
-
-export default {sendOTP};
diff --git a/server/index.js b/server/index.js
index 2ccd121..2a1bb1b 100644
--- a/server/index.js
+++ b/server/index.js
@@ -6,7 +6,7 @@ import dotenv from 'dotenv';
import userRoutes from './routes/users.js';
import healthRoutes from './routes/health.js';
-import otpRoutes from './routes/otp.js';
+import messageRoutes from './routes/message.js';
const app = Express();
dotenv.config();
@@ -17,7 +17,7 @@ app.use(cors());
app.use('/', healthRoutes);
app.use('/', userRoutes);
-app.use('/', otpRoutes);
+app.use('/', messageRoutes);
const CONNECTION_URL = process.env.CONNECTION_URL;
const PORT = process.env.PORT;
diff --git a/server/routes/message.js b/server/routes/message.js
new file mode 100644
index 0000000..0062838
--- /dev/null
+++ b/server/routes/message.js
@@ -0,0 +1,9 @@
+import Express from 'express';
+import message from '../controllers/message';
+
+const router = Express.Router();
+
+router.post('/otp', message.sendOTP);
+router.post('/message', message.sendMessage);
+
+export default router;
diff --git a/server/routes/otp.js b/server/routes/otp.js
deleted file mode 100644
index b73240e..0000000
--- a/server/routes/otp.js
+++ /dev/null
@@ -1,8 +0,0 @@
-import Express from 'express';
-import otp from '../controllers/otp';
-
-const router = Express.Router();
-
-router.post('/otp', otp.sendOTP);
-
-export default router;
diff --git a/server/services/twilio.js b/server/services/twilio.js
index f95cc5f..69eac16 100644
--- a/server/services/twilio.js
+++ b/server/services/twilio.js
@@ -3,7 +3,7 @@ import twilio from 'twilio';
const accountSid = process.env.TWILIO_ACCOUNT_SID;
const authToken = process.env.TWILIO_AUTH_TOKEN;
-const sendMessage = (phone, message) => {
+const sendSMS = (phone, message) => {
const client = twilio(accountSid, authToken);
client.messages
.create({
@@ -14,4 +14,4 @@ const sendMessage = (phone, message) => {
.then((message) => console.log(message.sid));
};
-export default sendMessage;
+export default sendSMS;