Skip to content

waywardcode/Typewriter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Typewriter (Unofficial fork)

Typewriter is a Visual Studio extensions that generates TypeScript files from c# code files using TypeScript Templates. This allows you to create fully typed TypeScript representations of server side API, models, controllers, SignalR hubs etc. that automatically updates when you make changes to your c# code.

Original Documentation
Download from Visual Studio Gallery old version 1.22.0

Why new fork?

It seems that Fredrik Hagnelius author of Typewriter is very busy and do not have enough time for supporting that extensions. From the other side that extensions really helps fulstack developers and work on it should be continued.

Main differences between original and this fork

Version 2.8.0

  • version compatible with Visual Studio 17.2.x

Version 2.7.0

  • latest updates for Visual Studio 17.1.x

Version 2.6.1

  • fix relative paths in output directory - now relative to template location

Version 2.6.0

  • ability to setup different output directory in settings.OutputDirectory
  • ability to skip adding generated files in project in template by using settings.SkipAddingGeneratedFilesToProject

Version 2.5.0

  • file scoped namespaces C# 10 compatibility

Version 2.3.1

  • exposing solution path in settings

Version 2.2.6

Version 1.32.0

  • added DefaultValue

Version 1.31.0

Version 1.30.0

  • Added support for C# 9.0 records
  • Fixed error for 'string?' type - invalid marked as IsEnumerable

Issues

The issue tracker is the preferred channel for bug reports, features requests and submitting pull requests.
For personal support requests Stack Overflow is a better place to get help. Please use the typewriter tag when posting your questions.

Getting started

Step 1: Add a TypeScript Template file (.tst)
Step 2: Add the following code in the template

$Classes(*Model)[ // Find all classes with a name ending with Model
    class $Name {
        constructor($Properties[public $name: $Type][, ]) {
        }
    }
]

Step 3: Save the template
Step 4: Add a c# class named TestModel
Step 5: Add the following code to the class

using System;

namespace TestApplication
{
    public class TestModel
    {
        public int Id { get; set; }
        public int Name { get; set; }
    }
}

Step 6: Save the class.

Each time a class matching the filter in the template is saved a TypeScript class matching the template is updated or added to the project.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages