PATH:
home
/
urbaoubp
/
rasadnik.caffemarilyn.online
/
wp-content
/
plugins
/
code-snippets
/
js
/
hooks
import { useMemo } from 'react' import { useAxios } from './useAxios' import type { AxiosResponse, CreateAxiosDefaults } from 'axios' export interface FileUploadRequest { files: FileList } export interface FileParseResponse { snippets: ImportableSnippet[] total_count: number message: string warnings?: string[] } export interface ImportableSnippet { id?: number name: string desc?: string description?: string code: string tags?: string[] scope?: string source_file?: string table_data: { id: number | string title: string scope: string tags: string description: string type: string } } export interface SnippetImportRequest { snippets: ImportableSnippet[] duplicate_action: 'ignore' | 'replace' | 'skip' network?: boolean } export interface SnippetImportResponse { imported: number imported_ids: number[] message: string } const ROUTE_BASE = `${window.CODE_SNIPPETS?.restAPI.base}code-snippets/v1/` const AXIOS_CONFIG: CreateAxiosDefaults = { headers: { 'X-WP-Nonce': window.CODE_SNIPPETS?.restAPI.nonce } } export interface FileUploadAPI { parseFiles: (request: FileUploadRequest) => Promise<AxiosResponse<FileParseResponse>> importSnippets: (request: SnippetImportRequest) => Promise<AxiosResponse<SnippetImportResponse>> } export const useFileUploadAPI = (): FileUploadAPI => { const { axiosInstance } = useAxios(AXIOS_CONFIG) return useMemo((): FileUploadAPI => ({ parseFiles: (request: FileUploadRequest) => { const formData = new FormData() for (let i = 0; i < request.files.length; i++) { formData.append('files[]', request.files[i]) } return axiosInstance.post<FileParseResponse>( `${ROUTE_BASE}file-upload/parse`, formData, { headers: { 'Content-Type': 'multipart/form-data', } } ) }, importSnippets: (request: SnippetImportRequest) => { return axiosInstance.post<SnippetImportResponse>( `${ROUTE_BASE}file-upload/import`, request ) } }), [axiosInstance]) }
[-] useFileUploadAPI.ts
[edit]
[-] useRestAPI.tsx
[edit]
[-] useImportersAPI.ts
[edit]
[-] useSubmitSnippet.ts
[edit]
[-] useSnippetsList.tsx
[edit]
[+]
..
[-] useAxios.ts
[edit]
[-] useSnippetForm.tsx
[edit]