init
This commit is contained in:
parent
6549edb533
commit
6214eb2085
@ -23,6 +23,7 @@
|
|||||||
"src/assets"
|
"src/assets"
|
||||||
],
|
],
|
||||||
"styles": [
|
"styles": [
|
||||||
|
"./node_modules/@angular/material/prebuilt-themes/indigo-pink.css",
|
||||||
"src/styles.css"
|
"src/styles.css"
|
||||||
],
|
],
|
||||||
"scripts": [],
|
"scripts": [],
|
||||||
@ -80,6 +81,7 @@
|
|||||||
"tsConfig": "src/tsconfig.spec.json",
|
"tsConfig": "src/tsconfig.spec.json",
|
||||||
"karmaConfig": "src/karma.conf.js",
|
"karmaConfig": "src/karma.conf.js",
|
||||||
"styles": [
|
"styles": [
|
||||||
|
"./node_modules/@angular/material/prebuilt-themes/indigo-pink.css",
|
||||||
"src/styles.css"
|
"src/styles.css"
|
||||||
],
|
],
|
||||||
"scripts": [],
|
"scripts": [],
|
||||||
|
33
package-lock.json
generated
33
package-lock.json
generated
@ -129,6 +129,23 @@
|
|||||||
"tslib": "1.10.0"
|
"tslib": "1.10.0"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"@angular/cdk": {
|
||||||
|
"version": "7.3.7",
|
||||||
|
"resolved": "https://registry.npmjs.org/@angular/cdk/-/cdk-7.3.7.tgz",
|
||||||
|
"integrity": "sha512-xbXxhHHKGkVuW6K7pzPmvpJXIwpl0ykBnvA2g+/7Sgy5Pd35wCC+UtHD9RYczDM/mkygNxMQtagyCErwFnDtQA==",
|
||||||
|
"requires": {
|
||||||
|
"parse5": "5.1.1",
|
||||||
|
"tslib": "1.10.0"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"parse5": {
|
||||||
|
"version": "5.1.1",
|
||||||
|
"resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.1.tgz",
|
||||||
|
"integrity": "sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug==",
|
||||||
|
"optional": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
"@angular/cli": {
|
"@angular/cli": {
|
||||||
"version": "7.3.9",
|
"version": "7.3.9",
|
||||||
"resolved": "https://registry.npmjs.org/@angular/cli/-/cli-7.3.9.tgz",
|
"resolved": "https://registry.npmjs.org/@angular/cli/-/cli-7.3.9.tgz",
|
||||||
@ -482,6 +499,14 @@
|
|||||||
"integrity": "sha512-a/Bqf19+YhqACxQOkpYB0HK/zjHqDrZVUyBtdiX17njuvlWgD4wvdtdxae//ZeIVHNDJS+G5Gelbe+Yzon+VGA==",
|
"integrity": "sha512-a/Bqf19+YhqACxQOkpYB0HK/zjHqDrZVUyBtdiX17njuvlWgD4wvdtdxae//ZeIVHNDJS+G5Gelbe+Yzon+VGA==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"@angular/material": {
|
||||||
|
"version": "7.3.7",
|
||||||
|
"resolved": "https://registry.npmjs.org/@angular/material/-/material-7.3.7.tgz",
|
||||||
|
"integrity": "sha512-Eq+7frkeNGkLOfEtmkmJgR+AgoWajOipXZWWfCSamNfpCcPof82DwvGOpAmgGni9FuN2XFQdqP5MoaffQzIvUA==",
|
||||||
|
"requires": {
|
||||||
|
"tslib": "1.10.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"@angular/platform-browser": {
|
"@angular/platform-browser": {
|
||||||
"version": "7.2.16",
|
"version": "7.2.16",
|
||||||
"resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-7.2.16.tgz",
|
"resolved": "https://registry.npmjs.org/@angular/platform-browser/-/platform-browser-7.2.16.tgz",
|
||||||
@ -6545,6 +6570,14 @@
|
|||||||
"integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==",
|
"integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==",
|
||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
|
"ng-animate": {
|
||||||
|
"version": "0.3.4",
|
||||||
|
"resolved": "https://registry.npmjs.org/ng-animate/-/ng-animate-0.3.4.tgz",
|
||||||
|
"integrity": "sha512-akMSySNAAe4H7f+XhjDvRnxa1eg+6zvl0DwVFXYpFDiGClPGlC93hT1+EXq0z9rq2U8IpBFh2FkSUT/FRIeROw==",
|
||||||
|
"requires": {
|
||||||
|
"tslib": "1.10.0"
|
||||||
|
}
|
||||||
|
},
|
||||||
"nice-try": {
|
"nice-try": {
|
||||||
"version": "1.0.5",
|
"version": "1.0.5",
|
||||||
"resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
|
"resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
|
||||||
|
@ -12,14 +12,17 @@
|
|||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@angular/animations": "~7.2.0",
|
"@angular/animations": "~7.2.0",
|
||||||
|
"@angular/cdk": "~7.3.7",
|
||||||
"@angular/common": "~7.2.0",
|
"@angular/common": "~7.2.0",
|
||||||
"@angular/compiler": "~7.2.0",
|
"@angular/compiler": "~7.2.0",
|
||||||
"@angular/core": "~7.2.0",
|
"@angular/core": "~7.2.0",
|
||||||
"@angular/forms": "~7.2.0",
|
"@angular/forms": "~7.2.0",
|
||||||
|
"@angular/material": "^7.3.7",
|
||||||
"@angular/platform-browser": "~7.2.0",
|
"@angular/platform-browser": "~7.2.0",
|
||||||
"@angular/platform-browser-dynamic": "~7.2.0",
|
"@angular/platform-browser-dynamic": "~7.2.0",
|
||||||
"@angular/router": "~7.2.0",
|
"@angular/router": "~7.2.0",
|
||||||
"core-js": "^2.5.4",
|
"core-js": "^2.5.4",
|
||||||
|
"ng-animate": "^0.3.4",
|
||||||
"rxjs": "~6.3.3",
|
"rxjs": "~6.3.3",
|
||||||
"tslib": "^1.9.0",
|
"tslib": "^1.9.0",
|
||||||
"zone.js": "~0.8.26"
|
"zone.js": "~0.8.26"
|
||||||
|
@ -0,0 +1,16 @@
|
|||||||
|
.page{
|
||||||
|
width:90%;
|
||||||
|
max-width: 1200px;
|
||||||
|
margin:auto;
|
||||||
|
display:flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.bottom{
|
||||||
|
display:flex;
|
||||||
|
flex-direction: row;
|
||||||
|
}
|
||||||
|
.right{
|
||||||
|
width:20%;
|
||||||
|
min-width:300px;
|
||||||
|
}
|
||||||
|
.left{width:100%;}
|
@ -1,20 +1,18 @@
|
|||||||
<!--The content below is only a placeholder and can be replaced.-->
|
<section class="page">
|
||||||
<div style="text-align:center">
|
<section class="top">
|
||||||
<h1>
|
<header><h1>
|
||||||
Welcome to {{ title }}!
|
Anonimowy mikroblog
|
||||||
</h1>
|
</h1>
|
||||||
<img width="300" alt="Angular Logo" src="">
|
</header>
|
||||||
</div>
|
</section>
|
||||||
<h2>Here are some links to help you start: </h2>
|
<section class="bottom">
|
||||||
<ul>
|
<section class="left">
|
||||||
<li>
|
<router-outlet></router-outlet>
|
||||||
<h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
|
</section>
|
||||||
</li>
|
<section class="right">
|
||||||
<li>
|
<app-right-panel>
|
||||||
<h2><a target="_blank" rel="noopener" href="https://angular.io/cli">CLI Documentation</a></h2>
|
|
||||||
</li>
|
|
||||||
<li>
|
|
||||||
<h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
|
</app-right-panel>
|
||||||
|
</section>
|
||||||
|
</section>
|
||||||
|
</section>
|
||||||
|
@ -2,13 +2,50 @@ import { BrowserModule } from '@angular/platform-browser';
|
|||||||
import { NgModule } from '@angular/core';
|
import { NgModule } from '@angular/core';
|
||||||
|
|
||||||
import { AppComponent } from './app.component';
|
import { AppComponent } from './app.component';
|
||||||
|
import { MainPageComponent } from './main-page/main-page.component';
|
||||||
|
import { MainPagePostComponent } from './main-page-post/main-page-post.component';
|
||||||
|
import { SinglePostComponent } from './single-post/single-post.component';
|
||||||
|
import { CommentComponent } from './comment/comment.component';
|
||||||
|
import { MenuComponent } from './menu/menu.component';
|
||||||
|
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
|
||||||
|
import {RouterModule, Routes} from '@angular/router';
|
||||||
|
import {MatButtonModule, MatCardModule, MatFormFieldModule, MatInputModule, MatRippleModule} from '@angular/material';
|
||||||
|
import { RightPanelComponent } from './right-panel/right-panel.component';
|
||||||
|
import {FormsModule} from '@angular/forms';
|
||||||
|
import {HttpClientModule} from '@angular/common/http';
|
||||||
|
|
||||||
|
const appRoutes: Routes = [
|
||||||
|
{ path: '', component: MainPageComponent },
|
||||||
|
{path: 'post/:id', component: SinglePostComponent},
|
||||||
|
// { path: 'hero/:id', component: HeroDetailComponent },
|
||||||
|
|
||||||
|
// { path: '**', component: PageNotFoundComponent }
|
||||||
|
];
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
declarations: [
|
declarations: [
|
||||||
AppComponent
|
AppComponent,
|
||||||
|
MainPageComponent,
|
||||||
|
MainPagePostComponent,
|
||||||
|
SinglePostComponent,
|
||||||
|
CommentComponent,
|
||||||
|
MenuComponent,
|
||||||
|
RightPanelComponent
|
||||||
],
|
],
|
||||||
imports: [
|
imports: [
|
||||||
BrowserModule
|
RouterModule.forRoot(
|
||||||
|
appRoutes,
|
||||||
|
{enableTracing: true} // <-- debugging purposes only
|
||||||
|
),
|
||||||
|
BrowserModule,
|
||||||
|
BrowserAnimationsModule,
|
||||||
|
MatCardModule,
|
||||||
|
MatButtonModule,
|
||||||
|
MatRippleModule,
|
||||||
|
MatInputModule,
|
||||||
|
MatFormFieldModule,
|
||||||
|
FormsModule,
|
||||||
|
HttpClientModule,
|
||||||
],
|
],
|
||||||
providers: [],
|
providers: [],
|
||||||
bootstrap: [AppComponent]
|
bootstrap: [AppComponent]
|
||||||
|
0
src/app/comment/comment.component.css
Normal file
0
src/app/comment/comment.component.css
Normal file
3
src/app/comment/comment.component.html
Normal file
3
src/app/comment/comment.component.html
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<p>
|
||||||
|
comment works!
|
||||||
|
</p>
|
25
src/app/comment/comment.component.spec.ts
Normal file
25
src/app/comment/comment.component.spec.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { CommentComponent } from './comment.component';
|
||||||
|
|
||||||
|
describe('CommentComponent', () => {
|
||||||
|
let component: CommentComponent;
|
||||||
|
let fixture: ComponentFixture<CommentComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ CommentComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(CommentComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
15
src/app/comment/comment.component.ts
Normal file
15
src/app/comment/comment.component.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-comment',
|
||||||
|
templateUrl: './comment.component.html',
|
||||||
|
styleUrls: ['./comment.component.css']
|
||||||
|
})
|
||||||
|
export class CommentComponent implements OnInit {
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
8
src/app/main-page-post/main-page-post.component.css
Normal file
8
src/app/main-page-post/main-page-post.component.css
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
.example-card {
|
||||||
|
width:90%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.example-header-image {
|
||||||
|
background-image: url('https://steamcdn-a.akamaihd.net/steamcommunity/public/images/avatars/66/66e2ca8e3874a6b9518ffd7ad2c5842b51e829ee_full.jpg');
|
||||||
|
background-size: cover;
|
||||||
|
}
|
18
src/app/main-page-post/main-page-post.component.html
Normal file
18
src/app/main-page-post/main-page-post.component.html
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<mat-card class="example-card" mat-ripple>
|
||||||
|
<div>
|
||||||
|
<mat-card-header>
|
||||||
|
<div mat-card-avatar class="example-header-image"></div>
|
||||||
|
<mat-card-title>{{post.text | slice:0:20}}...</mat-card-title>
|
||||||
|
<mat-card-subtitle><span *ngFor="let x of post.autors">{{x}}, </span></mat-card-subtitle>
|
||||||
|
</mat-card-header>
|
||||||
|
<mat-card-content>
|
||||||
|
<p>
|
||||||
|
{{post.text}}
|
||||||
|
</p>
|
||||||
|
</mat-card-content>
|
||||||
|
<mat-card-actions>
|
||||||
|
<button mat-button [routerLink]="['/post', id]">MORE</button>
|
||||||
|
<button mat-button [routerLink]="['/post', id]">Comment</button>
|
||||||
|
</mat-card-actions>
|
||||||
|
</div>
|
||||||
|
</mat-card>
|
25
src/app/main-page-post/main-page-post.component.spec.ts
Normal file
25
src/app/main-page-post/main-page-post.component.spec.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { MainPagePostComponent } from './main-page-post.component';
|
||||||
|
|
||||||
|
describe('MainPagePostComponent', () => {
|
||||||
|
let component: MainPagePostComponent;
|
||||||
|
let fixture: ComponentFixture<MainPagePostComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ MainPagePostComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(MainPagePostComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
16
src/app/main-page-post/main-page-post.component.ts
Normal file
16
src/app/main-page-post/main-page-post.component.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import {Component, Input, OnInit} from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-main-page-post',
|
||||||
|
templateUrl: './main-page-post.component.html',
|
||||||
|
styleUrls: ['./main-page-post.component.css']
|
||||||
|
})
|
||||||
|
export class MainPagePostComponent implements OnInit {
|
||||||
|
@Input() post;
|
||||||
|
@Input() id;
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
10
src/app/main-page/main-page.component.css
Normal file
10
src/app/main-page/main-page.component.css
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
.mainPage{
|
||||||
|
display:flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.postContainer{
|
||||||
|
margin-bottom:2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
6
src/app/main-page/main-page.component.html
Normal file
6
src/app/main-page/main-page.component.html
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<section class="mainPage">
|
||||||
|
<div class="postContainer" *ngFor="let post of posts">
|
||||||
|
<app-main-page-post [id]="post.pk" [post]="post.fields"></app-main-page-post>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</section>
|
25
src/app/main-page/main-page.component.spec.ts
Normal file
25
src/app/main-page/main-page.component.spec.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { MainPageComponent } from './main-page.component';
|
||||||
|
|
||||||
|
describe('MainPageComponent', () => {
|
||||||
|
let component: MainPageComponent;
|
||||||
|
let fixture: ComponentFixture<MainPageComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ MainPageComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(MainPageComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
34
src/app/main-page/main-page.component.ts
Normal file
34
src/app/main-page/main-page.component.ts
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
import {trigger, transition, useAnimation, state, style, animate} from '@angular/animations';
|
||||||
|
import { bounce } from 'ng-animate';
|
||||||
|
import {PostsService} from '../posts.service';
|
||||||
|
@Component({
|
||||||
|
selector: 'app-main-page',
|
||||||
|
templateUrl: './main-page.component.html',
|
||||||
|
styleUrls: ['./main-page.component.css'],
|
||||||
|
animations: [
|
||||||
|
trigger('flyInOut', [
|
||||||
|
state('in', style({ transform: 'translateX(0)' })),
|
||||||
|
transition('void => *', [
|
||||||
|
style({ transform: 'translateX(-100%)' }),
|
||||||
|
animate(100)
|
||||||
|
]),
|
||||||
|
transition('* => void', [
|
||||||
|
animate(100, style({ transform: 'translateX(100%)' }))
|
||||||
|
])
|
||||||
|
])
|
||||||
|
],
|
||||||
|
})
|
||||||
|
export class MainPageComponent implements OnInit {
|
||||||
|
posts;
|
||||||
|
constructor(private postService:PostsService) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
this.postService.getPosts(0).subscribe(d=>{
|
||||||
|
this.posts = d;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
0
src/app/menu/menu.component.css
Normal file
0
src/app/menu/menu.component.css
Normal file
3
src/app/menu/menu.component.html
Normal file
3
src/app/menu/menu.component.html
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<p>
|
||||||
|
menu works!
|
||||||
|
</p>
|
25
src/app/menu/menu.component.spec.ts
Normal file
25
src/app/menu/menu.component.spec.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { MenuComponent } from './menu.component';
|
||||||
|
|
||||||
|
describe('MenuComponent', () => {
|
||||||
|
let component: MenuComponent;
|
||||||
|
let fixture: ComponentFixture<MenuComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ MenuComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(MenuComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
15
src/app/menu/menu.component.ts
Normal file
15
src/app/menu/menu.component.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-menu',
|
||||||
|
templateUrl: './menu.component.html',
|
||||||
|
styleUrls: ['./menu.component.css']
|
||||||
|
})
|
||||||
|
export class MenuComponent implements OnInit {
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
src/app/posts.service.spec.ts
Normal file
12
src/app/posts.service.spec.ts
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import { TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { PostsService } from './posts.service';
|
||||||
|
|
||||||
|
describe('PostsService', () => {
|
||||||
|
beforeEach(() => TestBed.configureTestingModule({}));
|
||||||
|
|
||||||
|
it('should be created', () => {
|
||||||
|
const service: PostsService = TestBed.get(PostsService);
|
||||||
|
expect(service).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
17
src/app/posts.service.ts
Normal file
17
src/app/posts.service.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { Injectable } from '@angular/core';
|
||||||
|
import {HttpClient} from '@angular/common/http';
|
||||||
|
const BACKEND_URL = "http://localhost:8001";
|
||||||
|
@Injectable({
|
||||||
|
providedIn: 'root'
|
||||||
|
})
|
||||||
|
export class PostsService {
|
||||||
|
|
||||||
|
constructor(private http:HttpClient) { }
|
||||||
|
getPosts(page){
|
||||||
|
return this.http.get(`${BACKEND_URL}/post?page=${page}`)
|
||||||
|
}
|
||||||
|
addNewPost(name,text){
|
||||||
|
return this.http.post(`${BACKEND_URL}/post`, )
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
3
src/app/right-panel/right-panel.component.css
Normal file
3
src/app/right-panel/right-panel.component.css
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
mat-form-field{
|
||||||
|
width:100%;
|
||||||
|
}
|
23
src/app/right-panel/right-panel.component.html
Normal file
23
src/app/right-panel/right-panel.component.html
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<mat-card class="example-card" >
|
||||||
|
<mat-card-header>
|
||||||
|
|
||||||
|
<mat-card-title>Add a new mikrowpis!</mat-card-title>
|
||||||
|
<mat-card-subtitle>Down here!</mat-card-subtitle>
|
||||||
|
</mat-card-header>
|
||||||
|
<mat-card-content>
|
||||||
|
<mat-form-field>
|
||||||
|
<input matInput placeholder="Imię">
|
||||||
|
</mat-form-field>
|
||||||
|
<mat-form-field>
|
||||||
|
<textarea [(ngModel)]="text" matInput placeholder="Co ci chodzi po głowie :D">
|
||||||
|
|
||||||
|
</textarea>
|
||||||
|
</mat-form-field>
|
||||||
|
<button mat-button color="primary" style="width:100%;margin-bottom:1em">Add!</button>
|
||||||
|
<div>
|
||||||
|
<span (click)="addEmoji(emoji)"matRipple style="cursor: pointer" *ngFor="let emoji of emoji_list">{{emoji}}</span>
|
||||||
|
</div>
|
||||||
|
</mat-card-content>
|
||||||
|
|
||||||
|
|
||||||
|
</mat-card>
|
25
src/app/right-panel/right-panel.component.spec.ts
Normal file
25
src/app/right-panel/right-panel.component.spec.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { RightPanelComponent } from './right-panel.component';
|
||||||
|
|
||||||
|
describe('RightPanelComponent', () => {
|
||||||
|
let component: RightPanelComponent;
|
||||||
|
let fixture: ComponentFixture<RightPanelComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ RightPanelComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(RightPanelComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
22
src/app/right-panel/right-panel.component.ts
Normal file
22
src/app/right-panel/right-panel.component.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-right-panel',
|
||||||
|
templateUrl: './right-panel.component.html',
|
||||||
|
styleUrls: ['./right-panel.component.css']
|
||||||
|
})
|
||||||
|
export class RightPanelComponent implements OnInit {
|
||||||
|
emojis="😀 😁 😂 🤣 😃 😄 😅 😆 😉 😊 😋 😎 😍 😘 🥰 😗 😙 😚 ☺️ 🙂 🤗 🤩 🤔 🤨 😐 😑 😶 🙄 😏 😣 😥 😮 🤐 😯 😪 😫 😴 😌 😛 😜 😝 🤤 😒 😓 😔 😕 🙃 🤑 😲 ☹️ 🙁 😖 😞 😟 😤 😢 😭 😦 😧 😨 😩 🤯 😬 😰 😱 🥵 🥶 😳 🤪 😵 😡 😠 🤬 😷 🤒 🤕 🤢 🤮 🤧 😇 🤠 🤡 🥳 🥴 🥺 🤥 🤫 🤭 🧐 🤓 😈 👿 👹 👺 💀 👻 👽 🤖 💩 😺 😸 😹 😻 😼 😽 🙀 😿 😾"
|
||||||
|
emoji_list=[]
|
||||||
|
text="";
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
this.emoji_list = Array.from(this.emojis);
|
||||||
|
this.emoji_list = this.emoji_list.filter(d=>d.length>0);
|
||||||
|
}
|
||||||
|
addEmoji(emoji){
|
||||||
|
this.text+=emoji;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
0
src/app/single-post/single-post.component.css
Normal file
0
src/app/single-post/single-post.component.css
Normal file
3
src/app/single-post/single-post.component.html
Normal file
3
src/app/single-post/single-post.component.html
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<p>
|
||||||
|
single-post works!
|
||||||
|
</p>
|
25
src/app/single-post/single-post.component.spec.ts
Normal file
25
src/app/single-post/single-post.component.spec.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||||
|
|
||||||
|
import { SinglePostComponent } from './single-post.component';
|
||||||
|
|
||||||
|
describe('SinglePostComponent', () => {
|
||||||
|
let component: SinglePostComponent;
|
||||||
|
let fixture: ComponentFixture<SinglePostComponent>;
|
||||||
|
|
||||||
|
beforeEach(async(() => {
|
||||||
|
TestBed.configureTestingModule({
|
||||||
|
declarations: [ SinglePostComponent ]
|
||||||
|
})
|
||||||
|
.compileComponents();
|
||||||
|
}));
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
fixture = TestBed.createComponent(SinglePostComponent);
|
||||||
|
component = fixture.componentInstance;
|
||||||
|
fixture.detectChanges();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should create', () => {
|
||||||
|
expect(component).toBeTruthy();
|
||||||
|
});
|
||||||
|
});
|
15
src/app/single-post/single-post.component.ts
Normal file
15
src/app/single-post/single-post.component.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import { Component, OnInit } from '@angular/core';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-single-post',
|
||||||
|
templateUrl: './single-post.component.html',
|
||||||
|
styleUrls: ['./single-post.component.css']
|
||||||
|
})
|
||||||
|
export class SinglePostComponent implements OnInit {
|
||||||
|
|
||||||
|
constructor() { }
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -7,8 +7,10 @@
|
|||||||
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<link rel="icon" type="image/x-icon" href="favicon.ico">
|
<link rel="icon" type="image/x-icon" href="favicon.ico">
|
||||||
|
<link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500" rel="stylesheet">
|
||||||
|
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body class="mat-typography">
|
||||||
<app-root></app-root>
|
<app-root></app-root>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -1 +1,4 @@
|
|||||||
/* You can add global styles to this file, and also import other style files */
|
/* You can add global styles to this file, and also import other style files */
|
||||||
|
|
||||||
|
html, body { height: 100%; }
|
||||||
|
body { margin: 0; font-family: Roboto, "Helvetica Neue", sans-serif; background-color: #fafafa;}
|
||||||
|
Loading…
Reference in New Issue
Block a user