import { defineStore } from 'pinia'; import axios from 'axios'; import { Dataset } from '@/Dataset'; import menu from '@/menu'; export interface Person { id: number; name: string; email: string; name_type: string; identifier_orcid: string; datasetCount: string; created_at: string; } interface TransactionItem { amount: number; account: string; name: string; date: string; type: string; business: string; } export enum State { STATE_DISABLED = 0, STATE_CREATED = 1, STATE_ENABLED = 2, } export const saveState = async (data) => { const url = '/api/twofactor_totp/settings/enable'; const resp = await axios.post(url, data); return resp.data; }; // Anfrage staet : 1 // ANtwort json: // state: 1 // secret:"OX7IQ4OI3GXGFPHY" // qUrl:"https://odysseus.geologie.ac.at/apps/twofactor_totp/settings/enable" export const MainService = defineStore('main', { state: () => ({ /* User */ userName: '', userEmail: null, userAvatar: null, /* Field focus with ctrl+k (to register only once) */ isFieldFocusRegistered: false, /* Sample data for starting dashboard(commonly used) */ clients: [], history: [] as Array, // api based data authors: [] as Array, // persons: [] as Array, datasets: [], files: [], dataset: {} as Dataset, menu: menu, totpState: 0, graphData: {}, }), actions: { // payload = authenticated user setUser(payload) { if (payload.name) { this.userName = payload.name; } if (payload.email) { this.userEmail = payload.email; } if (payload.avatar) { this.userAvatar = payload.avatar; } }, setDataset(payload) { this.dataset = payload; // this.dataset = { // language: language, // licenses: payload.licenses, // rights: payload.rights, // type: payload.type, // creating_corporation: payload.creating_corporation, // titles: payload.titles, // descriptions: payload.descriptions, // authors: payload.authors, // project_id: payload.project_id, // embargo_date: payload.embargo_date, // } as Dataset; // for (let index in payload.titles) { // let title = payload.titles[index]; // title.language = language; // } }, clearDataset() { this.dataset = null; }, fetch(sampleDataKey) { // sampleDataKey= clients or history axios .get(`/data-sources/${sampleDataKey}.json`) .then((r) => { if (r.data && r.data.data) { this[sampleDataKey] = r.data.data; } }) .catch((error) => { alert(error.message); }); }, fetchApi(sampleDataKey) { // sampleDataKey= authors or datasets axios .get(`/api/${sampleDataKey}`) .then((r) => { if (r.data) { this[sampleDataKey] = r.data; } }) .catch((error) => { alert(error.message); }); }, setState(state) { this.totpState = state; }, async create(): Promise<{ url: any; secret: any; svg: any }> { const { state, secret, url, svg } = await saveState({ state: State.STATE_CREATED }); this.totpState = state; return { url, secret, svg }; // .then(({ state, secret, qrUrl }) => { // this.totpState = state; // return { qrUrl, secret }; // }) // .catch((error) => { // alert(error.message); // }); }, async disable() { const { state } = await saveState({ state: State.STATE_DISABLED }); this.totpState = state; }, async confirm(code: string) { const { state } = await saveState({ state: State.STATE_ENABLED, code, }); this.totpState = state; }, async fetchChartData(year) { // sampleDataKey= authors or datasets axios .get(`/api/statistic/${year}`) .then((r) => { if (r.data) { this.graphData = r.data; } }) .catch((error) => { alert(error.message); }); }, // fetchfiles(id) { // // sampleDataKey= authors or datasets // axios // .get(`api/files/${id}`) // .then((r) => { // if (r.data) { // this[sampleDataKey] = r.data; // } // }) // .catch((error) => { // alert(error.message); // }); // }, }, });