mirror of
https://github.com/mxpv/podsync.git
synced 2024-05-11 05:55:04 +00:00
Add URL input field
This commit is contained in:
@@ -4,14 +4,18 @@ import { NgModule } from '@angular/core';
|
||||
import { AppRoutingModule } from './app-routing.module';
|
||||
import { AppComponent } from './app.component';
|
||||
import { IndexComponent } from './index/index.component';
|
||||
import { InputComponent } from './input/input.component';
|
||||
import {FormsModule} from '@angular/forms';
|
||||
|
||||
@NgModule({
|
||||
declarations: [
|
||||
AppComponent,
|
||||
IndexComponent
|
||||
IndexComponent,
|
||||
InputComponent
|
||||
],
|
||||
imports: [
|
||||
BrowserModule,
|
||||
FormsModule,
|
||||
AppRoutingModule
|
||||
],
|
||||
providers: [],
|
||||
|
||||
@@ -29,7 +29,7 @@
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- <app-input></app-input>-->
|
||||
<app-input></app-input>
|
||||
|
||||
<div class="man"></div>
|
||||
|
||||
|
||||
38
ui/src/app/input/input.component.html
Normal file
38
ui/src/app/input/input.component.html
Normal file
@@ -0,0 +1,38 @@
|
||||
<div class="main" [hidden]="popupOpened">
|
||||
<div class="main-border shadow">
|
||||
<div class="input-border">
|
||||
<input type="text"
|
||||
placeholder="paste your link here"
|
||||
spellcheck="false"
|
||||
autofocus
|
||||
[(ngModel)]="link"
|
||||
(keydown.enter)="submit()" />
|
||||
|
||||
<div class="arrow-button" [style.display]="link.length > 3 ? 'block' : 'none'">
|
||||
<a href="#" (click)="submit()">
|
||||
<i class="fa fa-arrow-right" aria-hidden="true"></i>
|
||||
</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="controls">
|
||||
<div class="controls-icon">
|
||||
<ng-container *ngIf="locked">
|
||||
<a href="https://www.patreon.com/bePatron?c=278915" class="black">
|
||||
<i class="fa fa-question-circle master-tooltip"
|
||||
aria-hidden="true"
|
||||
title="This features are available for patrons only. You may support us and unlock this features"></i>
|
||||
</a>
|
||||
</ng-container>
|
||||
<ng-container *ngIf="!locked">
|
||||
<i class="fa fa-wrench" aria-hidden="true"></i>
|
||||
</ng-container>
|
||||
</div>
|
||||
|
||||
<div [class.locked]="locked">
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
79
ui/src/app/input/input.component.scss
Normal file
79
ui/src/app/input/input.component.scss
Normal file
@@ -0,0 +1,79 @@
|
||||
.main {
|
||||
text-align: center;
|
||||
padding: 5em 2em 10em;
|
||||
max-width: 860px;
|
||||
width: 90%;
|
||||
margin: 0 auto;
|
||||
padding: 3em 0;
|
||||
text-align: left;
|
||||
|
||||
@media screen and (max-width: 840px) {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
@media screen and (max-height: 840px) {
|
||||
padding-top: 0;
|
||||
}
|
||||
}
|
||||
|
||||
.main-border {
|
||||
border: thin solid #a39c8e;
|
||||
background: #f4ecda;
|
||||
|
||||
input {
|
||||
border: none;
|
||||
padding: 0.5em 0 0.5em 0.5em;
|
||||
width: calc(100% - 2em);
|
||||
font-size: 2em;
|
||||
line-height: 1;
|
||||
color: #616161;
|
||||
background: transparent;
|
||||
}
|
||||
}
|
||||
|
||||
.input-border {
|
||||
background-color: #e4dac8;
|
||||
border: none;
|
||||
border-bottom: 1px solid #a39c8e;
|
||||
}
|
||||
|
||||
*:focus {
|
||||
outline: none;
|
||||
}
|
||||
|
||||
/* Input button (arrow) */
|
||||
|
||||
.arrow-button {
|
||||
float: right;
|
||||
font-size: 2em;
|
||||
padding-top: 0.5em;
|
||||
padding-right: 0.3em;
|
||||
|
||||
a {
|
||||
color: rgb(142, 134, 119);
|
||||
}
|
||||
|
||||
a:hover {
|
||||
background: none;
|
||||
color: rgb(105, 98, 86);
|
||||
}
|
||||
}
|
||||
|
||||
/* Controls under input */
|
||||
|
||||
.controls {
|
||||
padding-left: 1em;
|
||||
word-spacing: 0.15em;
|
||||
margin: 12px 0 12px 0;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.controls-icon {
|
||||
float: left;
|
||||
padding-right: 6px;
|
||||
}
|
||||
|
||||
.locked {
|
||||
-ms-opacity: 0.3;
|
||||
opacity: 0.2;
|
||||
}
|
||||
25
ui/src/app/input/input.component.spec.ts
Normal file
25
ui/src/app/input/input.component.spec.ts
Normal file
@@ -0,0 +1,25 @@
|
||||
import { async, ComponentFixture, TestBed } from '@angular/core/testing';
|
||||
|
||||
import { InputComponent } from './input.component';
|
||||
|
||||
describe('InputComponent', () => {
|
||||
let component: InputComponent;
|
||||
let fixture: ComponentFixture<InputComponent>;
|
||||
|
||||
beforeEach(async(() => {
|
||||
TestBed.configureTestingModule({
|
||||
declarations: [ InputComponent ]
|
||||
})
|
||||
.compileComponents();
|
||||
}));
|
||||
|
||||
beforeEach(() => {
|
||||
fixture = TestBed.createComponent(InputComponent);
|
||||
component = fixture.componentInstance;
|
||||
fixture.detectChanges();
|
||||
});
|
||||
|
||||
it('should create', () => {
|
||||
expect(component).toBeTruthy();
|
||||
});
|
||||
});
|
||||
24
ui/src/app/input/input.component.ts
Normal file
24
ui/src/app/input/input.component.ts
Normal file
@@ -0,0 +1,24 @@
|
||||
import { Component, OnInit } from '@angular/core';
|
||||
|
||||
@Component({
|
||||
selector: 'app-input',
|
||||
templateUrl: './input.component.html',
|
||||
styleUrls: ['./input.component.scss']
|
||||
})
|
||||
export class InputComponent implements OnInit {
|
||||
popupOpened: boolean;
|
||||
locked = false;
|
||||
format = 'video';
|
||||
quality = 'high';
|
||||
pageSize = 50;
|
||||
link = '';
|
||||
|
||||
constructor() { }
|
||||
|
||||
ngOnInit() {
|
||||
}
|
||||
|
||||
submit() {
|
||||
console.log('input submit');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user