@swan-admin/swan-ai-measurements
Version:
provides ai measurement suggestion
105 lines (104 loc) • 4.12 kB
JavaScript
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
import axios from "axios";
import { APP_AUTH_BASE_URL, URLS, requiredMetaData } from "./constants.js";
import { URLType } from "./enum.js";
export function fetchData(options) {
return __awaiter(this, void 0, void 0, function* () {
const { path, body, queryParams, baseUrl = APP_AUTH_BASE_URL, apiKey, token, throwError = false, headers = Object.assign(Object.assign({ "Content-Type": "application/json" }, (apiKey ? { "X-Api-Key": apiKey } : {})), (token ? { Authorization: `Bearer ${token}` } : {})), urlType = URLType.PROD, } = options;
const apiUrl = `${getUrl({ urlName: baseUrl, urlType })}${path}${queryParams ? `?${new URLSearchParams(queryParams)}` : ""}`;
try {
const res = yield axios.post(apiUrl, body, { headers });
if (res.status >= 200 && res.status < 300) {
return res.data;
}
console.error(`Error: Unexpected response status ${res.status}`);
if (throwError) {
throw new Error(`Failed to upload`);
}
return {};
}
catch (error) {
console.error(error, "while uploading");
if (throwError) {
throw new Error(`Failed to upload: ${(error === null || error === void 0 ? void 0 : error.message) || "something went wrong"}`);
}
return {};
}
});
}
export function checkParameters(...args) {
for (const element of args) {
if (!element) {
return false;
}
}
return true;
}
export function checkMetaDataValue(arr) {
if (!checkValues(arr, requiredMetaData)) {
return false;
}
// let correctFormat = false;
// for (const obj of arr) {
// if (obj.callback_url && obj.callback_url.startsWith("https")) {
// correctFormat = true;
// }
// }
// if (!correctFormat) {
// return false;
// }
return true;
}
export const checkValues = (arr, requiredMetaData) => {
for (const key of requiredMetaData) {
let hasRequiredKey = false;
for (const obj of arr) {
if (Object.prototype.hasOwnProperty.call(obj, key) &&
obj[key] !== undefined &&
obj[key] !== null &&
obj[key] !== "" &&
typeof obj[key] !== "number") {
hasRequiredKey = true;
break;
}
}
if (!hasRequiredKey) {
return false;
}
}
return true;
};
export const addScanType = (arr, scan_id, email) => {
const scanType = arr.find((el) => el.scan_type);
if (!scanType) {
arr.push({ scan_type: "clothing_scan" });
}
arr.push({ scan_id });
arr.push({ email });
return arr;
};
export function getFileChunks(file, chunkSize = 5 * 1024 * 1024) {
const totalSize = file.size;
const chunks = [];
let start = 0;
while (start < totalSize) {
chunks.push(file.slice(start, start + chunkSize));
start += chunkSize;
}
return chunks;
}
export const getUrl = ({ urlName, urlType = URLType.PROD }) => {
return URLS[urlType][urlName];
};
export const isValidEmail = (email) => {
const checkEmailValidation = /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
return checkEmailValidation.test(email);
};