PNG %k25u25%fgd5n!
/home/mkuwqnjx/palaknaturals.com/wp-content/plugins/code-snippets/js/hooks/useFileUploadAPI.ts
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])
}