Skip to content

Latest commit

 

History

History
158 lines (114 loc) · 4.24 KB

README.md

File metadata and controls

158 lines (114 loc) · 4.24 KB

Renata Front-End Task

Build Status Given Task:

  • [Build] Make a two page application for encryption/decryption message
  • [Data Processing] Dependent Dropdowns

Tach Stack

  • React - For Front-End Library 🏡
  • TailWindCSS - For Simple Style 💄 & responsiveness ✨
  • CSS - Simple Animations 💫
  • SheetJS - For parsing excel data

How to start

See LIVE here: Renata Task Application

Or

Install the dependencies and devDependencies and start the server.

npm install
npm start

✨ Simple!

TasK One

Encryption Process:

  1. Take an object of array of all alphabates
const alphabates = {
    upperCase:['A','B','C',...],
    lowerCase:['a','b','c',...]
}
  1. Recieve the message from Input field
  2. Generate a random number for secret key. between 1-25
  3. Match the message letters with alphabate object to find index
  4. Add the secret key. with index
  5. Shift the letter number of secret key. times
  6. Round up the letter if new index > 26
  7. Concant the new shifted leeter starting with the secret key.
  8. Finally replace the 'SPACE' with point (.)

Additional feature

Copy to clipboard to copy the result

Limitation

Only message of characters with uppercase or lowercase can be encoded.

Result

input: CATS And DOGS
output: 25BZSR.Zmc.CNFR

Decryption Process:

Reverse The Encryption process

  1. Separate the secret key. from encode message
  2. Find the letters from alphabate object
  3. Subtract the secret key. from each index of letters
  4. Shift back the letters bysecret key. times
  5. If new index < 0 round up the letter backward
  6. Concat the decoded letters
  7. Replace the point(.) with 'SPACE'

Limitation

Only characters with uppercase or lowercase, numbers and point(.) can be decoded.

Result

input:25BZSR.Zmc.CNFR
output:CATS And DOGS

TasK Two

Web resource url Finded :

Data Processing from excel sheet:

  1. Used SheetJs for parsing the data from excel sheet
  2. Parsing the data from excel file within onload event
 var url = "data.xlsx"; // the excel file should be in public folder

  useEffect(() => {
    var oReq = new XMLHttpRequest();
    oReq.open("GET", url, true);
    oReq.responseType = "arraybuffer";

    oReq.onload = function (e) {
      var arraybuffer = oReq.response;

      /* convert data to binary string */
      var data = new Uint8Array(arraybuffer);
      var arr = [];
      for (var i = 0; i !== data.length; ++i)
        arr[i] = String.fromCharCode(data[i]);
      var bstr = arr.join("");

      /* Call XLSX */
      var workbook = XLSX.read(bstr, {
        type: "binary",
      });

      /* DO SOMETHING WITH workbook HERE */
      var first_sheet_name = workbook.SheetNames[0];
      /* Get worksheet */
      var worksheet = workbook.Sheets[first_sheet_name];
      var data__raw = XLSX.utils.sheet_to_json(worksheet, {
        raw: true,
      });
      console.log("line 33", data__raw);
      setFetchedData(data__raw);
      console.log(
        XLSX.utils.sheet_to_json(worksheet, {
          raw: true,
        })
      );
    };

    oReq.send();
    },[url])
  1. Set the data in a react state
  2. Map the first field Language in the Language Dropdown
  3. After selecting the first dropdown option filter the fetched data according to the selected Laguage field.then map the second dropdown
  4. Same process with the third dropdown after selecting the topic field from second dropdown
  5. Finallay find the Iframe link after according to the value of three dropdown

Problem faced during solving the problem

  1. All the W3school.com links are blocked by their Content Security Policy.That's why , all the links refuse to connect in the iFrame.
  2. Parsing the Data from Excel sheet was tough.

Solutions:

  1. For problem One Couldn't found any solution to show the url links because w3school refuse to connect because of their policies. Only in their domain Iframe works fine because of own domain.
  2. First three Iframe link data is changed with other resource links in the excel file just to show the logic works fine.
  3. A Default Link is provided in iFrame .