Commit 684a5cf5 authored by Nousheen Begum's avatar Nousheen Begum

Angular Assignment

parents
File added
<div class="header">
<i class='fab fa-asymmetrik' style='font-size:100px;color:white;float:left'></i>
<h1>Welcome to Adventure Land</h1>
<h3>Discover the magic of FUN!!</h3></div>
<app-comp1></app-comp1>
\ No newline at end of file
import { TestBed } from '@angular/core/testing';
import { AppComponent } from './app.component';
describe('AppComponent', () => {
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [
AppComponent
],
}).compileComponents();
});
it('should create the app', () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app).toBeTruthy();
});
it(`should have as title 'first-angularjs'`, () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app.title).toEqual('first-angularjs');
});
it('should render title', () => {
const fixture = TestBed.createComponent(AppComponent);
fixture.detectChanges();
const compiled = fixture.nativeElement;
expect(compiled.querySelector('.content span').textContent).toContain('first-angularjs app is running!');
});
});
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'first-angularjs';
}
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import { Comp1Component } from './comp1/comp1.component';
@NgModule({
declarations: [
AppComponent,
Comp1Component
],
imports: [
BrowserModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
<div class="dropdown">
<button class="dropbtn"><i class='fab fa-asymmetrik' style="font-size: 40px;"></i>Things You Can Find Here..</button>
<div class="dropdown-content">
<a href="#">Water Rides</a>
<a href="#">Land Rides</a>
<a href="#">High Thrill Rides</a>
<a href="#">Kids Rides</a>
</div>
</div>
\ No newline at end of file
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { Comp1Component } from './comp1.component';
describe('Comp1Component', () => {
let component: Comp1Component;
let fixture: ComponentFixture<Comp1Component>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ Comp1Component ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(Comp1Component);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit } from '@angular/core';
@Component({
selector: 'app-comp1',
templateUrl: './comp1.component.html',
styleUrls: ['./comp1.component.css']
})
export class Comp1Component implements OnInit {
constructor() { }
ngOnInit(): void {
}
}
export const environment = {
production: true
};
// This file can be replaced during build by using the `fileReplacements` array.
// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.
// The list of file replacements can be found in `angular.json`.
export const environment = {
production: false
};
/*
* For easier debugging in development mode, you can import the following file
* to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.
*
* This import should be commented out in production mode because it will have a negative impact
* on performance if an error is thrown.
*/
// import 'zone.js/dist/zone-error'; // Included with Angular CLI.
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>FirstAngularjs</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
<script src='https://kit.fontawesome.com/a076d05399.js'></script>
</head>
<body>
<app-root></app-root>
</body>
</html>
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
if (environment.production) {
enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
.catch(err => console.error(err));
/**
* This file includes polyfills needed by Angular and is loaded before the app.
* You can add your own extra polyfills to this file.
*
* This file is divided into 2 sections:
* 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
* 2. Application imports. Files imported after ZoneJS that should be loaded before your main
* file.
*
* The current setup is for so-called "evergreen" browsers; the last versions of browsers that
* automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera),
* Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile.
*
* Learn more in https://angular.io/guide/browser-support
*/
/***************************************************************************************************
* BROWSER POLYFILLS
*/
/** IE11 requires the following for NgClass support on SVG elements */
// import 'classlist.js'; // Run `npm install --save classlist.js`.
/**
* Web Animations `@angular/platform-browser/animations`
* Only required if AnimationBuilder is used within the application and using IE/Edge or Safari.
* Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0).
*/
// import 'web-animations-js'; // Run `npm install --save web-animations-js`.
/**
* By default, zone.js will patch all possible macroTask and DomEvents
* user can disable parts of macroTask/DomEvents patch by setting following flags
* because those flags need to be set before `zone.js` being loaded, and webpack
* will put import in the top of bundle, so user need to create a separate file
* in this directory (for example: zone-flags.ts), and put the following flags
* into that file, and then add the following code before importing zone.js.
* import './zone-flags';
*
* The flags allowed in zone-flags.ts are listed here.
*
* The following flags will work for all browsers.
*
* (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
* (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick
* (window as any).__zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
*
* in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
* with the following flag, it will bypass `zone.js` patch for IE/Edge
*
* (window as any).__Zone_enable_cross_context_check = true;
*
*/
/***************************************************************************************************
* Zone JS is required by default for Angular itself.
*/
import 'zone.js/dist/zone'; // Included with Angular CLI.
/***************************************************************************************************
* APPLICATION IMPORTS
*/
/* You can add global styles to this file, and also import other style files */
body{
background-image: url("C:\Sprint6\AngularJS\first-angularjs\src\assets\background.jpg");
background-size: 100% 100%;
background-position: center center;
background-repeat: no-repeat;
background-attachment: fixed;
}
.header h1{
text-align: right;
font-size: 58px;
font-style: italic;
color:white;
animation-name: head;
animation-duration: 10s;
}
@keyframes head {
0% {color:white;}
25% {color:orange;}
50% {color:mistyrose; }
75% {color:lime;}
100% {color:white;}
}
.header h3{
text-align: right;
font-size: 40px;
font-style: italic;
color:white;
transition: font-size 2s;
}
.header h3:hover{
font-size: 50px;
}
.body {
float: right;
background-color: mistyrose;
width: 300px;
height: 60px;
text-align: center;
}
.body h4{
font-size: 20px;
}
.dropdown {
position: relative;
display: inline-block;
float: right;
}
.dropbtn {
background-color: mistyrose;
padding: 16px;
font-size: 16px;
font-weight: bold;
cursor: pointer;
}
.dropdown-content {
display: none;
position: absolute;
background-color: #f9f9f9;
min-width: 160px;
box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
z-index: 1;
}
.dropdown-content a {
color: black;
padding: 12px 16px;
text-decoration: none;
display: block;
}
.dropdown-content a:hover {background-color:teal;color:white}
.dropdown:hover .dropdown-content {
display: block;
}
.dropdown:hover .dropbtn {
background-color:teal;
color:white;
font-size: 20px;
}
// This file is required by karma.conf.js and loads recursively all the .spec and framework files
import 'zone.js/dist/zone-testing';
import { getTestBed } from '@angular/core/testing';
import {
BrowserDynamicTestingModule,
platformBrowserDynamicTesting
} from '@angular/platform-browser-dynamic/testing';
declare const require: {
context(path: string, deep?: boolean, filter?: RegExp): {
keys(): string[];
<T>(id: string): T;
};
};
// First, initialize the Angular testing environment.
getTestBed().initTestEnvironment(
BrowserDynamicTestingModule,
platformBrowserDynamicTesting()
);
// Then we find all the tests.
const context = require.context('./', true, /\.spec\.ts$/);
// And load the modules.
context.keys().map(context);
File added
.string{
font-size: 30px;
font-style: italic;
font-weight: bold;
border :8px dashed black
}
.property img{
float:right;
}
.property p{
font-size: 30px;
font-style: italic;
font-weight: bold;
}
button{
font-size: 30px;
border:4px solid black;
margin-right: 15px;
}
button:hover{
background-color: red;
color:white
}
button:active{
background-color: green;
color: white;
}
h3{
font-size: 25px;
color:white;
background-color: rgb(83, 20, 20);
padding: 20px;
}
p{
font-size: 20px;
}
\ No newline at end of file
<h1 style="border: 6px solid black;font-size:50px;color:red;">Let's work on some data binding concepts.....</h1>
<h1 style="color:white;background-color:red;border: 2px solid black;">Hiii,I'm a specified template and styles are applied to me using Inline style sheets</h1>
<div class="string">
{{name}};
</div>
<div class="property">
<img [src]="image" >
<p>{{name1}}</p>
</div>
<h2 style="font-size:30px"> Event Binding Example</h2>
<button (click)="onClick()" (mouseover)='onMouseOver()'>Event Binding</button> <!--Event Binding-->
<button (click)="onButtonClicked()">Change Name</button>
<h2 style="font-size:30px">Two-way Binding Example</h2>
<input [(ngModel)]="name2" /> <br/><br/>
<p> {{name2}} </p>
<h1 style="border: 6px solid black;font-size:50px;color:red;">Let's work on component communication.....</h1>
<h3>Parent To Child :<p><app-comp1 [childMessage]="parentMessage"></app-comp1></p></h3>
<h3>Child to Parent :<p>Message: {{ message1 }}<app-comp1></app-comp1></p></h3>
<h3>Child to Parent :<p>Message: {{message2}}<app-comp2 (messageEvent)="receiveMessage($event)"></app-comp2></p></h3>
\ No newline at end of file
import { TestBed } from '@angular/core/testing';
import { AppComponent } from './app.component';
describe('AppComponent', () => {
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [
AppComponent
],
}).compileComponents();
});
it('should create the app', () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app).toBeTruthy();
});
it(`should have as title 'second-angularjs'`, () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app.title).toEqual('second-angularjs');
});
it('should render title', () => {
const fixture = TestBed.createComponent(AppComponent);
fixture.detectChanges();
const compiled = fixture.nativeElement;
expect(compiled.querySelector('.content span').textContent).toContain('second-angularjs app is running!');
});
});
import { Component,ViewChild,AfterViewInit } from '@angular/core';
import { Comp1Component} from "./comp1/comp1.component";
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
/* styles: [`
h1 {
border: 6px solid black;
font-size:50px;
color:red;
}
`]*/
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'second-angularjs';
name="Hii,I'm a string interpolation"
image="https://th.bing.com/th/id/OIP.7qISUYZ8rM9inWDkOSEW5AFNC7?w=305&h=180&c=7&o=5&pid=1.7"
name1="Helloooo,This image is an example of property binding --------------------------------"
name2= "Enter the text";
constructor(){}
onClick(){
alert("Button is binded using event binding!");
}
onMouseOver(){
console.log("Button hovered using event binding")
}
onButtonClicked() {
this.name = 'Text changed using event binding'
}
parentMessage = "Parent is sending message to child via Input decorator "
@ViewChild(Comp1Component) child:any;
message1:any;
ngAfterViewInit() {
this.message1 = this.child.message1
}
message2:any;
receiveMessage($event: any) {
this.message2 = $event
}
}
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import {FormsModule} from '@angular/forms';
import { AppComponent } from './app.component';
import { Comp1Component } from './comp1/comp1.component';
import { Comp2Component } from './comp2/comp2.component';
@NgModule({
declarations: [
AppComponent,
Comp1Component,
Comp2Component
],
imports: [
BrowserModule,
FormsModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
Say {{ childMessage }}
\ No newline at end of file
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { Comp1Component } from './comp1.component';
describe('Comp1Component', () => {
let component: Comp1Component;
let fixture: ComponentFixture<Comp1Component>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ Comp1Component ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(Comp1Component);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit ,Input} from '@angular/core';
@Component({
selector: 'app-comp1',
templateUrl: './comp1.component.html',
//template:'Say {{ childMessage }} <button (click)="sendMessage()">Send Message</button>',
styleUrls: ['./comp1.component.css']
})
export class Comp1Component implements OnInit {
@Input() childMessage:any;
message1 = 'Child is sending message to parent via ViewChild ';
constructor() { }
ngOnInit(): void {
}
}
<button (click)="sendMessage()">Send Message</button>
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { Comp2Component } from './comp2.component';
describe('Comp2Component', () => {
let component: Comp2Component;
let fixture: ComponentFixture<Comp2Component>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ Comp2Component ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(Comp2Component);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit,Output,EventEmitter } from '@angular/core';
@Component({
selector: 'app-comp2',
templateUrl: './comp2.component.html',
styleUrls: ['./comp2.component.css']
})
export class Comp2Component implements OnInit {
message2: string = "Child is sending message to parent via Output() and EventEmitter!"
@Output() messageEvent = new EventEmitter<string>();
sendMessage() {
this.messageEvent.emit(this.message2)
}
constructor() { }
ngOnInit(): void {
}
}
export const environment = {
production: true
};
// This file can be replaced during build by using the `fileReplacements` array.
// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.
// The list of file replacements can be found in `angular.json`.
export const environment = {
production: false
};
/*
* For easier debugging in development mode, you can import the following file
* to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.
*
* This import should be commented out in production mode because it will have a negative impact
* on performance if an error is thrown.
*/
// import 'zone.js/dist/zone-error'; // Included with Angular CLI.
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>SecondAngularjs</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
</head>
<body>
<app-root></app-root>
</body>
</html>
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
if (environment.production) {
enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
.catch(err => console.error(err));
/**
* This file includes polyfills needed by Angular and is loaded before the app.
* You can add your own extra polyfills to this file.
*
* This file is divided into 2 sections:
* 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
* 2. Application imports. Files imported after ZoneJS that should be loaded before your main
* file.
*
* The current setup is for so-called "evergreen" browsers; the last versions of browsers that
* automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera),
* Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile.
*
* Learn more in https://angular.io/guide/browser-support
*/
/***************************************************************************************************
* BROWSER POLYFILLS
*/
/** IE11 requires the following for NgClass support on SVG elements */
// import 'classlist.js'; // Run `npm install --save classlist.js`.
/**
* Web Animations `@angular/platform-browser/animations`
* Only required if AnimationBuilder is used within the application and using IE/Edge or Safari.
* Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0).
*/
// import 'web-animations-js'; // Run `npm install --save web-animations-js`.
/**
* By default, zone.js will patch all possible macroTask and DomEvents
* user can disable parts of macroTask/DomEvents patch by setting following flags
* because those flags need to be set before `zone.js` being loaded, and webpack
* will put import in the top of bundle, so user need to create a separate file
* in this directory (for example: zone-flags.ts), and put the following flags
* into that file, and then add the following code before importing zone.js.
* import './zone-flags';
*
* The flags allowed in zone-flags.ts are listed here.
*
* The following flags will work for all browsers.
*
* (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
* (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick
* (window as any).__zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
*
* in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
* with the following flag, it will bypass `zone.js` patch for IE/Edge
*
* (window as any).__Zone_enable_cross_context_check = true;
*
*/
/***************************************************************************************************
* Zone JS is required by default for Angular itself.
*/
import 'zone.js/dist/zone'; // Included with Angular CLI.
/***************************************************************************************************
* APPLICATION IMPORTS
*/
/* You can add global styles to this file, and also import other style files */
// This file is required by karma.conf.js and loads recursively all the .spec and framework files
import 'zone.js/dist/zone-testing';
import { getTestBed } from '@angular/core/testing';
import {
BrowserDynamicTestingModule,
platformBrowserDynamicTesting
} from '@angular/platform-browser-dynamic/testing';
declare const require: {
context(path: string, deep?: boolean, filter?: RegExp): {
keys(): string[];
<T>(id: string): T;
};
};
// First, initialize the Angular testing environment.
getTestBed().initTestEnvironment(
BrowserDynamicTestingModule,
platformBrowserDynamicTesting()
);
// Then we find all the tests.
const context = require.context('./', true, /\.spec\.ts$/);
// And load the modules.
context.keys().map(context);
File added
h1 {
font-size: 30px;
border: 5px solid black;
color:red;
}
h5{
font-size: 30px;
color:red;
}
.color:hover { color: red; }
.size { font-size: 20px; }
\ No newline at end of file
<h1>Let's work on some View Encapsulation</h1>
<h5>Heyyyyyy.......Encapsulation</h5>
<app-view1></app-view1>
<h1>Let's work on some Angular Directives</h1>
<button (click)="component()">Component Directives</button>
<button (click)="structural()">Structural Directives</button>
<button (click)="attribute()">Attribute Directives</button>
<h3>Example of Structural Directives</h3>
<ul>
<li><h4>*Ng-if <input type="checkbox" [(ngModel)]="showMe" /></h4></li>
<p *ngIf="showMe">
Helloooo...condition is satisfied,NG-IF has reached :)
</p>
<p *ngIf="!showMe">
Helloooo...condition is not satisfied,NG-IF cannot reach :(
</p>
<li><h4>*Ng-Switch : <input type='text' [(ngModel)]="num" /></h4></li>
<div [ngSwitch]="num">
<div *ngSwitchCase="'1'">Switched to One</div>
<div *ngSwitchCase="'2'">Switched to Two</div>
<div *ngSwitchCase="'3'">Switched to Three</div>
<div *ngSwitchCase="'4'">Switched to Four</div>
<div *ngSwitchCase="'5'">Switched to Five</div>
<div *ngSwitchDefault>This is Default</div>
</div>
<li><h4>*Ng-For :</h4></li>
<div *ngFor="let item of items">
<p > {{item}} </p>
</div>
</ul>
<h3>Example of Attribute Directives</h3>
<ul>
<li><h4>Ng-Class :</h4></li>
<div [ngClass]="'color size'">Helloooo........I'm Ng-Class from attribute directive used to add/remove css classes</div>
<li><h4>Ng-Style :</h4></li>
<p [ngStyle]="{'color': 'purple',
'font-size': '24px',
'font-weight': 'bold',
'font-style':'italic'}">Helloooo........I'm Ng-Style from attribute directive used to apply styles</p>
</ul>
<h1>Let's work on some Pipes</h1>
<button (click)="pipe()">Pipes</button>
<p>Unformatted text:{{msg}} </p>
<p> Unformatted number:{{num1}}</p>
<p>Unformatted Percentage:{{per}} </p>
<p>Unformatted currency:{{cur}} </p>
<h3>Example of different built-in Pipes</h3>
<ul>
<li><h4>Lowercasepipe</h4></li>
<p>{{msg | lowercase}} </p>
<li><h4>Uppercasepipe</h4></li>
<p>{{msg | uppercase}} </p>
<li><h4>Datepipe</h4></li>
<p>{{toDate | date}} </p> <!--date='medium,short,long,mediumtime,longDate'... can be written to get different types of dates -->
<li><h4>Currencypipe</h4></li>
<p>Example 1 :{{cur | currency }} </p>
<p>Example 2 :{{cur | currency:'INR':true:'5.5'}} </p>
<li><h4>Jsonpipe</h4></li>
<p>{{myObject | json}}</p>
<li><h4> Percentpipe</h4></li>
<p>Example 1 :{{per | percent }} </p>
<p>Example 2 :{{per | percent:'1.8'}} </p>
<li><h4>Decimalpipe</h4></li>
<p> Example 1 :{{num1 | number}}</p>
<p> Example 2 :{{num1 | number:'9.4'}}</p>
<li><h4>SlicePipe:</h4></li>
<p>{{msg | slice:1:10}} </p>
</ul>
<h3>Example of custom Pipes</h3>
<ul>
<li><h4>Square root Pipe:</h4></li>
<p>{{num2 | sqrt}}</p>
<li><h4>Square Pipe:</h4></li>
<p>{{num2 | square}}</p>
</ul>
<h1>Let's Know about Services and Dependency Injection</h1>
<button (click)="service()">Services</button>
<button (click)="di()">Dependency Injection</button>
\ No newline at end of file
import { TestBed } from '@angular/core/testing';
import { AppComponent } from './app.component';
describe('AppComponent', () => {
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [
AppComponent
],
}).compileComponents();
});
it('should create the app', () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app).toBeTruthy();
});
it(`should have as title 'third-angularjs'`, () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app.title).toEqual('third-angularjs');
});
it('should render title', () => {
const fixture = TestBed.createComponent(AppComponent);
fixture.detectChanges();
const compiled = fixture.nativeElement;
expect(compiled.querySelector('.content span').textContent).toContain('third-angularjs app is running!');
});
});
import { Component,ViewEncapsulation } from '@angular/core';
import { LoggingService } from './logging.service';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
encapsulation:ViewEncapsulation.Emulated
//encapsulation:ViewEncapsulation.ShadowDOM
//encapsulation:ViewEncapsulation.None
})
export class AppComponent {
title = 'third-angularjs';
showMe:any;
num:any;
items = ["Milk", "Apple", "Butter", "Bread"];
msg: string= 'Angular Pipes';
toDate: Date = new Date();
num1: number= 9542342.14554;
per: number= .34724;
cur: number= 543;
myObject = {
id: 1,
name: "Nousheen",
company: "nisum",
college: "MJCET"
};
num2:number=5;
component() {
alert("They are used in the main class and is declared by @Component. It contains the details on component processing, instantiated and usage at run time.")
}
structural(){
alert("They start with a * sign. These directives are used to manipulate and change the structure of the DOM elements. Example:*ngIf directive, *ngSwitch directive, and *ngFor directive")
}
attribute(){
alert("They are used to change the look and behavior of the DOM elements. Example: ngClass directive, and ngStyle directive etc")
}
pipe(){
alert("Pipes are used to transform data. It is denoted by symbol |")
}
constructor(private loggingService: LoggingService) {
this.loggingService.logSomeMessage("Hello...I'm AppComponent !")
}
service(){
alert("Angular services are singleton objects that get instantiated only once during the lifetime of an application.@Injectable() decorator accepts a metadata object for the service,that allows Angular to inject it into a component as a dependency.A provider is an object that tells an injector how to obtain or create a dependency. ")
}
di(){
alert(" It is used for injecting the service into a component, giving the component access to that service class.")
}
}
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { AppComponent } from './app.component';
import { SqrtPipe } from './sqrt.pipe';
import { SquarePipe } from './square.pipe';
import { View1Component } from './view1/view1.component';
@NgModule({
declarations: [
AppComponent,
SqrtPipe,
SquarePipe,
View1Component
],
imports: [
BrowserModule,
FormsModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
import { TestBed } from '@angular/core/testing';
import { LoggingService } from './logging.service';
describe('LoggingService', () => {
let service: LoggingService;
beforeEach(() => {
TestBed.configureTestingModule({});
service = TestBed.inject(LoggingService);
});
it('should be created', () => {
expect(service).toBeTruthy();
});
});
import { Injectable } from '@angular/core';
@Injectable({
providedIn: 'root',
})
export class LoggingService {
logSomeMessage(msg: any) {
alert("Message : " + msg);
}
}
import { SqrtPipe } from './sqrt.pipe';
describe('SqrtPipe', () => {
it('create an instance', () => {
const pipe = new SqrtPipe();
expect(pipe).toBeTruthy();
});
});
import { Pipe, PipeTransform } from '@angular/core';
@Pipe ({
name : 'sqrt'
})
export class SqrtPipe implements PipeTransform {
transform(val : number) : number {
return Math.sqrt(val);
}
}
\ No newline at end of file
import { SquarePipe } from './square.pipe';
describe('SquarePipe', () => {
it('create an instance', () => {
const pipe = new SquarePipe();
expect(pipe).toBeTruthy();
});
});
import { Pipe, PipeTransform } from '@angular/core';
@Pipe({
name: 'square'
})
export class SquarePipe implements PipeTransform {
transform(value: number): number {
return value * value;
}
}
<h5>Heyyyyyyy........Encapsulation!</h5>
<h6>Uncomment the lines in app.component.ts to view different encapsulations</h6>
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { View1Component } from './view1.component';
describe('View1Component', () => {
let component: View1Component;
let fixture: ComponentFixture<View1Component>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ View1Component ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(View1Component);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit,ViewEncapsulation } from '@angular/core';
@Component({
selector: 'app-view1',
templateUrl: './view1.component.html',
styleUrls: ['./view1.component.css'],
})
export class View1Component implements OnInit {
constructor() { }
ngOnInit(): void {
}
}
export const environment = {
production: true
};
// This file can be replaced during build by using the `fileReplacements` array.
// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.
// The list of file replacements can be found in `angular.json`.
export const environment = {
production: false
};
/*
* For easier debugging in development mode, you can import the following file
* to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.
*
* This import should be commented out in production mode because it will have a negative impact
* on performance if an error is thrown.
*/
// import 'zone.js/dist/zone-error'; // Included with Angular CLI.
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>ThirdAngularjs</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
</head>
<body>
<app-root></app-root>
</body>
</html>
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
if (environment.production) {
enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
.catch(err => console.error(err));
/**
* This file includes polyfills needed by Angular and is loaded before the app.
* You can add your own extra polyfills to this file.
*
* This file is divided into 2 sections:
* 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
* 2. Application imports. Files imported after ZoneJS that should be loaded before your main
* file.
*
* The current setup is for so-called "evergreen" browsers; the last versions of browsers that
* automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera),
* Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile.
*
* Learn more in https://angular.io/guide/browser-support
*/
/***************************************************************************************************
* BROWSER POLYFILLS
*/
/** IE11 requires the following for NgClass support on SVG elements */
// import 'classlist.js'; // Run `npm install --save classlist.js`.
/**
* Web Animations `@angular/platform-browser/animations`
* Only required if AnimationBuilder is used within the application and using IE/Edge or Safari.
* Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0).
*/
// import 'web-animations-js'; // Run `npm install --save web-animations-js`.
/**
* By default, zone.js will patch all possible macroTask and DomEvents
* user can disable parts of macroTask/DomEvents patch by setting following flags
* because those flags need to be set before `zone.js` being loaded, and webpack
* will put import in the top of bundle, so user need to create a separate file
* in this directory (for example: zone-flags.ts), and put the following flags
* into that file, and then add the following code before importing zone.js.
* import './zone-flags';
*
* The flags allowed in zone-flags.ts are listed here.
*
* The following flags will work for all browsers.
*
* (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
* (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick
* (window as any).__zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
*
* in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
* with the following flag, it will bypass `zone.js` patch for IE/Edge
*
* (window as any).__Zone_enable_cross_context_check = true;
*
*/
/***************************************************************************************************
* Zone JS is required by default for Angular itself.
*/
import 'zone.js/dist/zone'; // Included with Angular CLI.
/***************************************************************************************************
* APPLICATION IMPORTS
*/
/* You can add global styles to this file, and also import other style files */
html{
background-image: linear-gradient(rgba(255,255,255,0.75),rgba(255,255,255,0.75)), url("");
background-size: cover;
}
button{
font-size:20px;
color:white;
background-color: black;
margin-right: 5px;
}
button:hover{
color:white;
background-color: red;
}
button:active{
color:white;
background-color: green;
}
\ No newline at end of file
// This file is required by karma.conf.js and loads recursively all the .spec and framework files
import 'zone.js/dist/zone-testing';
import { getTestBed } from '@angular/core/testing';
import {
BrowserDynamicTestingModule,
platformBrowserDynamicTesting
} from '@angular/platform-browser-dynamic/testing';
declare const require: {
context(path: string, deep?: boolean, filter?: RegExp): {
keys(): string[];
<T>(id: string): T;
};
};
// First, initialize the Angular testing environment.
getTestBed().initTestEnvironment(
BrowserDynamicTestingModule,
platformBrowserDynamicTesting()
);
// Then we find all the tests.
const context = require.context('./', true, /\.spec\.ts$/);
// And load the modules.
context.keys().map(context);
File added
import { Component, NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import {LoginComponent }from './login/login.component';
import {RegisterComponent }from './register/register.component';
const routes: Routes = [
{path:'login',component:LoginComponent},
{path:'register',component:RegisterComponent}
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }
export const routingComponents=[LoginComponent,RegisterComponent]
html{
background-image: linear-gradient(rgba(255,255,255,0.75),rgba(255,255,255,0.75)), url("https://th.bing.com/th/id/OIP.vzAZLfoj6SJem3J09RD8twHaEK?w=279&h=180&c=7&o=5&pid=1.7");
background-size: cover;
}
<section id="home">
<div class="section-inner">
<h1>Welcome to Medicover Hospital </h1>
<img src="" class="profile-img">
<br>
<button routerLink="/login" routerLinkActive="active">Login</button>
<button routerLink="/register" routerLinkActive="active">Register</button>
<router-outlet></router-outlet>
</div>
</section>
import { TestBed } from '@angular/core/testing';
import { RouterTestingModule } from '@angular/router/testing';
import { AppComponent } from './app.component';
describe('AppComponent', () => {
beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [
RouterTestingModule
],
declarations: [
AppComponent
],
}).compileComponents();
});
it('should create the app', () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app).toBeTruthy();
});
it(`should have as title 'fourth-angularjs'`, () => {
const fixture = TestBed.createComponent(AppComponent);
const app = fixture.componentInstance;
expect(app.title).toEqual('fourth-angularjs');
});
it('should render title', () => {
const fixture = TestBed.createComponent(AppComponent);
fixture.detectChanges();
const compiled = fixture.nativeElement;
expect(compiled.querySelector('.content span').textContent).toContain('fourth-angularjs app is running!');
});
});
import { Component } from '@angular/core';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'fourth-angularjs';
}
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { FormsModule } from '@angular/forms';
import { ReactiveFormsModule } from '@angular/forms';
import { AppRoutingModule,routingComponents } from './app-routing.module';
import { AppComponent } from './app.component';
@NgModule({
declarations: [
AppComponent,
routingComponents
],
imports: [
BrowserModule,
FormsModule,
ReactiveFormsModule,
AppRoutingModule
],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule { }
input.ng-invalid.ng-touched{
border-color: red;
}
\ No newline at end of file
<!-- Reactive Form -->
<h3>Login Yourself.... </h3>
<form [formGroup]="form" (ngSubmit)="submitForm()">
<p> <label>UserName :</label>
<input type="text" [formControlName]="'username'" placeholder="Enter your username"/>
</p>
<br>
<label>Password :</label>
<input type="password" [formControlName]="'password'" placeholder="Enter your password"/>
<input type = "submit" value = "Login" [disabled]="!form.valid">
</form>
\ No newline at end of file
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { LoginComponent } from './login.component';
describe('LoginComponent', () => {
let component: LoginComponent;
let fixture: ComponentFixture<LoginComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ LoginComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(LoginComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component, OnInit } from '@angular/core';
import { FormGroup, FormControl,FormBuilder, Validators } from '@angular/forms';
@Component({
selector: 'app-login',
templateUrl: './login.component.html',
styleUrls: ['./login.component.css']
})
export class LoginComponent implements OnInit {
form: FormGroup;
constructor(private readonly fb: FormBuilder) {
this.form = this.fb.group({
username: ['',Validators.required],
password: ['',Validators.required],
});
}
submitForm() {
console.log(this.form.getRawValue());
alert("You have logged in successfully")
}
ngOnInit(): void {
}
}
input[type='radio']{
width: 50px;
height: 18px;
align-items: left;
display: inline-block;
}
input[type='checkbox']
{
width: 50px;
height: 20px;
align-items: left;
display: inline-block;
}
<!-- Template driven form -->
<h3>Please register yourself here.....</h3>
<form #hospital = "ngForm" (ngSubmit) = "onSubmit(hospital)" >
<label>Name :</label>
<input type = "text" name = "patient_name" placeholder = "Enter full name" pattern="^[a-zA-Z]+$" required ngModel #patient_name="ngModel">
<span class="help-bpx" *ngIf="patient_name.touched && !patient_name.valid">Please enter the valid Name (Only Alphabets)</span>
<br/>
<label>Age :</label>
<input type = "text" name = "patient_age" placeholder = "Enter age" required ngModel #age="ngModel" >
<span class="help-bpx" *ngIf="age.touched ">Please enter the Age</span>
<br/>
<label >Email :</label>
<input type="email" name="email" placeholder = "Enter email" email required ngModel #email="ngModel">
<span class="help-bpx" *ngIf="email.touched && !email.valid">Please enter the valid Email</span>
<br>
<label>Phone Number :</label>
<input type = "tel" name = "mobile" placeholder = "Enter Phone Number" maxlength="10" required ngModel #tel="ngModel">
<span class="help-bpx" *ngIf="tel.touched && !tel.valid ">Please enter the valid Phone Number</span>
<br/>
<label >Gender :
<input type="radio" value="male" name="gender"> Male
<input type="radio" value="female" name="gender"> Female
<input type="radio" value="other" name="gender"> Other</label>
<br>
<label >Did you concern any doctor before??
<input type="checkbox" name="doctor" ngModel></label>
<br>
<label >Specialists :
<select name="Specialists" ngModel>
<option selected="" value=""></option>
<option [ngValue]="c.id" *ngFor="let c of specialistsList">
{{c.name}}
</option>
</select> </label>
<br>
<input type = "submit" value = "Register" [disabled]="!hospital.valid">
</form>
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { RegisterComponent } from './register.component';
describe('RegisterComponent', () => {
let component: RegisterComponent;
let fixture: ComponentFixture<RegisterComponent>;
beforeEach(async () => {
await TestBed.configureTestingModule({
declarations: [ RegisterComponent ]
})
.compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(RegisterComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});
it('should create', () => {
expect(component).toBeTruthy();
});
});
import { Component } from '@angular/core';
@Component({
selector: 'app-register',
templateUrl: './register.component.html',
styleUrls: ['./register.component.css']
})
export class RegisterComponent {
onSubmit(hospital:any) {
console.log(hospital.value);
alert("Patient is registered successfully");
}
specialistsList:Specialists[] = [
new Specialists("1", "Audiologist"),
new Specialists('2', 'Cardiologist'),
new Specialists('3', 'Dermatologist'),
new Specialists('4', 'Gynecologist'),
new Specialists('5', 'Neurologist'),
new Specialists('6', 'Orthopedic Surgeon')
];
}
export class Specialists {
id:string;
name:string;
constructor(id:string, name:string) {
this.id=id;
this.name=name;
}
}
export const environment = {
production: true
};
// This file can be replaced during build by using the `fileReplacements` array.
// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`.
// The list of file replacements can be found in `angular.json`.
export const environment = {
production: false
};
/*
* For easier debugging in development mode, you can import the following file
* to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`.
*
* This import should be commented out in production mode because it will have a negative impact
* on performance if an error is thrown.
*/
// import 'zone.js/dist/zone-error'; // Included with Angular CLI.
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>FourthAngularjs</title>
<base href="/">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="icon" type="image/x-icon" href="favicon.ico">
</head>
<body>
<app-root></app-root>
</body>
</html>
import { enableProdMode } from '@angular/core';
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app/app.module';
import { environment } from './environments/environment';
if (environment.production) {
enableProdMode();
}
platformBrowserDynamic().bootstrapModule(AppModule)
.catch(err => console.error(err));
/**
* This file includes polyfills needed by Angular and is loaded before the app.
* You can add your own extra polyfills to this file.
*
* This file is divided into 2 sections:
* 1. Browser polyfills. These are applied before loading ZoneJS and are sorted by browsers.
* 2. Application imports. Files imported after ZoneJS that should be loaded before your main
* file.
*
* The current setup is for so-called "evergreen" browsers; the last versions of browsers that
* automatically update themselves. This includes Safari >= 10, Chrome >= 55 (including Opera),
* Edge >= 13 on the desktop, and iOS 10 and Chrome on mobile.
*
* Learn more in https://angular.io/guide/browser-support
*/
/***************************************************************************************************
* BROWSER POLYFILLS
*/
/** IE11 requires the following for NgClass support on SVG elements */
// import 'classlist.js'; // Run `npm install --save classlist.js`.
/**
* Web Animations `@angular/platform-browser/animations`
* Only required if AnimationBuilder is used within the application and using IE/Edge or Safari.
* Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0).
*/
// import 'web-animations-js'; // Run `npm install --save web-animations-js`.
/**
* By default, zone.js will patch all possible macroTask and DomEvents
* user can disable parts of macroTask/DomEvents patch by setting following flags
* because those flags need to be set before `zone.js` being loaded, and webpack
* will put import in the top of bundle, so user need to create a separate file
* in this directory (for example: zone-flags.ts), and put the following flags
* into that file, and then add the following code before importing zone.js.
* import './zone-flags';
*
* The flags allowed in zone-flags.ts are listed here.
*
* The following flags will work for all browsers.
*
* (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame
* (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick
* (window as any).__zone_symbol__UNPATCHED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames
*
* in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js
* with the following flag, it will bypass `zone.js` patch for IE/Edge
*
* (window as any).__Zone_enable_cross_context_check = true;
*
*/
/***************************************************************************************************
* Zone JS is required by default for Angular itself.
*/
import 'zone.js/dist/zone'; // Included with Angular CLI.
/***************************************************************************************************
* APPLICATION IMPORTS
*/
/* You can add global styles to this file, and also import other style files */
section {
height: 300vh;
border: 1px solid black;
display: flex;
justify-content: center;
text-align: center;
background-size: cover;
background-position: center center;
background-repeat: no-repeat;
background-attachment: fixed;
}
#home .profile-img {
width: 300px;
border-radius: 50%;
}
#home {
background-image: linear-gradient(rgba(255,255,255,0.75),rgba(255,255,255,0.75)), url('https://th.bing.com/th/id/OIP.vzAZLfoj6SJem3J09RD8twHaEK?w=279&h=180&c=7&o=5&pid=1.7');
}
#home h1{
font-size: 70px;
font-family: Georgia, 'Times New Roman', Times, serif;
font-style: italic;
}
#home button{
margin:30px 10px 0 10px;
color:white;
background-color: black;
padding:10px;
font-size: 25px;
}
#home button:hover{
background-color: red;
}
#home .active{
background-color: green;
}
h3{
padding: 5px;
font-size: 35px;
}
form {
width: 80%;
margin:10px auto;
}
label,
input {
/* In order to define widths */
display: block;
}
label {
/* Positions the label text beside the input */
text-align: left;
font-size: 22px;
}
input{
height: 30px;
width:100%
}
input[type='submit']{
font-size: 22px;
height: 40px;
padding:5px;
margin-top: 2%;
color: white;
background-color: black;
}
input[type='submit']:hover{
background-color: red;
}
input[type='submit']:disabled{
background-color: royalblue;
}
input.ng-invalid.ng-touched{
border-color: red;
}
\ No newline at end of file
// This file is required by karma.conf.js and loads recursively all the .spec and framework files
import 'zone.js/dist/zone-testing';
import { getTestBed } from '@angular/core/testing';
import {
BrowserDynamicTestingModule,
platformBrowserDynamicTesting
} from '@angular/platform-browser-dynamic/testing';
declare const require: {
context(path: string, deep?: boolean, filter?: RegExp): {
keys(): string[];
<T>(id: string): T;
};
};
// First, initialize the Angular testing environment.
getTestBed().initTestEnvironment(
BrowserDynamicTestingModule,
platformBrowserDynamicTesting()
);
// Then we find all the tests.
const context = require.context('./', true, /\.spec\.ts$/);
// And load the modules.
context.keys().map(context);
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment