mirror of
https://github.com/ionic-team/ionic-framework.git
synced 2025-08-18 19:21:34 +08:00
feat(demo): post the form
This commit is contained in:
@ -12,6 +12,7 @@ To use _this_ application perform the following commands from this directory:
|
|||||||
- `npm start` - to serve the application
|
- `npm start` - to serve the application
|
||||||
- `npm test` - to run the unit tests
|
- `npm test` - to run the unit tests
|
||||||
- `npm run e2e` - to run the end to end tests
|
- `npm run e2e` - to run the end to end tests
|
||||||
|
- `npx ts-node server/server.ts` - run the server required by any page that does a test post
|
||||||
|
|
||||||
See the `package.json` file for a complete list of scripts. The above are just the most common.
|
See the `package.json` file for a complete list of scripts. The above are just the most common.
|
||||||
|
|
||||||
|
564
packages/demos/angular/package-lock.json
generated
564
packages/demos/angular/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -24,7 +24,9 @@
|
|||||||
"@angular/router": "latest",
|
"@angular/router": "latest",
|
||||||
"@ionic/angular": "next",
|
"@ionic/angular": "next",
|
||||||
"@ionic/core": "next",
|
"@ionic/core": "next",
|
||||||
|
"body-parser": "^1.18.2",
|
||||||
"core-js": "^2.4.1",
|
"core-js": "^2.4.1",
|
||||||
|
"express": "^4.16.2",
|
||||||
"rxjs": "^5.5.2",
|
"rxjs": "^5.5.2",
|
||||||
"zone.js": "^0.8.14"
|
"zone.js": "^0.8.14"
|
||||||
},
|
},
|
||||||
@ -46,7 +48,7 @@
|
|||||||
"karma-jasmine": "~1.1.0",
|
"karma-jasmine": "~1.1.0",
|
||||||
"karma-jasmine-html-reporter": "^0.2.2",
|
"karma-jasmine-html-reporter": "^0.2.2",
|
||||||
"protractor": "~5.1.2",
|
"protractor": "~5.1.2",
|
||||||
"ts-node": "~3.2.0",
|
"ts-node": "^3.2.2",
|
||||||
"tslint": "~5.7.0",
|
"tslint": "~5.7.0",
|
||||||
"typescript": "^2.5.2"
|
"typescript": "^2.5.2"
|
||||||
}
|
}
|
||||||
|
25
packages/demos/angular/server/server.ts
Normal file
25
packages/demos/angular/server/server.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import * as bodyParser from 'body-parser';
|
||||||
|
import * as express from 'express';
|
||||||
|
|
||||||
|
const app = express();
|
||||||
|
|
||||||
|
app.set('port', process.env.PORT || 5000);
|
||||||
|
|
||||||
|
app.use(bodyParser.urlencoded({extended: true}));
|
||||||
|
app.use(bodyParser.json());
|
||||||
|
|
||||||
|
app.use(function(req, res, next) {
|
||||||
|
res.header('Access-Control-Allow-Origin', '*');
|
||||||
|
res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE');
|
||||||
|
res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization');
|
||||||
|
|
||||||
|
next();
|
||||||
|
});
|
||||||
|
|
||||||
|
app.post('/test', (req, res) => {
|
||||||
|
res.send(req.body);
|
||||||
|
});
|
||||||
|
|
||||||
|
app.listen(app.get('port'), () => {
|
||||||
|
console.log('Node app is running on port', app.get('port'));
|
||||||
|
});
|
@ -1,8 +1,10 @@
|
|||||||
import { BrowserModule } from '@angular/platform-browser';
|
import { BrowserModule } from '@angular/platform-browser';
|
||||||
import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';
|
import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';
|
||||||
|
import { HttpClientModule } from '@angular/common/http';
|
||||||
|
|
||||||
import { AppComponent } from './app.component';
|
import { AppComponent } from './app.component';
|
||||||
import { AppRoutingModule } from './app-routing.module';
|
import { AppRoutingModule } from './app-routing.module';
|
||||||
|
import { PostTestService } from './post-test/post-test.service';
|
||||||
|
|
||||||
import { IonicAngularModule, IonicRouterModule } from '@ionic/angular';
|
import { IonicAngularModule, IonicRouterModule } from '@ionic/angular';
|
||||||
|
|
||||||
@ -11,10 +13,12 @@ import { IonicAngularModule, IonicRouterModule } from '@ionic/angular';
|
|||||||
imports: [
|
imports: [
|
||||||
AppRoutingModule,
|
AppRoutingModule,
|
||||||
BrowserModule,
|
BrowserModule,
|
||||||
|
HttpClientModule,
|
||||||
IonicAngularModule.forRoot(),
|
IonicAngularModule.forRoot(),
|
||||||
IonicRouterModule.forRoot()
|
IonicRouterModule.forRoot()
|
||||||
],
|
],
|
||||||
bootstrap: [AppComponent],
|
bootstrap: [AppComponent],
|
||||||
schemas: [CUSTOM_ELEMENTS_SCHEMA]
|
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
||||||
|
providers: [PostTestService]
|
||||||
})
|
})
|
||||||
export class AppModule { }
|
export class AppModule { }
|
||||||
|
@ -82,7 +82,7 @@
|
|||||||
</ion-list>
|
</ion-list>
|
||||||
</ion-content>
|
</ion-content>
|
||||||
<ion-footer>
|
<ion-footer>
|
||||||
<ion-button expand="block" [disabled]="myForm.invalid" (click)="save()">
|
<ion-button expand="block" [disabled]="myForm.invalid" (click)="save(myForm.value)">
|
||||||
<ion-icon name="save" slot="start"></ion-icon>Looks Good to Me</ion-button>
|
<ion-icon name="save" slot="start"></ion-icon>Looks Good to Me</ion-button>
|
||||||
</ion-footer>
|
</ion-footer>
|
||||||
</ion-page>
|
</ion-page>
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import { Component, OnInit } from '@angular/core';
|
import { Component, OnInit } from '@angular/core';
|
||||||
import { Router } from '@angular/router';
|
import { Router } from '@angular/router';
|
||||||
import { HomePageComponent } from '../home-page/home-page.component';
|
import { PostTestService } from '../post-test/post-test.service';
|
||||||
import { HomePage } from '../../../e2e/home.po';
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-form-sample-page',
|
selector: 'app-form-sample-page',
|
||||||
@ -22,24 +21,12 @@ export class FormSamplePageComponent implements OnInit {
|
|||||||
desiredSalary: number;
|
desiredSalary: number;
|
||||||
levelOfHappy: number;
|
levelOfHappy: number;
|
||||||
|
|
||||||
constructor(private router: Router) { }
|
constructor(private postman: PostTestService, private router: Router) { }
|
||||||
|
|
||||||
ngOnInit() { }
|
ngOnInit() { }
|
||||||
|
|
||||||
save() {
|
save(data: any) {
|
||||||
const data = {
|
this.postman.post(data).subscribe(res => console.log(res));
|
||||||
firstName: this.firstName,
|
|
||||||
lastName: this.lastName,
|
|
||||||
title: this.jobTitle,
|
|
||||||
beer: this.drinkBeers,
|
|
||||||
tea: this.drinkTeas,
|
|
||||||
coffee: this.makeCoffee,
|
|
||||||
feed: this.feedEngineers,
|
|
||||||
description: this.selfDescription,
|
|
||||||
salary: this.desiredSalary,
|
|
||||||
happy: this.levelOfHappy
|
|
||||||
};
|
|
||||||
console.log('I would submit: ', data);
|
|
||||||
this.router.navigate(['home']);
|
this.router.navigate(['home']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,15 @@
|
|||||||
|
import { TestBed, inject } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { PostTestService } from './post-test.service';
|
||||||
|
|
||||||
|
describe('PostTestService', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
providers: [PostTestService]
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should be created', inject([PostTestService], (service: PostTestService) => {
|
||||||
|
expect(service).toBeTruthy();
|
||||||
|
}));
|
||||||
|
});
|
@ -0,0 +1,12 @@
|
|||||||
|
import { Injectable } from '@angular/core';
|
||||||
|
import { HttpClient } from '@angular/common/http';
|
||||||
|
import { Observable } from 'rxjs/Observable';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class PostTestService {
|
||||||
|
constructor(private http: HttpClient) { }
|
||||||
|
|
||||||
|
post(data: any): Observable<any> {
|
||||||
|
return this.http.post('http://localhost:5000/test', data);
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user