-
Notifications
You must be signed in to change notification settings - Fork 83
Home
Here is quickstart documentation cheatsheet for Reinforced.Typings (a.k.a. RT). Here you will find out information about how to set up RT, how to generate your first typings and how to extend RT.
To use Reinforced.Typings in your ASP.NET MVC project you need to install it from NuGet. Use UI or run from Package Manager Console:
PM> Install-Package Reinforced.Typings
It will install following components:
- RT .dll library to be used in project. It contains configuration classes, attributes and other stuff
- RT command-line utility that will be called every project's build and generate TypeScript typings for your project's assembly
- MSBuild script parts (.targets file and .dll containing MSBuild task for calling RT CLI)
- RT configuration file (Reinforced.Typings.settings.xml) that is being added to your project root.
RT has 3 configuration points:
- Reinforced.Typings.settings.xml file contains common generation properties. This file is well-documented. Feel free to read configuration parameters description right inside this file. Please do not delete or move this file out of project root. Actually Reinforced.Typings.settings.xml is MSBuild script part being executed each build. It is referenced inside Reinforced.Typings.targets file that is referenced and contains necessary properties to successfully run code generation.
- Attribute configuration - consists of attributes that you must arrange around your code to achieve specific code generation results. See more details about attribute configuration in corresponding part of this article
- Fluent configuration - an alternate way to configure code generation results. It can be used along with attribute configuration. See more details in corresponding part of this article
Simpliest way to start working with RT is using attribute configuration. Let's try to export sample class as TS interface. Let's assume that we have ASP.NET MVC project with TypeScript feature enabled and /Scripts
folder located in root of project.
-
Navigate to your class
public class OrderViewModel { public string ItemName { get; set; } public int Quantity { get; set; } public decimal Subtotal { get; set; } public bool IsPaid { get; set; } public string ClientName { get; set; } public string Address { get; set; } }
-
Add
using
forReinforced.Typings.Attributes
namespace and place[TsInterface]
attribute above your classusing Reinforced.Typings.Attributes; // ! [TsInterface] // ! public class OrderViewModel { // fold }
-
Rebuild your project
-
According to default value of
RtTargetFile
parameter specified in Reinforced.Typings.settings.xml, generated code is now dropped to$(ProjectDir)Scripts\project.ts
. So if you are using VS2015 or above - you have to add this file to your solution. To do that navigate to your project's/Scripts
folder in Project Inspector. Then Right click - "Add Existing item..." - Locate project.ts - Press "Add". Or locate generated file in Windows explorer then drag generated file into VisualStudio's Project Explorer then drop it inside/Scripts
folder. -
Feel free to reference generated .ts file in your other TypeScripts. Contents of generated file are:
module _your_namespace_ { export interface IOrderViewModel { ItemName: string; Quantity: number; Subtotal: number; IsPaid: boolean; ClientName: string; Address: string; } }
Calm down, Reinforced.Typings handles this problem. Just go to Reinforced.Typings.settings.xml and set RtBypassTypeScriptCompilation
to true
. This will disable TypeScript build when you rebuild your project C# code (dirty MSBuild hack is used here). Then you can fix your typings export code to produce valid typings. This is kind of killer-feature of Reinforced.Typings.
Important! Do not forget to set RtBypassTypeScriptCompilation
back to false
to restore TypeScript compilation during project build.
Besides [TsInterface]
attribute there are others. Avaiable attributes are presented at Configuration attributes page
There are some cases when attribute configuration is not applicable. E.g. when you trying to export typings for types belonging to another assembly which source code you do not have. In this case fluent configuration may be usable. Let's rewrite example above using fluent configuration:
-
Create static class containing static method that consumes instance of
Reinforced.Typings.Fluent.ConfigurationBuilder
somewhere as followsusing Reinforced.Typings.Fluent; namespace YourProjectNamespace { public static class ReinforcedTypingsConfiguration { public static void Configure(ConfigurationBuilder builder) { builder .ExportAsInterface<OrderViewModel>() .WithPublicProperties(); } } }
-
Go to Reinforced.Typings.settings.xml and set there
RtConfigurationMethod
parameter to full-qualified name ofConfigure
method as follows:... <RtConfigurationMethod>YourProjectNamespace.ReinforcedTypingsConfiguration.Configure</RtConfigurationMethod> ...
-
Rebuild your project and check project.ts file
You can find out more info about fluent configuration on this page.
Check out how to embed JSDOC to your TypeScript files here.
Reinforced.Typings has amazing abilities for spreading your generated TypeScript code among several files. Please discover them by referring to corresponding documentation section.
Check out how Reinforced.Typings resolves types and how can you handle it.
Check out advanced customization guide to know how to override code generators in RT and what can be achieved by using them. Also we have practical samples demostating RT's code generation in action. They can be found here (.zip download). Just open then with VisualStudio and run. Index page will show detailed instructions.