From 4ac50962320e3b5e5865ddc325d035bfd79721c4 Mon Sep 17 00:00:00 2001 From: Ward Bell Date: Mon, 24 Apr 2017 00:24:40 -0700 Subject: [PATCH] docs(aio): revised "Docs" page --- aio/content/guide/docs.md | 101 ++++++++++++------ aio/content/guide/fundamentals.md | 5 - aio/content/guide/learning-angular.md | 58 ---------- aio/content/guide/techniques.md | 5 - aio/content/navigation.json | 2 - .../live-example/live-example.component.html | 3 + .../live-example.component.spec.ts | 12 ++- .../live-example/live-example.component.ts | 10 +- 8 files changed, 89 insertions(+), 107 deletions(-) delete mode 100644 aio/content/guide/fundamentals.md delete mode 100644 aio/content/guide/learning-angular.md delete mode 100644 aio/content/guide/techniques.md diff --git a/aio/content/guide/docs.md b/aio/content/guide/docs.md index f60c2b6da6..c6a8566db3 100644 --- a/aio/content/guide/docs.md +++ b/aio/content/guide/docs.md @@ -1,48 +1,79 @@ -@title -Angular Docs +# Angular Docs -@description +Welcome to the Angular documentation where you'll find guidance for beginners and experts alike. -
+## What is Angular? - -

Quickstart

-

A quick look at an Angular application.

- -
+Angular is a platform for building and running web applications on desktop and mobile devices. +It's an architecture, a modular library, and a set of tools to help teams +build amazing web apps that run anywhere at scales large and small. - -

Getting Started

-

A beginner's guide to basic Angular concepts.

- -
+## Organization - -

Tutorial

-

The "Tour of Heroes" tutorial, a step-by-step.

- -
+Navigate the docs with the tree-view in the left side panel. Each top level category unfolds into topics that cover Angular from a distinct perspective: - -

API Reference

-

The developer's reference to Angular classes, methods, etc.

- -
+- **Getting Started** is a taste of Angular in under five minutes. - -

Core Guide

-

The Fundamentals of Angular.

- -
+- **Tutorial** is a step-by-step introduction to the essentials of Angular as you build a data-driven application with multi-page navigation. - -

Angular Techniques

-

Techniques for setting up, configuring, and deploying your application.

- -
+
-
+If you're new to Angular, we recommend that you start with these two categories before moving selectively through the others. + +
+ +- **Fundamentals** explains each Angular concept and feature in practical terms with loads of examples. + +- **Techniques** covers tools and techniques for setting up, testing, securing, and deploying your application. + +- **API** is the comprehensive, searchable documentation for every Angular class, interface, and programmable feature. + +- **References** include answers to common questions about usage and style. + +## Sample code + + + +Guide pages are full of code snippets that you can copy and use in your own projects. The snippets are typically drawn from an example app. +Look for the **link** that launches a browser-based editor where you can see it run, inspect the code, modify it, and save changes. + +In most cases you can also download the example, +unzip it, and run locally with these terminal commands: + + +npm install +npm start + + +## Assumptions + +While we strive to keep these pages beginner-friendly, we have to make a few assumptions about your skills and experience in order to stay focused on Angular. + +We assume that you are a seasoned, front-end web developer with a working knowledge of +**HTML, CSS, JavaScript**. The [Mozilla Developer Network](https://developer.mozilla.org/en-US/ "MDN - Mozilla Developer Network") is an excellent resource for reference and general learning. + +Effective Angular developers become familiar with two other technologies: + +**npm** - Modern web development depends on the [npm package management](https://www.npmjs.com/ "npm") system for distribution and installation of third party libraries. Angular is one such library. + +**TypeScript** - [TypeScript](http://www.typescriptlang.org/ "TypeScript") is a _typed_ superset of JavaScript. For the most part it is ES2015 JavaScript with type annotations to improve your design time experience and make it easier for teams to develop sophisticated applications. + +You _can_ write Angular applications in [JavaScript without TypeScript](guide/ts-to-js "Writing Angular in JavaScript"). But you should be able to _read_ TypeScript to understand this documentation and participate in conversations within the Angular community. The Angular CLI productivity tool and AOT high performance compiler only apply to TypeScript applications. + +You don't have to be an expert in npm or TypeScript to get started with Angular. A little knowledge will get you going and you can pick up what you need along the way. + +## Versions This is the Angular **version 4** documentation. See what's new in the [documentation changelog](guide/change-log). View the [Angular change log](https://github.com/angular/angular/blob/master/CHANGELOG.md) for enhancement and fixes to Angular itself. The Angular **version 2** documentation has been archived at [v2.angular.io](https://v2.angular.io "Angular v2 Docs"). + + +## Feedback + +We welcome feedback! + +You can file documentation [issues](https://github.com/angular/angular/issues "Angular Github Issues") and create [pull requests](https://github.com/angular/angular/pulls "Angular Github PRs") on the Angular Github repository. +Please prefix your issue or pull request title with "**docs:**" so that we know it concerns _documentation_ and draws the prompt attention of the appropriate people. + +Remember that a respectful, supportive approach produce the best results. Please consult and adhere to our [code of conduct](https://github.com/angular/code-of-conduct/blob/master/CODE_OF_CONDUCT.md "contributor code of conduct") when engaging with the Angular community. \ No newline at end of file diff --git a/aio/content/guide/fundamentals.md b/aio/content/guide/fundamentals.md deleted file mode 100644 index dce126d543..0000000000 --- a/aio/content/guide/fundamentals.md +++ /dev/null @@ -1,5 +0,0 @@ -@title -Fundamentals of Angular - -@description -Learn the fundamental features of Angular in this section of the guide. \ No newline at end of file diff --git a/aio/content/guide/learning-angular.md b/aio/content/guide/learning-angular.md deleted file mode 100644 index 8dd2a96230..0000000000 --- a/aio/content/guide/learning-angular.md +++ /dev/null @@ -1,58 +0,0 @@ -@title -Learning Angular - -@intro -A suggested path through the documentation for Angular newcomers. - -@description - - - -
- Us -
- - - -Everyone learns differently. -You don't have to read the documentation straight through. Most pages stand on their own. -Those new to Angular may wish to follow this popular learning path. -
- -1. [Setup](guide/setup "Setup locally withe Quickstart seed") for local Angular development, if you haven't already done so. - -1. Take the [*Tour of Heroes* tutorial](tutorial "Tour of Heroes"). - - The *Tour of Heroes* takes you step-by-step from [setup](guide/setup) - to a full-featured example that demonstrates the essential characteristics of a professional application: - a sensible project structure, data binding, master/detail, services, dependency injection, navigation, and remote data access. - -1. {@a architecture}Read the [Architecture](guide/architecture) overview for the big picture. - -1. [The Root Module](guide/appmodule) introduces the `NgModule` class that tells Angular how to compile and run your application. - -1. [Displaying Data](guide/displaying-data) shows how data binding puts component property values on screen. - -1. [User Input](guide/user-input) explains how to respond to user-initiated DOM events. - -1. [Forms](guide/forms) covers data entry and validation within the UI. - -1. [Dependency Injection](guide/dependency-injection) is the way to build large, maintainable applications -from small, single-purpose parts. - -1. [Template Syntax](guide/template-syntax) is a comprehensive study of Angular template HTML. - -After reading the above sections, feel free to skip around among the other pages on this site. - - -
- - - -### Next Step - -Try the [tutorial](tutorial "Tour of Heroes") if you're ready to start coding or -visit the [Architecture](guide/architecture "Basic Concepts") page if you prefer to learn the basic concepts first. - -
- diff --git a/aio/content/guide/techniques.md b/aio/content/guide/techniques.md deleted file mode 100644 index 3ae2ac4e92..0000000000 --- a/aio/content/guide/techniques.md +++ /dev/null @@ -1,5 +0,0 @@ -@title -Techniques - -@description -Learn important Angular application techniques such as how to setup, secure, and deploy your application. diff --git a/aio/content/navigation.json b/aio/content/navigation.json index 336295ac9d..522a2d9fe4 100644 --- a/aio/content/navigation.json +++ b/aio/content/navigation.json @@ -88,7 +88,6 @@ { "title": "Fundamentals", - "url": "guide/fundamentals", "tooltip": "The fundamentals of Angular", "children": [ @@ -261,7 +260,6 @@ { "title": "Techniques", - "url": "guide/techniques", "tooltip": "Techniques for putting Angular to work in your environment", "children": [ diff --git a/aio/src/app/embedded/live-example/live-example.component.html b/aio/src/app/embedded/live-example/live-example.component.html index 7ab9d25a8d..fd1fee551b 100644 --- a/aio/src/app/embedded/live-example/live-example.component.html +++ b/aio/src/app/embedded/live-example/live-example.component.html @@ -9,6 +9,9 @@ You can also download this example.

+ + {{title}} + {{title}} diff --git a/aio/src/app/embedded/live-example/live-example.component.spec.ts b/aio/src/app/embedded/live-example/live-example.component.spec.ts index 5c01251663..50ebc2d788 100644 --- a/aio/src/app/embedded/live-example/live-example.component.spec.ts +++ b/aio/src/app/embedded/live-example/live-example.component.spec.ts @@ -167,10 +167,20 @@ describe('LiveExampleComponent', () => { it('should not have a download link when `noDownload` atty present', async(() => { setHostTemplate(''); testComponent(() => { - expect(getAnchors().length).toBe(1, 'only the live-example anchor'); + const hrefs = getHrefs(); + expect(hrefs.length).toBe(1, 'only the plunker live-example anchor'); + expect(hrefs[0]).toContain('plnkr.html'); }); })); + it('should only have a download link when `downloadOnly` atty present', async(() => { + setHostTemplate('download this'); + testComponent(() => { + const hrefs = getHrefs(); + expect(hrefs.length).toBe(1, 'only the zip anchor'); + expect(hrefs[0]).toContain('.zip'); }); + })); + it('should have default title when no title attribute or content', async(() => { setHostTemplate(''); testComponent(() => { diff --git a/aio/src/app/embedded/live-example/live-example.component.ts b/aio/src/app/embedded/live-example/live-example.component.ts index 4879aedd98..3e204a8b05 100644 --- a/aio/src/app/embedded/live-example/live-example.component.ts +++ b/aio/src/app/embedded/live-example/live-example.component.ts @@ -23,6 +23,7 @@ const zipBase = 'content/zips/'; * [embedded-style] // show plnkr in embedded style (default and on narrow screens) * [flat-style] // show plnkr in flat (original) style * [noDownload] // no downloadable zip option +* [downloadOnly] // just the zip * [title="..."]> // text for live example link and tooltip * text // higher precedence way to specify text for live example link and tooltip * @@ -99,7 +100,12 @@ export class LiveExampleComponent implements OnInit { const noDownload = this.getAttrValue(['noDownload', 'nodownload']); // noDownload aliases this.enableDownload = !boolFromAtty(noDownload); + this.plnkrImg = imageBase + (attrs.img || defaultPlnkrImg); + + if (boolFromAtty(this.getAttrValue(['downloadOnly', 'downloadonly']))) { + this.mode = 'downloadOnly'; + } } calcPlnkrLink(width: number) { @@ -154,7 +160,9 @@ export class LiveExampleComponent implements OnInit { @HostListener('window:resize', ['$event.target.innerWidth']) onResize(width) { - this.calcPlnkrLink(width); + if (this.mode !== 'downloadOnly') { + this.calcPlnkrLink(width); + } } toggleEmbedded () { this.showEmbedded = !this.showEmbedded; }