Compare commits

...

5 Commits

7 changed files with 87 additions and 16 deletions

6
package-lock.json generated
View File

@ -46,11 +46,11 @@
"geist": "^1.3.1", "geist": "^1.3.1",
"input-otp": "1.4.1", "input-otp": "1.4.1",
"lucide-react": "^0.454.0", "lucide-react": "^0.454.0",
"next": "14.2.16", "next": "^14.2.16",
"next-themes": "^0.4.6", "next-themes": "^0.4.6",
"react": "^18", "react": "^18.3.1",
"react-day-picker": "9.8.0", "react-day-picker": "9.8.0",
"react-dom": "^18", "react-dom": "^18.3.1",
"react-hook-form": "^7.60.0", "react-hook-form": "^7.60.0",
"react-resizable-panels": "^2.1.7", "react-resizable-panels": "^2.1.7",
"recharts": "2.15.4", "recharts": "2.15.4",

View File

@ -47,11 +47,11 @@
"geist": "^1.3.1", "geist": "^1.3.1",
"input-otp": "1.4.1", "input-otp": "1.4.1",
"lucide-react": "^0.454.0", "lucide-react": "^0.454.0",
"next": "14.2.16", "next": "^14.2.16",
"next-themes": "^0.4.6", "next-themes": "^0.4.6",
"react": "^18", "react": "^18.3.1",
"react-day-picker": "9.8.0", "react-day-picker": "9.8.0",
"react-dom": "^18", "react-dom": "^18.3.1",
"react-hook-form": "^7.60.0", "react-hook-form": "^7.60.0",
"react-resizable-panels": "^2.1.7", "react-resizable-panels": "^2.1.7",
"recharts": "2.15.4", "recharts": "2.15.4",

64
services/api.mjs Normal file
View File

@ -0,0 +1,64 @@
// váriaveis básicas
const BASE_URL = "https://yuanqfswhberkoevtmfr.supabase.co";
const API_KEY = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJzdXBhYmFzZSIsInJlZiI6Inl1YW5xZnN3aGJlcmtvZXZ0bWZyIiwicm9sZSI6ImFub24iLCJpYXQiOjE3NTQ5NTQzNjksImV4cCI6MjA3MDUzMDM2OX0.g8Fm4XAvtX46zifBZnYVH4tVuQkqUH6Ia9CXQj4DztQ";
var tempToken;
async function login() {
const response = await fetch("https://yuanqfswhberkoevtmfr.supabase.co/auth/v1/token?grant_type=password", {
method: "POST",
headers: {
"Content-Type": "application/json",
"apikey": API_KEY, // valor fixo
},
body: JSON.stringify({ email: "hugo@popcode.com.br", password: "hdoria" }),
});
const data = await response.json();
console.log("Resposta da API:", data);
console.log("Token:", data.access_token);
// salvar o token do usuário
//localStorage.setItem("token", data.access_token);
tempToken = data.access_token
return data;
}
await login()
async function request(endpoint, options = {}) {
//const token = localStorage.getItem("token"); // token do usuário, salvo no login
const token = tempToken;
const headers = {
"Content-Type": "application/json",
"apikey": API_KEY, // obrigatório sempre
...(token ? { Authorization: `Bearer ${token}` } : {}), // obrigatório em todas EXCETO login
...options.headers,
};
try {
const response = await fetch(`${BASE_URL}${endpoint}`, {
...options,
headers,
});
if (!response.ok) {
throw new Error(`Erro HTTP: ${response.status}`);
}
return await response.json();
} catch (error) {
console.error("Erro na requisição:", error);
throw error;
}
}
export const api = {
get: (endpoint) => request(endpoint, { method: "GET" }),
post: (endpoint, body) =>
request(endpoint, { method: "POST", body: JSON.stringify(body) }),
patch: (endpoint, body) =>
request(endpoint, { method: "PATCH", body: JSON.stringify(body) }),
delete: (endpoint) => request(endpoint, { method: "DELETE" }),
};

0
services/doctorsApi.mjs Normal file
View File

9
services/patientsApi.mjs Normal file
View File

@ -0,0 +1,9 @@
import { api } from "./api.mjs";
export const patientsService = {
list: () => api.get("/rest/v1/patients"),
getById: (id) => api.get(`/rest/v1/patients/${id}`),
create: (data) => api.post("/rest/v1/patients", data),
update: (id, data) => api.patch(`/rest/v1/patients/${id}`, data),
delete: (id) => api.delete(`/rest/v1/patients/${id}`),
};

View File

@ -1,25 +1,23 @@
{ {
"compilerOptions": { "compilerOptions": {
"target": "esnext",
"lib": ["dom", "dom.iterable", "esnext"], "lib": ["dom", "dom.iterable", "esnext"],
"allowJs": true, "allowJs": true,
"target": "ES6",
"skipLibCheck": true, "skipLibCheck": true,
"strict": true, "strict": true,
"forceConsistentCasingInFileNames": true,
"noEmit": true, "noEmit": true,
"esModuleInterop": true, "esModuleInterop": true,
"module": "esnext", "module": "esnext",
"moduleResolution": "bundler", "moduleResolution": "node",
"resolveJsonModule": true, "resolveJsonModule": true,
"isolatedModules": true, "isolatedModules": true,
"jsx": "preserve", "jsx": "preserve",
"incremental": true, "incremental": true,
"plugins": [ "plugins": [{ "name": "next" }],
{ "baseUrl": ".", // adiciona esta linha
"name": "next" "paths": { // adiciona esta linha
} "@/*": ["./*"] // e esta linha
],
"paths": {
"@/*": ["./*"]
} }
}, },
"include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"], "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"],