I am attempting to use the Page Alerts Service (https://docs.abp.io/en/abp/latest/UI/Angular/Page-Alerts) to provide system notifications to users of our application. However, a requirement for this is to allow hyperlinks in the notifications. By default HTML does not appear to work within these notifications, is there a way to allow for hyperlinks?
I am using the microservice template.
I need to create an endpoint which generates a csv download of data this is stored in our DB. I am using ABP generate proxy, however after the proxy is generated I cannot access the passed data in the front end (it errors in the subscribe). Experimenting with the proxy has shown me that if I edit the proxy to set the responseType to blob, the download works. Unfortunately this change is wiped out every time we regenerate the proxy, and so manually editing it does not seem like a long term viable solution. Is there a way to specify the proxies response type for an endpoint? Or is there a better way of accessing the FileStreamResult in the front end?
Here is the code for the Controller:
[HttpGet]
[Route("entry/export/csv")]
public async Task<IActionResult> GetTimeEntryExportCSV(Guid[] ids)
{
var bytes = await _fileExportAppService.GetTimeEntryExportCSV(ids);
MemoryStream stream = new MemoryStream();
stream.Write(bytes, 0, bytes.Length);
stream.Position = 0;
var file = File(stream, "application/octet-stream", "exported-time"+DateTime.Now.ToString("yyyyMMddHHmmss")+".csv");
return file;
}
Here is the generated proxy:
getTimeEntryExportCSVByIds = (ids: string[]) =>
this.restService.request<any, IActionResult>({
method: 'GET',
url: '/api/timetracker-service/entry/export/csv',
params: { ids }
},
{ apiName: this.apiName });