Skip to content

Commit

Permalink
Removed: util functions those are unused
Browse files Browse the repository at this point in the history
  • Loading branch information
ymaheshwari1 committed Feb 2, 2024
1 parent 2336044 commit 27a9f7c
Showing 1 changed file with 1 addition and 101 deletions.
102 changes: 1 addition & 101 deletions src/utils/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,4 @@
import saveAs from "file-saver";
import { toastController } from "@ionic/vue";
import Papa from "papaparse"
import { Group, Route, Rule } from "@/types";
import { DateTime } from "luxon";

Expand All @@ -21,104 +19,6 @@ const showToast = async (message: string) => {
return toast.present();
}

// Utility for parsing CSV file
// Package Used : PapaParse (Link to Documentation : https://www.papaparse.com/docs#config)

// In this we will be receiving the file and options in the function
// and we are returning a promise with results in it

// We have used the parse method of the papaparse library which will take a config object with File.
// In the config object we have passed various keys:
// - header : It tells papaparse that there will be a header in the CSV.
// - skipEmptyLines : It will ignore any empty lines in the CSV.
// - complete : A parse result always contains three objects: data, errors, and meta.
// data and errors are arrays, and meta is an object. In the step callback, the data
// array will only contain one element.

// Also, we have passed options, as if user wants to add some more properties to the method
// or if he want to modify some pre-build keys then he can do so.

// Types of Responses

// CSV FILE :
// columnA,columnB,columnC
// "Susan",41,a
// "Mike",5,b
// "Jake",33,c
// "Jill",30,d

// For (header:true) we get
// [{columnA: "Susan", columnB: "41", columnC: "a"},
// {columnA: "Mike", columnB: "5", columnC: "b"},
// {columnA: "Jake", columnB: "33", columnC: "c"},
// {columnA: "Jill", columnB: "30", columnC: "d"}]

// // For (header:false) we get
// [["columnA", "columnB", "columnC"],
// ["Susan", "41", "a"],
// ["Mike", "5", "b"],
// ["Jake", "33", "c"],
// ["Jill", "30", "d"]]

const parseCsv = async (file: File, options: any) => {
return new Promise ((resolve, reject) => {
Papa.parse(file, {
header: false,
skipEmptyLines: true,
complete: function (results: any) {
if (results.errors.length) {
reject(results.error)
} else {
resolve(results)
}
},
...options
});
})
}

// Here we have created a JsonToCsvOption which contains the properties which we can pass to jsonToCsv function

interface JsonToCsvOption {
parse?: object | null;
encode?: object | null;
name?: string;
download?: boolean;
}

// Utility for converting Javascript Object into blob and download it as Csv
// Package Used : PapaParse (Link to Documentation : https://www.papaparse.com/docs#config)
// file-saver (Link to Documentation : https://www.npmjs.com/package/file-saver)

// In this we will be receiving a Javascript object and options in the function and we will be
// returning a blob object

// We have used a unparse method of papaparse library for converting javascript object into csv file,
// and in addition to this we are using saveAs method to download our blob file
// In the options we will be passing various keys:
// parse: In this we will be passing a object which contains various properties (headers,skipEmptyLines) to be passed in unparse method
// encode: In this we will be passing a object which contains various properties related to the encoding like { type }
// name: In this we will provide a name by which we want to download the csv File, and it is necessary to provide the .csv in the name
// download: In this we will provide a value which will decide whether we want to download the file or not

const jsonToCsv = (file: any, options: JsonToCsvOption = {}) => {
const csv = Papa.unparse(file, {
...options.parse
});
const encoding = {
type: String,
default: "utf-8",
...options.encode
};
const blob = new Blob([csv], {
type: "application/csvcharset=" + encoding
});
if (options.download) {
saveAs(blob, options.name ? options.name : "default.csv");
}
return blob;
}

const sortSequence = (sequence: Array<Group | Route | Rule>) => {
// Currently, sorting is only performed on sequenceNum, so if two seqence have same seqNum then they will be arranged in FCFS basis
// TODO: Need to check that if for the above case we need to define the sorting on name as well, when seqNum is same
Expand All @@ -133,4 +33,4 @@ const getTimeFromSeconds = (time: any) => {
return time ? DateTime.fromSeconds(time).toLocaleString(DateTime.DATETIME_MED) : "-";
}

export { getTime, getTimeFromSeconds, showToast, hasError , parseCsv , jsonToCsv, JsonToCsvOption, sortSequence }
export { getTime, getTimeFromSeconds, showToast, hasError, sortSequence }

0 comments on commit 27a9f7c

Please sign in to comment.