diff --git a/OnlyOneAccessTemplate/Controllers/ConverterController.cs b/OnlyOneAccessTemplate/Controllers/ConverterController.cs index 2f25fcc..487589f 100644 --- a/OnlyOneAccessTemplate/Controllers/ConverterController.cs +++ b/OnlyOneAccessTemplate/Controllers/ConverterController.cs @@ -6,10 +6,12 @@ using OnlyOneAccessTemplate.Models; namespace OnlyOneAccessTemplate.Controllers { + [ApiController] + [Route("converter")] // Adicione esta linha public class ConverterController : BaseController { private readonly IServiceProvider _serviceProvider; - private readonly ILogger _logger; + //private readonly ILogger _logger; private readonly Dictionary _converterTypes; public ConverterController( @@ -18,20 +20,21 @@ namespace OnlyOneAccessTemplate.Controllers ISeoService seoService, IMemoryCache cache, IConfiguration configuration, - IServiceProvider serviceProvider, - ILogger logger + IServiceProvider serviceProvider + //,ILogger logger ) : base(siteConfig, languageService, seoService, cache, configuration) { _serviceProvider = serviceProvider; - this._logger = logger; + //this._logger = logger; // Registrar tipos de conversores disponíveis _converterTypes = new Dictionary { ["text-case"] = typeof(TextCaseConverterService), ["csv-json"] = typeof(CsvToJsonConverterService), - ["image-ocr"] = typeof(ImageToTextConverterService) + ["image-ocr"] = typeof(ImageToTextConverterService), + ["sentence-converter"] = typeof(UpperLowerConversorService) // Adicionar novos conversores aqui }; } @@ -98,7 +101,7 @@ namespace OnlyOneAccessTemplate.Controllers } catch (Exception ex) { - _logger.LogError(ex, "Erro na conversão {ConverterType}", converterType); + //_logger.LogError(ex, "Erro na conversão {ConverterType}", converterType); return StatusCode(500, new { success = false, message = "Erro interno do servidor" }); } } @@ -121,9 +124,15 @@ namespace OnlyOneAccessTemplate.Controllers } catch (Exception ex) { - _logger.LogError(ex, "Erro ao buscar configuração do conversor {ConverterType}", converterType); + //_logger.LogError(ex, "Erro ao buscar configuração do conversor {ConverterType}", converterType); return StatusCode(500, new { success = false, message = "Erro interno do servidor" }); } } + + [HttpGet("test")] + public IActionResult Test() + { + return Ok(new { message = "Controller funcionando", timestamp = DateTime.Now }); + } } } diff --git a/OnlyOneAccessTemplate/Program.cs b/OnlyOneAccessTemplate/Program.cs index a89f901..bd271c7 100644 --- a/OnlyOneAccessTemplate/Program.cs +++ b/OnlyOneAccessTemplate/Program.cs @@ -40,6 +40,7 @@ builder.Services.AddScoped(); builder.Services.AddScoped(); builder.Services.AddScoped(); +builder.Services.AddScoped(); // Adicione aqui novos conversores conforme necessrio: // builder.Services.AddScoped(); @@ -59,8 +60,7 @@ builder.Services.AddResponseCaching(); // Memory Cache builder.Services.AddMemoryCache(); -// Logging -builder.Logging.ClearProviders(); +// Loggingbuilder.Logging.ClearProviders(); builder.Logging.AddConsole(); builder.Logging.AddDebug(); diff --git a/OnlyOneAccessTemplate/Services/UpperLowerConversorService.cs b/OnlyOneAccessTemplate/Services/UpperLowerConversorService.cs new file mode 100644 index 0000000..4648769 --- /dev/null +++ b/OnlyOneAccessTemplate/Services/UpperLowerConversorService.cs @@ -0,0 +1,85 @@ +using OnlyOneAccessTemplate.Services.OnlyOneAccessTemplate.Services; +using System.Text.RegularExpressions; +using System.Text; + +namespace OnlyOneAccessTemplate.Services +{ + public class UpperLowerConversorService : BaseConverterService + { + public override string ConverterType => "text-case-sentence"; + + public override string ConverterName => "Maiúsculas para minúsculas"; + + public UpperLowerConversorService(ILogger logger, IConfiguration configuration) + : base(logger, configuration) { } + + public override async Task ConvertAsync(ConversionRequest request) + { + try + { + // Sua lógica de conversão aqui + var resultado = ConvertToSentenceCase(request.TextInput); + + return new ConversionResult(true, OutputText: resultado); + } + catch (Exception ex) + { + _logger.LogError(ex, "Erro na conversão"); + return new ConversionResult(false, ErrorMessage: "Erro ao processar"); + } + } + + private string ConvertToSentenceCase(string text) + { + if (string.IsNullOrEmpty(text)) + return text; + + // Converte todo o texto para minúsculas primeiro + string lowerText = text.ToLower(); + + // StringBuilder para construir o resultado + StringBuilder result = new StringBuilder(lowerText); + + // Capitaliza a primeira letra do texto se for uma letra + if (result.Length > 0 && char.IsLetter(result[0])) + { + result[0] = char.ToUpper(result[0]); + } + + // Regex para encontrar início de frases/parágrafos + // Procura por pontos, exclamações, interrogações ou quebras de linha + // seguidos por espaços e uma letra + string pattern = @"([.!?\n]\s*)([a-z])"; + + string resultText = result.ToString(); + resultText = Regex.Replace(resultText, pattern, match => + { + return match.Groups[1].Value + char.ToUpper(match.Groups[2].Value[0]); + }); + + return resultText; + } + + public override ConverterConfiguration GetConfiguration(string language) + { + var texts = GetLocalizedTexts(language); + + // Personalize os textos para seu conversor + texts["ConverterTitle"] = language switch + { + "en" => "Sentence Case Convert", + "es" => "TÍTULO DE TU CONVERTIDOR", + _ => "Converter para primeira maiúscula" + }; + + return new ConverterConfiguration + { + ConverterType = "text", // ou "file" ou "url" + OutputType = "text", // ou "download" ou "preview" + HasAdvancedOptions = false, + AllowShare = true, + LocalizedTexts = texts + }; + } + } +} diff --git a/OnlyOneAccessTemplate/Views/Shared/_ConverterWidget.cshtml b/OnlyOneAccessTemplate/Views/Shared/_ConverterWidget.cshtml index f54b686..42dff63 100644 --- a/OnlyOneAccessTemplate/Views/Shared/_ConverterWidget.cshtml +++ b/OnlyOneAccessTemplate/Views/Shared/_ConverterWidget.cshtml @@ -8,7 +8,7 @@
- + @if (ViewBag.ConverterType == "file") { @@ -31,24 +31,24 @@
} - + @if (ViewBag.ConverterType == "text") { -
@ViewBag.InputHelpText
} - + @if (ViewBag.ConverterType == "url") { -
@ViewBag.InputHelpText
} - + @if (ViewBag.HasAdvancedOptions == true) { @@ -57,8 +57,8 @@ @(ViewBag.AdvancedOptionsText ?? "Opções Avançadas")
- @{ - try + @{ + try { await Html.RenderPartialAsync("_AdvancedOptions"); } @@ -74,12 +74,12 @@
} - +
- + - +
@if (ViewBag.OutputType == "text") { - } else if (ViewBag.OutputType == "download") @@ -115,13 +115,13 @@
}
- + - +
- +
+ \ No newline at end of file diff --git a/OnlyOneAccessTemplate/appsettings.json b/OnlyOneAccessTemplate/appsettings.json index a352ef2..05a11de 100644 --- a/OnlyOneAccessTemplate/appsettings.json +++ b/OnlyOneAccessTemplate/appsettings.json @@ -1,7 +1,7 @@ { // Exemplo 1: Conversor de Maiúsculas/Minúsculas "Converter": { - "Type": "text-case", + "Type": "text-case-sentence", "Name": "Conversor de Maiúsculas e Minúsculas" }, diff --git a/OnlyOneAccessTemplate/wwwroot/js/converters/image-ocr-converter.js b/OnlyOneAccessTemplate/wwwroot/js/converters/image-ocr-converter.js new file mode 100644 index 0000000..7970708 --- /dev/null +++ b/OnlyOneAccessTemplate/wwwroot/js/converters/image-ocr-converter.js @@ -0,0 +1,165 @@ +// wwwroot/js/converters/image-ocr-converter.js +// Implementação específica para conversor de imagem para texto (OCR) + +async function performConversion(formData) { + const fileInput = formData.get('file'); + + if (!fileInput || fileInput.size === 0) { + throw new Error('Por favor, selecione uma imagem'); + } + + // Validar tipo de arquivo + const allowedTypes = ['image/jpeg', 'image/jpg', 'image/png', 'image/gif', 'image/bmp', 'application/pdf']; + if (!allowedTypes.includes(fileInput.type)) { + throw new Error('Formato de arquivo não suportado. Use JPG, PNG, GIF, BMP ou PDF.'); + } + + // Validar tamanho (15MB) + if (fileInput.size > 15 * 1024 * 1024) { + throw new Error('Arquivo muito grande. Tamanho máximo: 15MB'); + } + + const requestData = new FormData(); + requestData.append('inputType', 'file'); + requestData.append('fileInput', fileInput); + requestData.append('language', document.documentElement.lang || 'pt'); + + // Adicionar opções de OCR se houver + const ocrLanguage = formData.get('ocrLanguage') || 'por'; + const options = { ocrLanguage: ocrLanguage }; + requestData.append('options', JSON.stringify(options)); + + const response = await fetch('/converter/api/convert/image-ocr', { + method: 'POST', + body: requestData + }); + + if (!response.ok) { + const error = await response.json(); + throw new Error(error.message || 'Erro no processamento da imagem'); + } + + const result = await response.json(); + + // Mostrar resultado do OCR + showOcrResult(result.outputText, fileInput); +} + +function showOcrResult(extractedText, originalFile) { + const outputTextElement = document.getElementById('outputText'); + const successActions = document.getElementById('successActions'); + + if (outputTextElement) { + outputTextElement.value = extractedText; + document.getElementById('outputArea').style.display = 'block'; + successActions.style.display = 'block'; + + // Mostrar preview da imagem + showImagePreview(originalFile); + + // Adicionar botão para salvar texto + addSaveTextButton(extractedText); + } +} + +function showImagePreview(file) { + const previewContainer = document.getElementById('imagePreview'); + if (previewContainer && file.type.startsWith('image/')) { + const reader = new FileReader(); + reader.onload = function (e) { + previewContainer.innerHTML = ` +
+ Imagem processada:
+ Preview +
+ `; + }; + reader.readAsDataURL(file); + } +} + +function addSaveTextButton(text) { + const successActions = document.getElementById('successActions'); + + if (document.getElementById('saveTextBtn')) return; + + const saveBtn = document.createElement('button'); + saveBtn.id = 'saveTextBtn'; + saveBtn.type = 'button'; + saveBtn.className = 'btn btn-sm btn-outline-success'; + saveBtn.innerHTML = ' Salvar Texto'; + + saveBtn.addEventListener('click', () => { + const blob = new Blob([text], { type: 'text/plain;charset=utf-8' }); + const url = URL.createObjectURL(blob); + const a = document.createElement('a'); + a.href = url; + a.download = 'texto-extraido.txt'; + document.body.appendChild(a); + a.click(); + document.body.removeChild(a); + URL.revokeObjectURL(url); + }); + + successActions.appendChild(saveBtn); +} + +function initializeConverter() { + setupAdvancedOcrOptions(); + setupImagePreview(); +} + +function setupAdvancedOcrOptions() { + const advancedContainer = document.getElementById('advancedSettings'); + if (advancedContainer) { + advancedContainer.innerHTML = ` +
+
+ + +
+
+ + +
+
+ `; + } +} + +function setupImagePreview() { + const fileInput = document.getElementById('fileInput'); + if (fileInput) { + fileInput.addEventListener('change', function (e) { + const file = e.target.files[0]; + if (file && file.type.startsWith('image/')) { + const reader = new FileReader(); + reader.onload = function (event) { + let previewContainer = document.getElementById('imagePreview'); + if (!previewContainer) { + previewContainer = document.createElement('div'); + previewContainer.id = 'imagePreview'; + fileInput.parentNode.appendChild(previewContainer); + } + + previewContainer.innerHTML = ` +
+ Preview +
+ `; + }; + reader.readAsDataURL(file); + } + }); + } +} \ No newline at end of file diff --git a/OnlyOneAccessTemplate/wwwroot/js/converters/sentence-converter.js b/OnlyOneAccessTemplate/wwwroot/js/converters/sentence-converter.js new file mode 100644 index 0000000..9a0c220 --- /dev/null +++ b/OnlyOneAccessTemplate/wwwroot/js/converters/sentence-converter.js @@ -0,0 +1,45 @@ +async function performConversion(formData) { + // Validar entrada + const input = formData.get('inputText') || formData.get('file'); + if (!input) { + throw new Error('Por favor, forneça uma entrada válida'); + } + + // Preparar dados + const requestData = new FormData(); + requestData.append('inputType', 'text'); // ou 'file' + requestData.append('textInput', input); + requestData.append('language', document.documentElement.lang || 'pt'); + + // Fazer requisição + const response = await fetch('/converter/api/convert/sentence-converter', { + method: 'POST', + body: requestData + }); + + if (!response.ok) { + const error = await response.json(); + throw new Error(error.message || 'Erro na conversão'); + } + + const result = await response.json(); + + // Mostrar resultado + showResult(result.outputText); +} + +function showResult(output) { + const outputElement = document.getElementById('outputText'); + const successActions = document.getElementById('successActions'); + + if (outputElement) { + outputElement.value = output; + document.getElementById('outputArea').style.display = 'block'; + successActions.style.display = 'block'; + } +} + +function initializeConverter() { + // Inicializações específicas do seu conversor + console.log('Conversor inicializado'); +} \ No newline at end of file diff --git a/OnlyOneAccessTemplate/wwwroot/js/converters/text-case-converter.js b/OnlyOneAccessTemplate/wwwroot/js/converters/text-case-sentence.js similarity index 56% rename from OnlyOneAccessTemplate/wwwroot/js/converters/text-case-converter.js rename to OnlyOneAccessTemplate/wwwroot/js/converters/text-case-sentence.js index 42caa28..a2c2019 100644 --- a/OnlyOneAccessTemplate/wwwroot/js/converters/text-case-converter.js +++ b/OnlyOneAccessTemplate/wwwroot/js/converters/text-case-sentence.js @@ -246,168 +246,3 @@ function debounce(func, wait) { }; } -// wwwroot/js/converters/image-ocr-converter.js -// Implementação específica para conversor de imagem para texto (OCR) - -async function performConversion(formData) { - const fileInput = formData.get('file'); - - if (!fileInput || fileInput.size === 0) { - throw new Error('Por favor, selecione uma imagem'); - } - - // Validar tipo de arquivo - const allowedTypes = ['image/jpeg', 'image/jpg', 'image/png', 'image/gif', 'image/bmp', 'application/pdf']; - if (!allowedTypes.includes(fileInput.type)) { - throw new Error('Formato de arquivo não suportado. Use JPG, PNG, GIF, BMP ou PDF.'); - } - - // Validar tamanho (15MB) - if (fileInput.size > 15 * 1024 * 1024) { - throw new Error('Arquivo muito grande. Tamanho máximo: 15MB'); - } - - const requestData = new FormData(); - requestData.append('inputType', 'file'); - requestData.append('fileInput', fileInput); - requestData.append('language', document.documentElement.lang || 'pt'); - - // Adicionar opções de OCR se houver - const ocrLanguage = formData.get('ocrLanguage') || 'por'; - const options = { ocrLanguage: ocrLanguage }; - requestData.append('options', JSON.stringify(options)); - - const response = await fetch('/converter/api/convert/image-ocr', { - method: 'POST', - body: requestData - }); - - if (!response.ok) { - const error = await response.json(); - throw new Error(error.message || 'Erro no processamento da imagem'); - } - - const result = await response.json(); - - // Mostrar resultado do OCR - showOcrResult(result.outputText, fileInput); -} - -function showOcrResult(extractedText, originalFile) { - const outputTextElement = document.getElementById('outputText'); - const successActions = document.getElementById('successActions'); - - if (outputTextElement) { - outputTextElement.value = extractedText; - document.getElementById('outputArea').style.display = 'block'; - successActions.style.display = 'block'; - - // Mostrar preview da imagem - showImagePreview(originalFile); - - // Adicionar botão para salvar texto - addSaveTextButton(extractedText); - } -} - -function showImagePreview(file) { - const previewContainer = document.getElementById('imagePreview'); - if (previewContainer && file.type.startsWith('image/')) { - const reader = new FileReader(); - reader.onload = function (e) { - previewContainer.innerHTML = ` -
- Imagem processada:
- Preview -
- `; - }; - reader.readAsDataURL(file); - } -} - -function addSaveTextButton(text) { - const successActions = document.getElementById('successActions'); - - if (document.getElementById('saveTextBtn')) return; - - const saveBtn = document.createElement('button'); - saveBtn.id = 'saveTextBtn'; - saveBtn.type = 'button'; - saveBtn.className = 'btn btn-sm btn-outline-success'; - saveBtn.innerHTML = ' Salvar Texto'; - - saveBtn.addEventListener('click', () => { - const blob = new Blob([text], { type: 'text/plain;charset=utf-8' }); - const url = URL.createObjectURL(blob); - const a = document.createElement('a'); - a.href = url; - a.download = 'texto-extraido.txt'; - document.body.appendChild(a); - a.click(); - document.body.removeChild(a); - URL.revokeObjectURL(url); - }); - - successActions.appendChild(saveBtn); -} - -function initializeConverter() { - setupAdvancedOcrOptions(); - setupImagePreview(); -} - -function setupAdvancedOcrOptions() { - const advancedContainer = document.getElementById('advancedSettings'); - if (advancedContainer) { - advancedContainer.innerHTML = ` -
-
- - -
-
- - -
-
- `; - } -} - -function setupImagePreview() { - const fileInput = document.getElementById('fileInput'); - if (fileInput) { - fileInput.addEventListener('change', function (e) { - const file = e.target.files[0]; - if (file && file.type.startsWith('image/')) { - const reader = new FileReader(); - reader.onload = function (event) { - let previewContainer = document.getElementById('imagePreview'); - if (!previewContainer) { - previewContainer = document.createElement('div'); - previewContainer.id = 'imagePreview'; - fileInput.parentNode.appendChild(previewContainer); - } - - previewContainer.innerHTML = ` -
- Preview -
- `; - }; - reader.readAsDataURL(file); - } - }); - } -} \ No newline at end of file