Hello maliming,
I did check that and that is how I figured out that it is failing. The dynamically generated abp.services.app creates “jJComputerSystem”. I then went in and created an entity of all lower case prefix of jjComputerSystem and it dynamically generated abp.services.app creates “jjComputerSystem” which is correct and works. I then tried other two digit prefixes and they had the same problem if I made both of them CAPS like JJ{entity} or MM{entity}. It is dynamically creating them wrong so I was trying to find the file that creates the list of abp.services.app.{service} but I could not find that. I am just trying to add a prefix the way your tables are setup with a App prefix I was making “JJ” prefix so it is easy to find in the db.
I am new to AspNet Zero and this is my first project using it so I apologize if I am calling things by the wrong name. I have always put things in MVVM pattern using controllers with everything coded and not dynamically created. I like your way better than the way I used to do it!
Howie
Hi Javier,
Go to {your project name} \AspNetZeroRadTool\FileTemplates\Server\ExportAppServiceClass\ and copy the file MainTemplate.txt to the filename MainTemplate.custom.txt. Now open that file and make it refelect this:
using System.Collections.Generic; using Abp.Runtime.Session; using Abp.Timing.Timezone; using {{Namespace_Here}}.DataExporting.Excel.NPOI; using {{Namespace_Here}}.{{Namespace_Relative_Full_Here}}.Dtos; using {{Namespace_Here}}.Dto; using {{Namespace_Here}}.Storage;
namespace {{Namespace_Here}}.{{Namespace_Relative_Full_Here}}.Exporting { public class {{Entity_Name_Plural_Here}}ExcelExporter : NpoiExcelExporterBase, I{{Entity_Name_Plural_Here}}ExcelExporter {
private readonly ITimeZoneConverter _timeZoneConverter;
private readonly IAbpSession _abpSession;
public {{Entity_Name_Plural_Here}}ExcelExporter(
ITimeZoneConverter timeZoneConverter,
IAbpSession abpSession,
ITempFileCacheManager tempFileCacheManager) :
base(tempFileCacheManager)
{
_timeZoneConverter = timeZoneConverter;
_abpSession = abpSession;
}
public FileDto ExportToFile(List<Get{{Entity_Name_Here}}ForViewDto> {{entity_Name_Plural_Here}})
{
return CreateExcelPackage(
"{{Entity_Name_Plural_Here}}.xlsx",
excelPackage =>
{
var sheet = excelPackage.CreateSheet(L("{{Entity_Name_Plural_Here}}"));
AddHeader(
sheet{{Property_Header_Here}}{{NP_Header_Here}}
);
AddObjects(
sheet, 2, {{entity_Name_Plural_Here}}{{Property_Params_Here}}{{NP_Params_Here}}
);
{{Property_DateTime_Formatter_Here}}
});
}
}
}
Save the file and to {your project name} \AspNetZeroRadTool\FileTemplates\Server\ExportAppServiceClass\MainTemplate.custom.txt and go back and regenerate your files and they will work.
For completeness I changed:
using {{Namespace_Here}}.DataExporting.Excel.EpPlus; Change to using {{Namespace_Here}}.DataExporting.Excel.NPOI;
var sheet = excelPackage.Workbook.Worksheets.Add(L("{{Entity_Name_Plural_Here}}")); changed to var sheet = excelPackage.CreateSheet(L("{{Entity_Name_Plural_Here}}"));
Then remove line sheet.OutLineApplyStyle = true;
The code above is the compled version.
Howie
Hello @maliming,
I did see those, I was wondering if On the Roadmap it shows "User Sync/Link feature", will this be a Xamarin offline sync feature?. I don't know when that was put on the roadmap so I would just wait for that feature, however if the "User Sync/Link feature" is not a Xamarin local user sync but something else then I would just go down the path of the those other questions.
Thanks
Thanks, It all works.