79117f424d | ||
---|---|---|
_build | ||
_utils | ||
code | ||
design/Assets | ||
docs | ||
poc | ||
samples | ||
templates | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
CONTRIBUTING.md | ||
LICENSE.md | ||
README.md |
README.md
Windows Template Studio
Windows Template Studio is a Visual Studio 2017 Extension that accelerates the creation of new Universal Windows Platform (UWP) apps using a wizard-based experience. The resulting UWP project is well-formed, readable code that incorporates the latest Windows 10 features while implementing proven patterns and best practices. Sprinkled throughout the generated code we have links Docs, Stack Overflow and blogs to provide useful insights.
Example scenario: I need an app that uses MVVM Light, uses master detail, can suspend and resume, settings, maps on one of the pages and will need Azure hub notifications. It will need a background service that does a query every 5 minutes.
Build Status
Branch | CI | Test Version | Version |
---|---|---|---|
master | |||
dev |
Branch | Gen Tests | Full Tests | WACK Tests |
---|---|---|---|
master | |||
dev |
The builds include test verifications to validate the contributions:
- CI Build: Includes all unit test + minimum integration verifications (minumum generation + build + code style rules). Runs every PR requested / PR accepted.
- Gen Tests: Includes tests to verify combinations and variations of templates from a project generation point of view. Runs every PR accepted and takes a bit to complete.
- Full Tests: Includes
Gen Tests
and actually builds the solutions generated to ensure no build time issues found. Runs every PR accepted and takes longer to be completed.- Wack Tests: Includes tests that run the App Certification Kit against the generated projects to ensure there are no issues blocking a submission to the store. Runs once nightly and takes quite a while to complete.
Features
Windows Template Studio approaches UWP app creation using the following four attribute sets:
- Project type: First, how do you want your app's UI navigation to behave? We currently support three project types: basic, navigation pane, and pivot and tabs.
- App framework: Next, what coding pattern do you want to use in your project, we currently support three common patterns: code behind, basic MVVM, MVVM Light, and CaliburnMicro.
- App pages: To accelerate app creation, we provide a number of app page templates that you can use to add common UI pages into your new app. We currently include page templates from the blank page to the common layouts (e.g., master/detail, tabbed, web view) to pages that implement common patterns (e.g., app settings, map control). Using the wizard, add as many of the pages as you need, providing a name for each one, and we'll generate them for you.
- Windows 10 features: Lastly, you specify which UWP capabilities you want to use in your app, and we'll build out the framework for the features into your app, tagging 'TODO' items. Currently supported features cover application lifecycle (settings storage, suspend and resume), background tasks, and user interaction (app notifications, Live tiles, and Azure Notification Hub).
Once you select the attributes you want your new UWP app to have, you can quickly extend the generated code.
Documentation
- Installing / Using the extension
- Using and extending your generated project
- Concepts of Windows Template Studio
- Getting started with the generator codebase
- Authoring Templates
Known issues
- You can't have side-by-side versions (nightly/pre-release/release) of WindowsTemplateStudio VSPackage into a single instance of Visual Studio.
Feedback, Requests and Roadmap
Please use GitHub issues for feedback, questions or comments.
If you have specific feature requests or would like to vote on what others are recommending, please go to the GitHub issues section as well. We would love to see what you are thinking.
Here is what we're currently thinking in our roadmap.
Contributing
Do you want to contribute? We would love to have you help out. Here are our contribution guidelines.
Principles
- Generated templates will be kept simple.
- Generated templates are a starting point, not a completed application.
- Generated templates once generated, must be able to be compiled and run.
- Generated templates should work on all device families.
- Templates should have comments to aid developers. This includes links to signup pages for keys, MSDN, blogs and how-to's. All guidance provide should be validated from either the framework/SDK/library’s creator.
- All features will be supported for two most recent RTM Windows 10 Updates. Those supported releases are Windows 10 Creators Update and Windows 10 Fall Creators Update.
- Templates released in production will try to adhere to the design language used in the current release of Windows 10.
- Code should follow .NET Core coding style.
This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behavior in our community. For more information see the .NET Foundation Code of Conduct.
License
This code is distributed under the terms and conditions of the MIT license.
Privacy Statement
The extension does log basic telemetry for what is being selected. Please read the Microsoft privacy statement for more information.
.NET Foundation
This project is supported by the .NET Foundation.