commit
d8af3200c4
121 changed files with 1378 additions and 881 deletions
4
.gitignore
vendored
4
.gitignore
vendored
|
@ -17,3 +17,7 @@ public/bundle/Lekton-*
|
||||||
public/bundle/style.css
|
public/bundle/style.css
|
||||||
|
|
||||||
uploads
|
uploads
|
||||||
|
|
||||||
|
config/
|
||||||
|
|
||||||
|
deployment-config.json
|
||||||
|
|
109
README.md
109
README.md
|
@ -1,21 +1,97 @@
|
||||||
# Spee.ch
|
# Spee.ch
|
||||||
Spee.ch is a web app that reads and publishes images and videos to and from the [LBRY](https://lbry.io/) blockchain. You are encouraged to contribute to the shared code base, or fork it and make it your own.
|
Spee.ch is a web app that reads and publishes images and videos to and from the [LBRY](https://lbry.io/) blockchain. We encourage you to contribute to the shared code base, or fork it and make it your own.
|
||||||
|
|
||||||
You can create your own custom version of spee.ch by installing this code base and then creating your own custom components and styles to override the defaults. (More details/guide on how to do that coming soon.)
|
You can create your own custom version of spee.ch by installing this code base and then creating your own custom components and styles to override the defaults. (More details/guide on how to do that coming soon.)
|
||||||
|
|
||||||
## Quickstart
|
## Technology Overview
|
||||||
|
Spee.ch is a react web app that depends on MySQL for local content, and on two other lbry technologies:
|
||||||
|
* [chainquery](https://github.com/lbryio/chainquery) - a normalized database of the blockchain data. We've provided credentials to use a public chainquery service. You can also install it on your own server to avoid being affected by the commons.
|
||||||
|
* [lbrynet](https://github.com/lbryio/lbry) - a daemon that handles your wallet and transactions.
|
||||||
|
|
||||||
### Ubuntu
|
## Installation
|
||||||
[Ubuntu VPS Setup](./docs/ubuntu16vpspersonal.md)
|
|
||||||
|
|
||||||
_Note: This is our new setup. For our old setup see the [fullstart guide](./fullstart.md)._
|
### Ubuntu Step by Step
|
||||||
|
[Ubuntu Install Guide](./docs/ubuntuinstall.md)
|
||||||
|
|
||||||
#### System Dependencies:
|
### Quickstart Overview
|
||||||
* [node](https://nodejs.org)
|
|
||||||
|
#### Get some information ready:
|
||||||
|
* mysqlusername
|
||||||
|
* mysqlpassword
|
||||||
|
* domainname or 'http://localhost'
|
||||||
|
* speechport = 3000
|
||||||
|
|
||||||
|
#### Install and Set Up System Dependencies:
|
||||||
|
* [NodeJS](https://nodejs.org)
|
||||||
* [MySQL](https://dev.mysql.com/doc/refman/8.0/en/installing.html)
|
* [MySQL](https://dev.mysql.com/doc/refman/8.0/en/installing.html)
|
||||||
* [`lbry`](https://github.com/lbryio/lbry) daemon
|
* localhost port 3306
|
||||||
* note: retrieve an address from the daemon and send your wallet a few credits (or join us in the [#speech discord channel](https://discord.gg/YjYbwhS) and we will send you a few)
|
* mysqlusername or root
|
||||||
|
* mysqlpassword
|
||||||
|
* You may need
|
||||||
|
```
|
||||||
|
mysql> `ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'yourpassword';`
|
||||||
|
```
|
||||||
|
* [lbrynet](https://github.com/lbryio/lbry) daemon
|
||||||
|
* run this as a service exposing ports 3333 and 4444
|
||||||
|
* _note_: once the daemon is running, issue commands in another terminal session (tmux) to retrieve an address for your wallet to recieve 5+ LBC credits (or join us in the [#speech discord channel](https://discord.gg/YjYbwhS) and we will send you a few)
|
||||||
|
* `./lbrynet commands` gets a list of commands
|
||||||
|
* `./lbrynet account_balance` gets your balance (initially 0.0)
|
||||||
|
* `./lbrynet address_list` gets addresses you can use to recieve LBC
|
||||||
* [FFmpeg](https://www.ffmpeg.org/download.html)
|
* [FFmpeg](https://www.ffmpeg.org/download.html)
|
||||||
|
* [Spee.ch] (below)
|
||||||
|
* [pm2] (optional) process manager such as pm2 to run speech server.js
|
||||||
|
* [http proxy server] caddy, nginx, traefik, etc to forward 443 to speech port 3000
|
||||||
|
|
||||||
|
|
||||||
|
#### Clone this repo
|
||||||
|
* release version for stable production
|
||||||
|
```
|
||||||
|
$ git clone -b release https://github.com/lbryio/spee.ch.git
|
||||||
|
```
|
||||||
|
* master version for development
|
||||||
|
```
|
||||||
|
$ git clone https://github.com/lbryio/spee.ch.git
|
||||||
|
```
|
||||||
|
* your own fork for customization
|
||||||
|
|
||||||
|
#### Change directory into your project
|
||||||
|
```
|
||||||
|
$ cd spee.ch
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Install node dependencies
|
||||||
|
```
|
||||||
|
$ npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Create the config files using the built-in CLI
|
||||||
|
_note: make sure lbrynet is running in the background before proceeding_
|
||||||
|
|
||||||
|
```
|
||||||
|
$ npm run configure
|
||||||
|
```
|
||||||
|
|
||||||
|
* _note: At the moment, you will have to copy chainqueryConfig.json from:_
|
||||||
|
```
|
||||||
|
~/spee.ch/docs/setup/conf/speech/chainqueryConfig.json
|
||||||
|
```
|
||||||
|
|
||||||
|
_to:_
|
||||||
|
```
|
||||||
|
~/spee.ch/site/config/chainqueryConfig.json
|
||||||
|
```
|
||||||
|
|
||||||
|
* _note: The domain name in this part must be prefixed with http:// or https://_
|
||||||
|
|
||||||
|
#### Build & start the app
|
||||||
|
|
||||||
|
_note: make sure lbrynet is running in the background before proceeding_
|
||||||
|
```
|
||||||
|
$ npm run start
|
||||||
|
```
|
||||||
|
|
||||||
|
#### View in browser
|
||||||
|
* Visit [http://localhost:3000](http://localhost:3000) in your browser
|
||||||
|
|
||||||
#### Customize your app
|
#### Customize your app
|
||||||
|
|
||||||
|
@ -23,12 +99,11 @@ Check out the [customization guide](https://github.com/lbryio/spee.ch/blob/readm
|
||||||
|
|
||||||
#### (optional) add custom components and update the styles
|
#### (optional) add custom components and update the styles
|
||||||
|
|
||||||
* Create custom components by creating React components in `src/views/` (further instructions coming soon)
|
* Create custom components by creating React components in `site/custom/src/` (further instructions coming soon)
|
||||||
* Update the CSS by changing the files in `public/assets/css/` (further instructions and refactor coming soon)
|
* Update the CSS by changing the files in `site/custom/scss` (further instructions and refactor coming soon)
|
||||||
|
|
||||||
#### (optional) Syncing the full blockchain
|
#### (optional) install your own chainquery
|
||||||
* Start the `spee.ch-sync` tool available at [billbitt/spee.ch-sync](https://github.com/billbitt/spee.ch-sync)
|
Instructions are coming at [lbry-docker] to install your own chainquery instance using docker-compose. This will require 50GB of preferably SSD space and at least 10 minutes to download, possibly much longer.
|
||||||
* This is not necessary, but highly recommended. It will decode the blocks of the `LBRY` blockchain and add the claims information to your database's tables
|
|
||||||
|
|
||||||
## API
|
## API
|
||||||
#### /api/claim/publish
|
#### /api/claim/publish
|
||||||
|
@ -112,7 +187,7 @@ Spee.ch also runs a sync tool, which decodes blocks from the `LBRY` blockchain a
|
||||||
|
|
||||||
|
|
||||||
### Architecture
|
### Architecture
|
||||||
* `cli/` contains the code for the CLI tool. Running the tool will create `.json` config files and place them in the `config/` folder
|
* `cli/` contains the code for the CLI tool. Running the tool will create `.json` config files and place them in the `site/config/` folder
|
||||||
* `configure.js` is the entry point for the CLI tool
|
* `configure.js` is the entry point for the CLI tool
|
||||||
* `cli/defaults/` holds default config files
|
* `cli/defaults/` holds default config files
|
||||||
* `cli/questions/` holds the questions that the CLI tool asks to build the config files
|
* `cli/questions/` holds the questions that the CLI tool asks to build the config files
|
||||||
|
@ -128,9 +203,9 @@ Spee.ch also runs a sync tool, which decodes blocks from the `LBRY` blockchain a
|
||||||
* `client/scss/` contains the CSS for the project
|
* `client/scss/` contains the CSS for the project
|
||||||
*
|
*
|
||||||
|
|
||||||
* `config/custom` is a folder which can be used to override the default components in `client/`
|
* `site/custom` is a folder which can be used to override the default components in `client/`
|
||||||
* The folder structure mimics that of the `client/` folder
|
* The folder structure mimics that of the `client/` folder
|
||||||
* to customize spee.ch, place your own components and scss in the `config/custom/src/` and `config/custom/scss` folders.
|
* to customize spee.ch, place your own components and scss in the `site/custom/src/` and `site/custom/scss` folders.
|
||||||
|
|
||||||
* `server/` contains all of the server code
|
* `server/` contains all of the server code
|
||||||
* `index.js` is the entry point for the server. It creates the [express app](https://expressjs.com/), requires the routes, syncs the database, and starts the server listening on the `PORT` designated in the config files.
|
* `index.js` is the entry point for the server. It creates the [express app](https://expressjs.com/), requires the routes, syncs the database, and starts the server listening on the `PORT` designated in the config files.
|
||||||
|
|
|
@ -67,6 +67,13 @@ try {
|
||||||
slackConfig = require('./defaults/slackConfig.json');
|
slackConfig = require('./defaults/slackConfig.json');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let chainqueryConfig;
|
||||||
|
try {
|
||||||
|
chainqueryConfig = require('../site/config/chainqueryConfig.json');
|
||||||
|
} catch (error) {
|
||||||
|
chainqueryConfig = require('./defaults/chainqueryConfig.json');
|
||||||
|
}
|
||||||
|
|
||||||
// ask user questions and create config files
|
// ask user questions and create config files
|
||||||
inquirer
|
inquirer
|
||||||
.prompt(mysqlQuestions(mysqlDatabase, mysqlUsername, mysqlPassword))
|
.prompt(mysqlQuestions(mysqlDatabase, mysqlUsername, mysqlPassword))
|
||||||
|
@ -196,6 +203,7 @@ inquirer
|
||||||
createConfigFile('lbryConfig.json', lbryConfig);
|
createConfigFile('lbryConfig.json', lbryConfig);
|
||||||
createConfigFile('loggerConfig.json', loggerConfig);
|
createConfigFile('loggerConfig.json', loggerConfig);
|
||||||
createConfigFile('slackConfig.json', slackConfig);
|
createConfigFile('slackConfig.json', slackConfig);
|
||||||
|
createConfigFile('chainqueryConfig.json', chainqueryConfig);
|
||||||
})
|
})
|
||||||
.then(() => {
|
.then(() => {
|
||||||
console.log('\nYou\'re all done!');
|
console.log('\nYou\'re all done!');
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
{
|
{
|
||||||
"host": "localhost",
|
"host": "public.chainquery.lbry.io",
|
||||||
"port": "3306",
|
"port": "3306",
|
||||||
"timeout": 30,
|
"timeout": 30,
|
||||||
"database": "chainquery",
|
"database": "chainquery",
|
||||||
"username": "lbry",
|
"username": "speechpublic",
|
||||||
"password": "root"
|
"password": "7uITJLwZRvHBZYS3JZDykD1-7hLVkVA1jDWfcgqi6QnC"
|
||||||
}
|
}
|
||||||
|
|
129
client/scss/_asset-display.scss
Normal file
129
client/scss/_asset-display.scss
Normal file
|
@ -0,0 +1,129 @@
|
||||||
|
.asset-main {
|
||||||
|
height: 75vh;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.asset-display {
|
||||||
|
display: flex;
|
||||||
|
min-height: 50vh
|
||||||
|
}
|
||||||
|
|
||||||
|
.asset-title {
|
||||||
|
padding-bottom: $thin-padding;
|
||||||
|
text-align: center;
|
||||||
|
|
||||||
|
@media (min-width: $break-point-mobile) {
|
||||||
|
padding-top: $secondary-padding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.asset-image, .asset-video {
|
||||||
|
max-height: 100%;
|
||||||
|
max-width: 100%;
|
||||||
|
margin-left: auto;
|
||||||
|
margin-right: auto;
|
||||||
|
object-fit: contain;
|
||||||
|
object-position: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*below must die if this is intended to be shareable component! it also probably doesn't need to be*/
|
||||||
|
|
||||||
|
.visible-content {
|
||||||
|
margin: 0;
|
||||||
|
padding-bottom: 30px;
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
|
||||||
|
&.closed {
|
||||||
|
box-shadow: none;
|
||||||
|
|
||||||
|
&:after {
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&:after {
|
||||||
|
box-shadow: 0px 2px 3px 2px $shadow-color;
|
||||||
|
content: '';
|
||||||
|
height: 0;
|
||||||
|
position: absolute;
|
||||||
|
top: 100%;
|
||||||
|
width: 100%;
|
||||||
|
z-index: 100;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.vertical-split, .visible-content {
|
||||||
|
flex : 1 0 auto;
|
||||||
|
display : flex;
|
||||||
|
flex-direction : column;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items : center;
|
||||||
|
};
|
||||||
|
|
||||||
|
.collapse-content {
|
||||||
|
flex-grow: 0;
|
||||||
|
@media (max-width: $break-point-tablet) {
|
||||||
|
max-width: 100%;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.collapse-content.closed{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.collapse-button {
|
||||||
|
background: none;
|
||||||
|
border: none;
|
||||||
|
display: block;
|
||||||
|
margin: 15px auto 0;
|
||||||
|
width: 25px;
|
||||||
|
height: 25px;
|
||||||
|
text-align: center;
|
||||||
|
padding: 0px;
|
||||||
|
|
||||||
|
@media (max-width: $break-point-tablet) {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
svg {
|
||||||
|
stroke: $primary-color;
|
||||||
|
&.plus-icon {
|
||||||
|
transform: rotate(0);
|
||||||
|
transition: all 0.4s ease;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
.plus-icon {
|
||||||
|
transform: rotate(-180deg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.asset-info {
|
||||||
|
$asset-info-width: 1000px;
|
||||||
|
max-width: $asset-info-width;
|
||||||
|
margin: $primary-padding;
|
||||||
|
max-width: 100%;
|
||||||
|
|
||||||
|
@media (max-width: $break-point-tablet) {
|
||||||
|
margin: $primary-padding $secondary-padding;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: $break-point-mobile) {
|
||||||
|
margin: $primary-padding 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.asset-footer {
|
||||||
|
border-top: 1px solid $grey-border;
|
||||||
|
padding-top: $primary-padding;
|
||||||
|
margin-top: $primary-padding;
|
||||||
|
color: $grey;
|
||||||
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
body {
|
body {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
height: 100%;
|
min-height: 100%;
|
||||||
word-wrap: break-word;
|
word-wrap: break-word;
|
||||||
display: -webkit-flex;
|
display: -webkit-flex;
|
||||||
display: flex;
|
display: flex;
|
16
client/scss/_button-primary.scss
Normal file
16
client/scss/_button-primary.scss
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
.button--primary, .button--primary:focus, .button--primary:active {
|
||||||
|
border-color: $primary-color;
|
||||||
|
color: $primary-color;
|
||||||
|
background-color: $background-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button--primary:hover {
|
||||||
|
color: $background-color;
|
||||||
|
background-color: $primary-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button--primary:active {
|
||||||
|
$color: darken($primary-color, 10%);
|
||||||
|
border-color: $color;
|
||||||
|
background-color: $color;
|
||||||
|
}
|
11
client/scss/_button-secondary.scss
Normal file
11
client/scss/_button-secondary.scss
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
.button--secondary, .button--secondary:focus, .button--secondary:active {
|
||||||
|
border-bottom-color: $secondary-color;
|
||||||
|
color: $secondary-color;
|
||||||
|
background-color: $background-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button--secondary:active {
|
||||||
|
$color: darken($secondary-color, 10%);
|
||||||
|
color: $color;
|
||||||
|
border-bottom-color: $color;
|
||||||
|
}
|
21
client/scss/_button.scss
Normal file
21
client/scss/_button.scss
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
button {
|
||||||
|
cursor: pointer;
|
||||||
|
&:active
|
||||||
|
{
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.button--primary, .button--secondary
|
||||||
|
{
|
||||||
|
border-width: $button-border-width;
|
||||||
|
border-style: $button-border-strength;
|
||||||
|
border-color: transparent;
|
||||||
|
padding: $thin-padding;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.button--jumbo, .button--jumbo:focus, .button--jumbo:active {
|
||||||
|
width: $button-full-width;
|
||||||
|
font-size: x-large;
|
||||||
|
}
|
33
client/scss/_click-to-copy.scss
Normal file
33
client/scss/_click-to-copy.scss
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
.click-to-copy-wrap {
|
||||||
|
display: flex;
|
||||||
|
width: 100%;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
cursor: pointer;
|
||||||
|
border: 1px solid $grey-border;
|
||||||
|
border-radius: 6px;
|
||||||
|
.click-to-copy {
|
||||||
|
border: none;
|
||||||
|
padding: 0.36em 0.5em;
|
||||||
|
margin: 0;
|
||||||
|
background-color: transparent;
|
||||||
|
width: calc(100% - 1em - 2px);
|
||||||
|
font-size: 14px;
|
||||||
|
letter-spacing: -0.6px;
|
||||||
|
line-height: 20px;
|
||||||
|
letter-spacing: 0;
|
||||||
|
font-family: monospace;
|
||||||
|
border-right: 1px solid $grey-border;
|
||||||
|
}
|
||||||
|
.icon-wrap {
|
||||||
|
width: 30px;
|
||||||
|
height: 30px;
|
||||||
|
line-height: 34px;
|
||||||
|
text-align: center;
|
||||||
|
svg {
|
||||||
|
stroke: $primary-color;
|
||||||
|
width: 16px;
|
||||||
|
height: 16px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -16,6 +16,7 @@
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
user-select: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
.dropzone:hover, .dropzone--active {
|
.dropzone:hover, .dropzone--active {
|
||||||
|
@ -28,6 +29,11 @@
|
||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.dropzone-dropit-display
|
||||||
|
{
|
||||||
|
color: $primary-color;
|
||||||
|
}
|
||||||
|
|
||||||
.dropzone-preview-wrapper {
|
.dropzone-preview-wrapper {
|
||||||
position: relative;
|
position: relative;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
@ -49,3 +55,7 @@
|
||||||
padding: 1em;
|
padding: 1em;
|
||||||
width: calc(100% - 2em);
|
width: calc(100% - 2em);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.dropzone-instructions-display__chooser-label {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
7
client/scss/_form.scss
Normal file
7
client/scss/_form.scss
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
.form-group {
|
||||||
|
padding-bottom: $secondary-padding;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-title {
|
||||||
|
padding-bottom: $secondary-padding;
|
||||||
|
}
|
62
client/scss/_horizontal-split.scss
Normal file
62
client/scss/_horizontal-split.scss
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
.horizontal-split {
|
||||||
|
max-width: $width-content-constrained;
|
||||||
|
width: 100%;
|
||||||
|
margin-left: auto;
|
||||||
|
margin-right: auto;
|
||||||
|
display : flex;
|
||||||
|
flex-direction : row;
|
||||||
|
justify-content: space-between;
|
||||||
|
|
||||||
|
&.horizontal-split--mobile-collapse {
|
||||||
|
@media (max-width: $break-point-mobile) {
|
||||||
|
flex-direction: column;
|
||||||
|
|
||||||
|
.horizontal-split__column {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.horizontal-split__column--right {
|
||||||
|
padding-left: 0;
|
||||||
|
padding-top: $secondary-padding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
.horizontal-split__column {
|
||||||
|
width: 50%;
|
||||||
|
flex: 1 0 auto;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
.horizontal-split__column--left {
|
||||||
|
padding-right: $primary-padding;
|
||||||
|
|
||||||
|
@media (max-width: $break-point-mobile) {
|
||||||
|
padding-right: $thin-padding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.horizontal-split__column--right {
|
||||||
|
padding-left: $primary-padding;
|
||||||
|
|
||||||
|
@media (max-width: $break-point-mobile) {
|
||||||
|
padding-left: $thin-padding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: $break-point-tablet) {
|
||||||
|
|
||||||
|
.horizontal-split__column {
|
||||||
|
display : flex;
|
||||||
|
flex-direction : column;
|
||||||
|
justify-content: space-between;
|
||||||
|
};
|
||||||
|
|
||||||
|
.column {
|
||||||
|
width: 100%;
|
||||||
|
padding-left: 0;
|
||||||
|
padding-right: 0;
|
||||||
|
padding-bottom: $secondary-padding;
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,17 +4,12 @@ input:-webkit-autofill {
|
||||||
|
|
||||||
input {
|
input {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
outline: none;
|
|
||||||
padding: $input-padding;
|
padding: $input-padding;
|
||||||
border: 0;
|
border: 0;
|
||||||
background-color: $background-color;
|
background-color: $background-color;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
}
|
}
|
||||||
|
|
||||||
.input-text {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
.input-slider {
|
.input-slider {
|
||||||
width: 100%
|
width: 100%
|
||||||
}
|
}
|
||||||
|
@ -43,6 +38,10 @@ input {
|
||||||
border-bottom: 1px solid $secondary-color;
|
border-bottom: 1px solid $secondary-color;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.form-group {
|
||||||
|
padding-bottom: $secondary-padding;
|
||||||
|
}
|
||||||
|
|
||||||
// modifiers
|
// modifiers
|
||||||
|
|
||||||
.input--full-width {
|
.input--full-width {
|
|
@ -2,6 +2,7 @@
|
||||||
padding-top: $thin-padding;
|
padding-top: $thin-padding;
|
||||||
padding-bottom: $thin-padding;
|
padding-bottom: $thin-padding;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
|
font-size: 12px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.label-radio {
|
.label-radio {
|
||||||
|
@ -10,7 +11,7 @@
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: $break-point-medium ) {
|
@media (max-width: $break-point-tablet ) {
|
||||||
|
|
||||||
// note: bolding break point lines up with row-label break point
|
// note: bolding break point lines up with row-label break point
|
||||||
.label, .label-radio {
|
.label, .label-radio {
|
21
client/scss/_link.scss
Normal file
21
client/scss/_link.scss
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
a, a:visited {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.link--primary, .link--primary:visited {
|
||||||
|
color: $primary-color;
|
||||||
|
&:hover { text-decoration: underline; }
|
||||||
|
}
|
||||||
|
|
||||||
|
.link--nav {
|
||||||
|
color: $text-color;
|
||||||
|
border-bottom: 2px solid white;
|
||||||
|
&:hover {
|
||||||
|
color: $primary-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.link--nav-active {
|
||||||
|
border-bottom: 2px solid $primary-color;
|
||||||
|
}
|
7
client/scss/_media-queries.scss
Normal file
7
client/scss/_media-queries.scss
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
@media (max-width: $break-point-x-large) {
|
||||||
|
// hide site description in nav bar
|
||||||
|
.site-description {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,31 +1,37 @@
|
||||||
.nav-bar {
|
.nav-bar {
|
||||||
padding-left: $primary-padding;
|
margin-top: $thin-padding;
|
||||||
padding-right: $primary-padding;
|
margin-left: $primary-padding;
|
||||||
border-bottom: 0.5px solid $tertiary-color;
|
margin-right: $primary-padding;
|
||||||
.select--arrow {
|
|
||||||
padding: 0 1.5em 0 $input-padding;
|
@media (max-width: $break-point-mobile) {
|
||||||
|
margin-left: 15px;
|
||||||
|
margin-right: 15px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.nav-bar-link {
|
.nav-bar-link {
|
||||||
padding: calc(1em - 2px);
|
padding: calc(1em - 2px);
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
|
font-size: $text-medium;
|
||||||
|
letter-spacing: 0.4px;
|
||||||
|
text-transform: uppercase;
|
||||||
}
|
}
|
||||||
|
|
||||||
.nav-bar-logo {
|
.nav-bar-logo {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: $break-point-medium ) {
|
@media (max-width: $break-point-tablet ) {
|
||||||
.nav-bar-link {
|
.nav-bar-link {
|
||||||
padding-top: calc(1em - 2px);
|
padding-top: calc(1em - 2px);
|
||||||
padding-right: 1em;
|
padding-right: 1em;
|
||||||
padding-bottom: calc(1em - 2px);
|
padding-bottom: calc(1em - 2px);
|
||||||
padding-left: 1em;
|
padding-left: 1em;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (max-width: $break-point-small ) {
|
@media (max-width: $break-point-mobile ) {
|
||||||
.nav-bar-link {
|
.nav-bar-link {
|
||||||
padding-top: calc(0.5em - 2px);
|
padding-top: calc(0.5em - 2px);
|
||||||
padding-right: 0.5em;
|
padding-right: 0.5em;
|
27
client/scss/_page-layout.scss
Normal file
27
client/scss/_page-layout.scss
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
.page-layout {
|
||||||
|
flex: 1 0 auto;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
.content {
|
||||||
|
flex: 1 0 auto;
|
||||||
|
display: flex;
|
||||||
|
-webkit-flex-direction: column;
|
||||||
|
flex-direction: column;
|
||||||
|
margin: $secondary-padding;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: $break-point-tablet) {
|
||||||
|
.page-layout .content { margin: $tertiary-padding; }
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: $break-point-mobile) {
|
||||||
|
max-width: calc(100% - 30px);
|
||||||
|
}
|
||||||
|
|
||||||
|
//below should take some styles from _text.scss and probably elsewhere and become "markdown" or "rich" styles
|
||||||
|
.page-layout {
|
||||||
|
p {
|
||||||
|
margin-bottom: $tertiary-padding;
|
||||||
|
}
|
||||||
|
}
|
12
client/scss/_progress-bar.scss
Normal file
12
client/scss/_progress-bar.scss
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
.progress-bar__wrapper {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
.progress-bar--inactive {
|
||||||
|
color: $grey;
|
||||||
|
}
|
||||||
|
|
||||||
|
.progress-bar--active {
|
||||||
|
color: $primary-color;
|
||||||
|
}
|
13
client/scss/_publish-preview.scss
Normal file
13
client/scss/_publish-preview.scss
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
.publish-form__title {
|
||||||
|
max-width: $width-content-constrained;
|
||||||
|
margin-left: auto;
|
||||||
|
margin-right: auto;
|
||||||
|
|
||||||
|
@media (max-width: $break-point-mobile) {
|
||||||
|
font-size: .8em;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.publish-preview-dim {
|
||||||
|
opacity: 0.2;
|
||||||
|
}
|
|
@ -17,5 +17,5 @@
|
||||||
.publish-url-text {
|
.publish-url-text {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
color: $secondary-color;
|
color: $help-color;
|
||||||
}
|
}
|
4
client/scss/_reset.scss
Normal file
4
client/scss/_reset.scss
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
button, input, textarea, label, select, option {
|
||||||
|
font-family: inherit;
|
||||||
|
font-size: inherit;
|
||||||
|
}
|
|
@ -1,5 +1,5 @@
|
||||||
.row {
|
.row {
|
||||||
padding-bottom: 2em;
|
margin-bottom: 1.2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
.row-labeled {
|
.row-labeled {
|
||||||
|
@ -7,29 +7,28 @@
|
||||||
flex-direction: row;
|
flex-direction: row;
|
||||||
flex-wrap: nowrap;
|
flex-wrap: nowrap;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
|
padding-bottom: $tertiary-padding;
|
||||||
}
|
}
|
||||||
|
|
||||||
.row-labeled-label {
|
.row-labeled-label {
|
||||||
align-self: flex-start;
|
|
||||||
width: 30%;
|
width: 30%;
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
flex: 1;
|
||||||
}
|
}
|
||||||
.row-labeled-content {
|
.row-labeled-content {
|
||||||
align-self: center;
|
align-self: center;
|
||||||
width: 70%;
|
width: 70%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@media (max-width: $break-point-tablet ) {
|
||||||
@media (max-width: $break-point-medium ) {
|
|
||||||
|
|
||||||
.row-labeled {
|
.row-labeled {
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
}
|
}
|
||||||
|
|
||||||
.row-labeled-label {
|
.row-labeled-label {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
.row-labeled-content {
|
.row-labeled-content {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
4
client/scss/_select.scss
Normal file
4
client/scss/_select.scss
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
select {
|
||||||
|
margin: 0;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
51
client/scss/_share-buttons.scss
Normal file
51
client/scss/_share-buttons.scss
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
.share-buttons {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
a {
|
||||||
|
display: block;
|
||||||
|
width: 30px;
|
||||||
|
height: 30px;
|
||||||
|
margin: 0 7px;
|
||||||
|
border-radius: 100%;
|
||||||
|
line-height: 30px;
|
||||||
|
text-align: center;
|
||||||
|
transition: all 0.2s ease;
|
||||||
|
&.twitter {
|
||||||
|
background:#4DC2FE;
|
||||||
|
img {
|
||||||
|
margin-top: 8px;
|
||||||
|
margin-left: 2px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.facebook {
|
||||||
|
background: #5487DE;
|
||||||
|
img {
|
||||||
|
margin-top: 6px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.tumblr {
|
||||||
|
background: #274061;
|
||||||
|
img {
|
||||||
|
margin-top: 7px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.reddit {
|
||||||
|
background: #FF4500;
|
||||||
|
img {
|
||||||
|
margin-top: 7px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&:first-child{
|
||||||
|
margin-left: 0px;
|
||||||
|
}
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
background: $primary-color;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,5 +7,4 @@
|
||||||
.social-share-link > a{
|
.social-share-link > a{
|
||||||
padding-right:0.5em;
|
padding-right:0.5em;
|
||||||
padding-left:0.5em;
|
padding-left:0.5em;
|
||||||
padding-bottom:0.3em;
|
|
||||||
}
|
}
|
59
client/scss/_text.scss
Normal file
59
client/scss/_text.scss
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
// set defaults
|
||||||
|
|
||||||
|
h1, h2, h3, h4, p {
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
color: $text-color;
|
||||||
|
font-family: 'Circular', serif;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: $text-xx-large;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
font-size: $text-x-large;
|
||||||
|
}
|
||||||
|
|
||||||
|
h3 {
|
||||||
|
font-size: $text-large;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--extra-large {
|
||||||
|
font-size: $text-xx-large;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--large {
|
||||||
|
font-size: $text-large;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--medium {
|
||||||
|
font-size: $text-medium;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--small {
|
||||||
|
font-size: $text-small;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--extra-small {
|
||||||
|
font-size: $text-x-small;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--secondary {
|
||||||
|
color: $help-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--interactive {
|
||||||
|
color: $primary-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--failure {
|
||||||
|
color: $failure-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text--success {
|
||||||
|
color: $success-color;
|
||||||
|
}
|
6
client/scss/_textarea.scss
Normal file
6
client/scss/_textarea.scss
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
textarea {
|
||||||
|
margin: 0;
|
||||||
|
padding: $input-padding;
|
||||||
|
display: inline-block;
|
||||||
|
width: $input-full-width;
|
||||||
|
}
|
|
@ -1,10 +1,12 @@
|
||||||
$base-color: white;
|
$base-color: white;
|
||||||
$primary-color: black;
|
$primary-color: #005da0;
|
||||||
$secondary-color: #9b9b9b;
|
$secondary-color: $primary-color;
|
||||||
$tertiary-color: #ccccc0;
|
|
||||||
$interactive-color: blue;
|
|
||||||
$success-color: green;
|
$success-color: green;
|
||||||
$failure-color: red;
|
$failure-color: red;
|
||||||
|
$grey: #9095A5;
|
||||||
|
$help-color: $grey;
|
||||||
|
$grey-border: #DDDFE4;
|
||||||
|
$shadow-color: rgba(169, 173, 186, 0.2);
|
||||||
|
|
||||||
$primary-padding: 3em;
|
$primary-padding: 3em;
|
||||||
$secondary-padding: 2em;
|
$secondary-padding: 2em;
|
||||||
|
@ -12,8 +14,10 @@ $tertiary-padding: 1em;
|
||||||
$thin-padding: 0.3em;
|
$thin-padding: 0.3em;
|
||||||
$full-width-thin-padding: calc(100% - 0.6em);
|
$full-width-thin-padding: calc(100% - 0.6em);
|
||||||
|
|
||||||
|
$width-content-constrained: 1000px;
|
||||||
|
|
||||||
$background-color: $base-color;
|
$background-color: $base-color;
|
||||||
$font-color: $primary-color;
|
$text-color: #333;
|
||||||
|
|
||||||
$button-border-width: 1px;
|
$button-border-width: 1px;
|
||||||
$button-border-strength: solid;
|
$button-border-strength: solid;
|
||||||
|
@ -23,16 +27,14 @@ $input-padding: 0.3em;
|
||||||
$input-full-width: calc(100% - 0.6em);
|
$input-full-width: calc(100% - 0.6em);
|
||||||
|
|
||||||
$text-xx-large: 2.5em;
|
$text-xx-large: 2.5em;
|
||||||
$text-x-large: xx-large;
|
$text-x-large: 2.0em;
|
||||||
$text-large: x-large;
|
$text-large: 1.5em;
|
||||||
$text-medium: large;
|
$text-medium: 1.0em;
|
||||||
$text-small: medium;
|
$text-small: 0.9em;
|
||||||
$text-x-small: small;
|
$text-x-small: 0.8em;
|
||||||
|
|
||||||
$break-point-xx-large: 1400px;
|
$break-point-xx-large: 1400px;
|
||||||
$break-point-x-large: 1290px;
|
$break-point-x-large: 1290px;
|
||||||
$break-point-large: 1000px;
|
$break-point-large: 1000px;
|
||||||
$break-point-medium: 800px;
|
$break-point-tablet: 800px;
|
||||||
$break-point-small: 500px;
|
$break-point-mobile: 500px;
|
||||||
$break-point-x-small: 400px;
|
|
||||||
|
|
|
@ -1,48 +1,44 @@
|
||||||
@import '~variables/_variables';
|
@import '_variables';
|
||||||
@import '~reset/_reset';
|
@import '_reset';
|
||||||
@import '~font/_font';
|
@import 'font/_font.scss';
|
||||||
@import '~html/_html';
|
@import '_html';
|
||||||
@import '~body/_body';
|
@import '_body';
|
||||||
@import '~react-app/_react-app';
|
@import '_react-app';
|
||||||
@import '~text/_text';
|
@import '_text';
|
||||||
|
|
||||||
@import '~link/_link';
|
@import '_link';
|
||||||
@import '~input/_input';
|
@import '_input';
|
||||||
@import '~select/_select';
|
@import '_select';
|
||||||
@import '~textarea/_textarea';
|
@import '_textarea';
|
||||||
@import '~video/_video';
|
@import '_video';
|
||||||
|
@import '_form';
|
||||||
|
|
||||||
@import '~asset-display/_asset-display';
|
@import '_asset-display';
|
||||||
@import '~asset-preview/_asset-preview';
|
@import '_asset-preview';
|
||||||
@import '~button/_button';
|
@import '_button';
|
||||||
@import '~button-primary/_button-primary';
|
@import '_button-primary';
|
||||||
@import '~button-secondary/_button-secondary';
|
@import '_button-secondary';
|
||||||
@import '~button-tertiary/_button-tertiary';
|
@import '_click-to-copy';
|
||||||
@import '~click-to-copy/_click-to-copy';
|
@import '_form-feedback';
|
||||||
@import '~column/_column';
|
@import '_horizontal-split';
|
||||||
@import '~form-feedback/_form-feedback';
|
@import '_label';
|
||||||
@import '~horizontal-quad-split/_horizontal-quad-split';
|
@import '_nav-bar';
|
||||||
@import '~horizontal-split/_horizontal-split';
|
@import '_page-layout';
|
||||||
@import '~label/_label';
|
@import '_page-layout-show-lite';
|
||||||
@import '~nav-bar/_nav-bar';
|
@import '_page-content';
|
||||||
@import '~page-layout/_page-layout';
|
@import '_progress-bar';
|
||||||
@import '~page-layout-show-lite/_page-layout-show-lite';
|
@import '_publish-preview';
|
||||||
@import '~page-content/_page-content';
|
@import '_share-buttons';
|
||||||
@import '~progress-bar/_progress-bar';
|
@import '_space-between';
|
||||||
@import '~publish-preview/_publish-preview';
|
@import '_space-around';
|
||||||
@import '~space-between/_space-between';
|
@import '_row';
|
||||||
@import '~space-around/_space-around';
|
@import '_tooltip';
|
||||||
@import '~row/_row';
|
@import '_social-share-link';
|
||||||
@import '~vertical-split/_vertical-split';
|
|
||||||
@import '~tooltip/_tooltip';
|
|
||||||
@import '~social-share-link/_social-share-link';
|
|
||||||
|
|
||||||
@import '~channel-claims-display/_channel-claims-display';
|
|
||||||
@import '~dropzone/_dropzone';
|
|
||||||
@import '~publish-url-input/_publish-url-input';
|
|
||||||
@import '~publish-status/_publish-status';
|
|
||||||
@import '~publish-disabled-message/_publish-disabled-message';
|
|
||||||
|
|
||||||
@import '~media-queries/_media-queries';
|
|
||||||
|
|
||||||
|
@import '_channel-claims-display';
|
||||||
|
@import '_dropzone';
|
||||||
|
@import '_publish-url-input';
|
||||||
|
@import '_publish-status';
|
||||||
|
@import '_publish-disabled-message';
|
||||||
|
|
||||||
|
@import '_media-queries';
|
||||||
|
|
|
@ -1,22 +0,0 @@
|
||||||
.asset-display {
|
|
||||||
display: flex;
|
|
||||||
flex: 1 0 auto;
|
|
||||||
flex-direction: column;
|
|
||||||
justify-content: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.asset-image, .asset-video {
|
|
||||||
margin : 0;
|
|
||||||
max-width: 100%;
|
|
||||||
max-height: 100%;
|
|
||||||
object-fit: contain;
|
|
||||||
object-position: center;
|
|
||||||
}
|
|
||||||
.asset-video {
|
|
||||||
border: 1px solid #d0d0d0;
|
|
||||||
margin: 16px;
|
|
||||||
padding: 6px;
|
|
||||||
}
|
|
||||||
.vertical-split .asset-display {
|
|
||||||
height: 90vh;
|
|
||||||
}
|
|
|
@ -1,34 +0,0 @@
|
||||||
.button-primary, .button-primary:focus, .button-primary:active {
|
|
||||||
border: $button-border-width $button-border-strength $primary-color;
|
|
||||||
margin-top: $thin-padding;
|
|
||||||
margin-bottom: $thin-padding;
|
|
||||||
padding: $thin-padding;
|
|
||||||
color: $primary-color;
|
|
||||||
background-color: $background-color;
|
|
||||||
outline: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button-primary:focus {
|
|
||||||
border-color: $secondary-color;
|
|
||||||
background-color: $tertiary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.button-primary:hover {
|
|
||||||
border-color: $interactive-color;
|
|
||||||
color: $background-color;
|
|
||||||
background-color: $interactive-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button-primary:active{
|
|
||||||
border-color: $background-color;
|
|
||||||
color: $secondary-color;
|
|
||||||
background-color: $tertiary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button-primary--jumbo, .button-primary--jumbo:focus, .button-primary--jumbo:active {
|
|
||||||
width: $button-full-width;
|
|
||||||
padding-top: $secondary-padding;
|
|
||||||
padding-bottom: $secondary-padding;
|
|
||||||
font-size: x-large;
|
|
||||||
}
|
|
|
@ -1,21 +0,0 @@
|
||||||
.button--secondary, .button--secondary:focus {
|
|
||||||
border: 0;
|
|
||||||
border-bottom: $button-border-width $button-border-strength $primary-color;
|
|
||||||
padding: 0.5em;
|
|
||||||
color: $primary-color;
|
|
||||||
background-color: $background-color;
|
|
||||||
outline: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--secondary:focus{
|
|
||||||
border-color: $secondary-color;
|
|
||||||
background-color: $tertiary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--secondary:hover {
|
|
||||||
color: $interactive-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--secondary:active {
|
|
||||||
color: $background-color;
|
|
||||||
}
|
|
|
@ -1,14 +0,0 @@
|
||||||
.button--tertiary, .button--tertiary:focus, .button--tertiary:active {
|
|
||||||
border: 0;
|
|
||||||
color: $secondary-color;
|
|
||||||
background-color: $background-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--tertiary:hover {
|
|
||||||
color: $primary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.button--tertiary:active, .button--tertiary:focus {
|
|
||||||
color: $secondary-color;
|
|
||||||
background-color: $tertiary-color;
|
|
||||||
}
|
|
|
@ -1,3 +0,0 @@
|
||||||
button {
|
|
||||||
cursor: pointer;
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
.click-to-copy {
|
|
||||||
cursor: pointer;
|
|
||||||
border: 1px solid black;
|
|
||||||
padding: 0.5em;
|
|
||||||
margin: 0;
|
|
||||||
color: black;
|
|
||||||
background-color: white;
|
|
||||||
width: calc(100% - 1em - 2px);
|
|
||||||
}
|
|
|
@ -1,4 +0,0 @@
|
||||||
.column {
|
|
||||||
padding-left: $primary-padding;
|
|
||||||
padding-right: $primary-padding;
|
|
||||||
}
|
|
BIN
client/scss/font/Circular/CircularStd-Bold.ttf
Normal file
BIN
client/scss/font/Circular/CircularStd-Bold.ttf
Normal file
Binary file not shown.
BIN
client/scss/font/Circular/CircularStd-Book.ttf
Normal file
BIN
client/scss/font/Circular/CircularStd-Book.ttf
Normal file
Binary file not shown.
|
@ -16,3 +16,16 @@
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
font-style: italic;
|
font-style: italic;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@font-face {
|
||||||
|
font-family: 'Circular';
|
||||||
|
src: url('./font/Circular/CircularStd-Book.ttf');
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
@font-face {
|
||||||
|
font-family: 'Circular';
|
||||||
|
src: url('./font/Circular/CircularStd-Bold.ttf');
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
|
@ -1,53 +0,0 @@
|
||||||
.horizontal-quad-split {
|
|
||||||
display : flex;
|
|
||||||
flex-direction : row;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items : flex-start;
|
|
||||||
.left-side, .right-side {
|
|
||||||
width : 50%;
|
|
||||||
display : flex;
|
|
||||||
flex-direction : row;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items : flex-start;
|
|
||||||
.column-a, .column-b, .column-c, .column-d {
|
|
||||||
width: 50%;
|
|
||||||
};
|
|
||||||
.column-a, .column-b, .column-c {
|
|
||||||
padding-right: $secondary-padding;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@media (max-width: $break-point-large ) {
|
|
||||||
|
|
||||||
.horizontal-quad-split {
|
|
||||||
flex-direction : column;
|
|
||||||
.left-side, .right-side {
|
|
||||||
width : 100%;
|
|
||||||
.column-a, .column-b, .column-c, .column-d {
|
|
||||||
width: 50%;
|
|
||||||
};
|
|
||||||
.column-b {
|
|
||||||
padding-right: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-medium ) {
|
|
||||||
|
|
||||||
.horizontal-quad-split {
|
|
||||||
flex-direction : column;
|
|
||||||
.left-side, .right-side {
|
|
||||||
flex-direction : column;
|
|
||||||
.column-a, .column-b, .column-c, .column-d {
|
|
||||||
width: 100%;
|
|
||||||
padding: 0;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,28 +0,0 @@
|
||||||
.horizontal-split {
|
|
||||||
display : flex;
|
|
||||||
flex-direction : row;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items : flex-start;
|
|
||||||
.column {
|
|
||||||
width: 50%;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@media (max-width: $break-point-large ) {
|
|
||||||
|
|
||||||
.horizontal-split {
|
|
||||||
display : flex;
|
|
||||||
flex-direction : column;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items : flex-start;
|
|
||||||
.column {
|
|
||||||
width: 100%;
|
|
||||||
padding-left: 0;
|
|
||||||
padding-right: 0;
|
|
||||||
padding-bottom: $secondary-padding;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
9
client/scss/icon/chevron-down.svg
Normal file
9
client/scss/icon/chevron-down.svg
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<svg width="14px" height="8px" viewBox="0 0 14 8" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
|
||||||
|
<!-- Generator: Sketch 52.2 (67145) - http://www.bohemiancoding.com/sketch -->
|
||||||
|
<title>chevron-down</title>
|
||||||
|
<desc>Created with Sketch.</desc>
|
||||||
|
<g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd" stroke-linecap="round">
|
||||||
|
<polyline id="chevron-down" stroke="#000000" stroke-width="1.2" fill-rule="nonzero" points="13 1 7 7 1 1"></polyline>
|
||||||
|
</g>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 582 B |
|
@ -1,27 +0,0 @@
|
||||||
a, a:visited {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link--primary, .link--primary:visited {
|
|
||||||
color: $interactive-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link--secondary, .link--secondary:visited {
|
|
||||||
margin: 0px;
|
|
||||||
padding: 0.3em;
|
|
||||||
color: $secondary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link--nav {
|
|
||||||
color: $primary-color;
|
|
||||||
border-bottom: 2px solid white;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link--nav:hover {
|
|
||||||
color: $interactive-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link--nav-active {
|
|
||||||
color: $interactive-color;
|
|
||||||
border-bottom: 2px solid $interactive-color;
|
|
||||||
}
|
|
|
@ -1,24 +0,0 @@
|
||||||
@media (max-width: $break-point-x-large) {
|
|
||||||
// hide site description in nav bar
|
|
||||||
.site-description {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-large ) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-medium) {
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-small) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-x-small ) {
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,12 +0,0 @@
|
||||||
.page-layout {
|
|
||||||
flex: 1 0 auto;
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
.content {
|
|
||||||
flex: 1 0 auto;
|
|
||||||
display: flex;
|
|
||||||
-webkit-flex-direction: column;
|
|
||||||
flex-direction: column;
|
|
||||||
margin: $primary-padding;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
.progress-bar--inactive {
|
|
||||||
color: $secondary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.progress-bar--active {
|
|
||||||
color: $primary-color;
|
|
||||||
}
|
|
|
@ -1,3 +0,0 @@
|
||||||
.publish-preview-dim {
|
|
||||||
opacity: 0.2;
|
|
||||||
}
|
|
|
@ -1,17 +0,0 @@
|
||||||
select {
|
|
||||||
margin: 0;
|
|
||||||
outline: none;
|
|
||||||
padding: $input-padding;
|
|
||||||
border: 0;
|
|
||||||
background-color: $background-color;
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
.select--arrow {
|
|
||||||
-moz-appearance:none;
|
|
||||||
-webkit-appearance: none;
|
|
||||||
background: url('./icon/downArrow.svg') no-repeat right;
|
|
||||||
cursor: pointer;
|
|
||||||
padding-right: 1.5em;
|
|
||||||
padding-left: $input-padding
|
|
||||||
}
|
|
|
@ -1,165 +0,0 @@
|
||||||
// set defaults
|
|
||||||
|
|
||||||
h1, h2, h3, h4, p {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
font-size: $text-xx-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
font-size: $text-x-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
font-size: $text-large;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
p, body, button, input, textarea, label, select, option {
|
|
||||||
font-family: 'Lekton', monospace;
|
|
||||||
font-size: $text-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--extra-large {
|
|
||||||
font-size: $text-xx-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--large {
|
|
||||||
font-size: $text-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--medium {
|
|
||||||
font-size: $text-medium;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--small {
|
|
||||||
font-size: $text-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--extra-small {
|
|
||||||
font-size: $text-x-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--underline {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--primary {
|
|
||||||
color: $primary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--secondary {
|
|
||||||
color: $secondary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--tertiary {
|
|
||||||
color: $tertiary-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--interactive {
|
|
||||||
color: $interactive-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--failure {
|
|
||||||
color: $failure-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--success {
|
|
||||||
color: $success-color;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-x-large ) {
|
|
||||||
h1 {
|
|
||||||
font-size: $text-x-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
font-size: $text-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
font-size: $text-medium;
|
|
||||||
}
|
|
||||||
|
|
||||||
p, body, button, input, textarea, label, select, option {
|
|
||||||
font-size: $text-medium;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--extra-large {
|
|
||||||
font-size: $text-x-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--large {
|
|
||||||
font-size: $text-medium;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--medium {
|
|
||||||
font-size: $text-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-medium) {
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
font-size: $text-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
font-size: $text-medium;
|
|
||||||
}
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
font-size: $text-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
p, body, button, input, textarea, label, select, option {
|
|
||||||
font-size: $text-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--extra-large {
|
|
||||||
font-size: $text-large;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--large {
|
|
||||||
font-size: $text-medium;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--small {
|
|
||||||
font-size: $text-x-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $break-point-x-small) {
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
font-size: $text-medium;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
font-size: $text-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
p, body, button, input, textarea, label, select, option {
|
|
||||||
font-size: $text-x-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--extra-large {
|
|
||||||
font-size: $text-x-small;
|
|
||||||
font-weight: bold;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--large {
|
|
||||||
font-size: $text-x-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text--medium {
|
|
||||||
font-size: $text-x-small;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -1,10 +0,0 @@
|
||||||
textarea {
|
|
||||||
margin: 0;
|
|
||||||
outline: none;
|
|
||||||
padding: $input-padding;
|
|
||||||
border: 0;
|
|
||||||
border-bottom: 1px solid $secondary-color;
|
|
||||||
background-color: $background-color;
|
|
||||||
display: inline-block;
|
|
||||||
width: $input-full-width;
|
|
||||||
}
|
|
|
@ -1,7 +0,0 @@
|
||||||
.vertical-split {
|
|
||||||
flex : 1 0 auto;
|
|
||||||
display : flex;
|
|
||||||
flex-direction : column;
|
|
||||||
justify-content: space-between;
|
|
||||||
align-items : center;
|
|
||||||
};
|
|
|
@ -7,9 +7,9 @@ const AboutSpeechDetails = () => {
|
||||||
<div>
|
<div>
|
||||||
<Row>
|
<Row>
|
||||||
<p className={'text--large'}>
|
<p className={'text--large'}>
|
||||||
<Link to='/tos'>Terms of Service</Link>
|
<Link className={'link--primary'} to='/tos'>Terms of Service</Link>
|
||||||
<br />
|
<br />
|
||||||
<Link to='/faq'>Frequently Asked Questions</Link>
|
<Link className={'link--primary'} to='/faq'>Frequently Asked Questions</Link>
|
||||||
</p>
|
</p>
|
||||||
</Row>
|
</Row>
|
||||||
<Row>
|
<Row>
|
||||||
|
|
|
@ -8,18 +8,12 @@ const AboutSpeechOverview = () => {
|
||||||
<p className={'text--extra-large'}>Spee.ch is an open-source project. Please contribute to the existing site, or fork it and make your own.</p>
|
<p className={'text--extra-large'}>Spee.ch is an open-source project. Please contribute to the existing site, or fork it and make your own.</p>
|
||||||
</Row>
|
</Row>
|
||||||
<Row>
|
<Row>
|
||||||
<p className={'text--large'}>
|
<div className={'text--large'}>
|
||||||
<a className='link--primary' target='_blank' href='https://twitter.com/spee_ch'>TWITTER</a>
|
<a className='link--primary' target='_blank' href='https://twitter.com/spee_ch'>TWITTER</a><br/>
|
||||||
</p>
|
<a className='link--primary' target='_blank' href='https://github.com/lbryio/spee.ch'>GITHUB</a><br/>
|
||||||
<p className={'text--large'}>
|
<a className='link--primary' target='_blank' href='https://discord.gg/YjYbwhS'>DISCORD CHANNEL</a><br/>
|
||||||
<a className='link--primary' target='_blank' href='https://github.com/lbryio/spee.ch'>GITHUB</a>
|
<a className='link--primary' target='_blank' href='https://github.com/lbryio/spee.ch/blob/master/README.md'>DOCUMENTATION</a><br/>
|
||||||
</p>
|
</div>
|
||||||
<p className={'text--large'}>
|
|
||||||
<a className='link--primary' target='_blank' href='https://discord.gg/YjYbwhS'>DISCORD CHANNEL</a>
|
|
||||||
</p>
|
|
||||||
<p className={'text--large'}>
|
|
||||||
<a className='link--primary' target='_blank' href='https://github.com/lbryio/spee.ch/blob/master/README.md'>DOCUMENTATION</a>
|
|
||||||
</p>
|
|
||||||
</Row>
|
</Row>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
14
client/src/components/AssetInfoFooter/index.js
Normal file
14
client/src/components/AssetInfoFooter/index.js
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
import React from 'react';
|
||||||
|
import Row from '@components/Row';
|
||||||
|
|
||||||
|
const AssetInfoFooter = ({ assetUrl, name }) => {
|
||||||
|
return (
|
||||||
|
<div className='asset-footer'>
|
||||||
|
<p>
|
||||||
|
Hosted via the <a className={'link--primary'} href={'https://lbry.io/get'} target={'_blank'}>LBRY</a> blockchain
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default AssetInfoFooter;
|
|
@ -5,49 +5,53 @@ const AssetShareButtons = ({ assetUrl, name }) => {
|
||||||
return (
|
return (
|
||||||
<SocialShareLink >
|
<SocialShareLink >
|
||||||
<a
|
<a
|
||||||
className='link--primary'
|
className='link--primary twitter'
|
||||||
target='_blank'
|
target='_blank'
|
||||||
href={`https://twitter.com/intent/tweet?text=${assetUrl}`}
|
href={`https://twitter.com/intent/tweet?text=${assetUrl}`}
|
||||||
>
|
>
|
||||||
twitter
|
<img src='/assets/img/icn_twitter.svg' />
|
||||||
</a>
|
</a>
|
||||||
<a
|
<a
|
||||||
className='link--primary'
|
className='link--primary facebook'
|
||||||
target='_blank'
|
target='_blank'
|
||||||
href={`https://www.facebook.com/sharer/sharer.php?u=${assetUrl}`}
|
href={`https://www.facebook.com/sharer/sharer.php?u=${assetUrl}`}
|
||||||
>
|
>
|
||||||
facebook
|
<img src='/assets/img/icn_facebook.svg' />
|
||||||
</a>
|
</a>
|
||||||
<a
|
<a
|
||||||
className='link--primary'
|
className='link--primary tumblr'
|
||||||
target='_blank'
|
target='_blank'
|
||||||
href={`https://tumblr.com/widgets/share/tool?canonicalUrl=${assetUrl}`}
|
href={`https://tumblr.com/widgets/share/tool?canonicalUrl=${assetUrl}`}
|
||||||
>
|
>
|
||||||
tumblr
|
<img src='/assets/img/icn_tumblr.svg' />
|
||||||
</a>
|
</a>
|
||||||
<a
|
<a
|
||||||
className='link--primary'
|
className='link--primary reddit'
|
||||||
target='_blank'
|
target='_blank'
|
||||||
href={`https://www.reddit.com/submit?url=${assetUrl}&title=${name}`}
|
href={`https://www.reddit.com/submit?url=${assetUrl}&title=${name}`}
|
||||||
>
|
>
|
||||||
reddit
|
<img src='/assets/img/icn_reddit.svg' />
|
||||||
</a>
|
|
||||||
<a
|
|
||||||
className='link--primary'
|
|
||||||
target='_blank'
|
|
||||||
href={`https://sharetomastodon.github.io/?title=${name}&url=${assetUrl}`}
|
|
||||||
>
|
|
||||||
mastodon
|
|
||||||
</a>
|
|
||||||
<a
|
|
||||||
className='link--primary'
|
|
||||||
target='_blank'
|
|
||||||
href={`https://share.diasporafoundation.org/?title=${name}&url=${assetUrl}`}
|
|
||||||
>
|
|
||||||
diaspora
|
|
||||||
</a>
|
</a>
|
||||||
</SocialShareLink>
|
</SocialShareLink>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
//
|
||||||
|
// Additional icons disabled. If you want to add additional icons, you have to solve
|
||||||
|
// https://github.com/lbryio/spee.ch/issues/687
|
||||||
|
//
|
||||||
|
// <a
|
||||||
|
// className='link--primary'
|
||||||
|
// target='_blank'
|
||||||
|
// href={`https://sharetomastodon.github.io/?title=${name}&url=${assetUrl}`}
|
||||||
|
// >
|
||||||
|
// mastodon
|
||||||
|
// </a>
|
||||||
|
// <a
|
||||||
|
// className='link--primary'
|
||||||
|
// target='_blank'
|
||||||
|
// href={`https://share.diasporafoundation.org/?title=${name}&url=${assetUrl}`}
|
||||||
|
// >
|
||||||
|
// diaspora
|
||||||
|
// </a>
|
||||||
|
|
||||||
export default AssetShareButtons;
|
export default AssetShareButtons;
|
||||||
|
|
|
@ -4,7 +4,7 @@ const ButtonPrimary = ({ value, onClickHandler, type = 'button' }) => {
|
||||||
return (
|
return (
|
||||||
<button
|
<button
|
||||||
type={type}
|
type={type}
|
||||||
className={'button button-primary'}
|
className={'button button--primary'}
|
||||||
onClick={onClickHandler}
|
onClick={onClickHandler}
|
||||||
>
|
>
|
||||||
{value}
|
{value}
|
||||||
|
|
|
@ -3,7 +3,7 @@ import React from 'react';
|
||||||
const ButtonPrimaryJumbo = ({ value, onClickHandler }) => {
|
const ButtonPrimaryJumbo = ({ value, onClickHandler }) => {
|
||||||
return (
|
return (
|
||||||
<button
|
<button
|
||||||
className={'button button-primary button-primary--jumbo'}
|
className={'button button--primary button--jumbo'}
|
||||||
onClick={onClickHandler}
|
onClick={onClickHandler}
|
||||||
>
|
>
|
||||||
{value}
|
{value}
|
||||||
|
|
|
@ -1,14 +0,0 @@
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
const ButtonTertiary = ({ value, onClickHandler }) => {
|
|
||||||
return (
|
|
||||||
<button
|
|
||||||
className={'button button--tertiary'}
|
|
||||||
onClick={onClickHandler}
|
|
||||||
>
|
|
||||||
{value}
|
|
||||||
</button>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
export default ButtonTertiary;
|
|
|
@ -2,8 +2,9 @@ import React from 'react';
|
||||||
|
|
||||||
const ChannelAbout = () => {
|
const ChannelAbout = () => {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div className={'text--large'}>
|
||||||
<p className={'text--large'}>Channels allow you to publish and group content under an identity. You can create a channel for yourself, or share one with like-minded friends. You can create 1 channel, or 100, so whether you're <a className='link--primary' target='_blank' href='/@catalonia2017:43dcf47163caa21d8404d9fe9b30f78ef3e146a8'>documenting important events</a>, or making a public repository for <a className='link--primary' target='_blank' href='/@catGifs'>cat gifs</a> (password: '1234'), try creating a channel for it!</p>
|
<p>Channels allow you to publish and group content under an identity. You can create a channel for yourself, or share one with like-minded friends.</p>
|
||||||
|
<p>You can create 1 channel, or 100, so whether you're <a className='link--primary' target='_blank' href='/@catalonia2017:43dcf47163caa21d8404d9fe9b30f78ef3e146a8'>documenting important events</a>, or making a public repository for <a className='link--primary' target='_blank' href='/@catGifs'>cat gifs</a> (password: '1234'), try creating a channel for it!</p>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
|
@ -5,7 +5,6 @@ const ChannelSelectDropdown = ({ selectedChannel, handleSelection, loggedInChann
|
||||||
return (
|
return (
|
||||||
<select
|
<select
|
||||||
id='channel-name-select'
|
id='channel-name-select'
|
||||||
className='select select--arrow'
|
|
||||||
value={selectedChannel}
|
value={selectedChannel}
|
||||||
onChange={handleSelection}>
|
onChange={handleSelection}>
|
||||||
{ loggedInChannelName && (
|
{ loggedInChannelName && (
|
||||||
|
|
|
@ -1,13 +1,15 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import * as Icon from 'react-feather';
|
||||||
|
|
||||||
class ClickToCopy extends React.Component {
|
class ClickToCopy extends React.Component {
|
||||||
constructor (props) {
|
constructor (props) {
|
||||||
super(props);
|
super(props);
|
||||||
this.copyToClipboard = this.copyToClipboard.bind(this);
|
this.copyToClipboard = this.copyToClipboard.bind(this);
|
||||||
}
|
}
|
||||||
copyToClipboard (event) {
|
copyToClipboard () {
|
||||||
const elementToCopy = event.target.id;
|
const elementToCopy = this.props.id;
|
||||||
const element = document.getElementById(elementToCopy);
|
const element = document.getElementById(elementToCopy);
|
||||||
|
console.log(elementToCopy);
|
||||||
element.select();
|
element.select();
|
||||||
try {
|
try {
|
||||||
document.execCommand('copy');
|
document.execCommand('copy');
|
||||||
|
@ -18,15 +20,22 @@ class ClickToCopy extends React.Component {
|
||||||
render () {
|
render () {
|
||||||
const {id, value} = this.props;
|
const {id, value} = this.props;
|
||||||
return (
|
return (
|
||||||
|
<div
|
||||||
|
className='click-to-copy-wrap'
|
||||||
|
onClick={this.copyToClipboard}
|
||||||
|
>
|
||||||
<input
|
<input
|
||||||
id={id}
|
id={id}
|
||||||
value={value}
|
value={value}
|
||||||
onClick={this.copyToClipboard}
|
|
||||||
type='text'
|
type='text'
|
||||||
className='click-to-copy'
|
className='click-to-copy'
|
||||||
readOnly
|
readOnly
|
||||||
spellCheck='false'
|
spellCheck='false'
|
||||||
/>
|
/>
|
||||||
|
<div className='icon-wrap'>
|
||||||
|
<Icon.Copy />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
import React from 'react';
|
|
||||||
|
|
||||||
class Column extends React.Component {
|
|
||||||
render () {
|
|
||||||
return (
|
|
||||||
<div className={'column'}>
|
|
||||||
{this.props.children}
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default Column;
|
|
|
@ -3,7 +3,7 @@ import React from 'react';
|
||||||
const DropzoneDropItDisplay = () => {
|
const DropzoneDropItDisplay = () => {
|
||||||
return (
|
return (
|
||||||
<div className={'dropzone-dropit-display'}>
|
<div className={'dropzone-dropit-display'}>
|
||||||
<p className={'text--interactive'}>Drop it.</p>
|
Drop it.
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,15 +9,15 @@ const DropzoneInstructionsDisplay = ({fileError, message}) => {
|
||||||
return (
|
return (
|
||||||
<div className={'dropzone-instructions-display'}>
|
<div className={'dropzone-instructions-display'}>
|
||||||
<Row>
|
<Row>
|
||||||
<p className={'text--large'}>{message}</p>
|
<span className={'text--large'}>{message}</span>
|
||||||
</Row>
|
</Row>
|
||||||
<Row>
|
<Row>
|
||||||
<p className={'text--small'}>OR</p>
|
<span className={'text--small text--secondary'}>OR</span>
|
||||||
</Row>
|
</Row>
|
||||||
{ fileError ? (
|
{ fileError ? (
|
||||||
<div>
|
<div>
|
||||||
<Row>
|
<Row>
|
||||||
<p className={'text--large text--underline'}>CHOOSE FILE</p>
|
<span className={'text--large dropzone-instructions-display__chooser-label'}>CHOOSE FILE</span>
|
||||||
</Row>
|
</Row>
|
||||||
<FormFeedbackDisplay
|
<FormFeedbackDisplay
|
||||||
errorMessage={fileError}
|
errorMessage={fileError}
|
||||||
|
@ -25,7 +25,7 @@ const DropzoneInstructionsDisplay = ({fileError, message}) => {
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<p className={'text--large text--underline'}>CHOOSE FILE</p>
|
<span className={'text--large dropzone-instructions-display__chooser-label'}>CHOOSE FILE</span>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,21 +1,21 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
|
||||||
const FormFeedbackDisplay = ({ errorMessage, defaultMessage }) => {
|
const FormFeedbackDisplay = ({ errorMessage, defaultMessage }) => {
|
||||||
return (
|
return (errorMessage || defaultMessage) ? (
|
||||||
<div className={'form-feedback'}>
|
<div className={'form-feedback'}>
|
||||||
{ errorMessage ? (
|
{ errorMessage ? (
|
||||||
<p className={'text--small text--failure'}>{errorMessage}</p>
|
<span className={'text--small text--failure'}>{errorMessage}</span>
|
||||||
) : (
|
) : (
|
||||||
<div>
|
<div>
|
||||||
{ defaultMessage ? (
|
{ defaultMessage ? (
|
||||||
<p className={'text--small text--secondary'}>{defaultMessage}</p>
|
<span className={'text--small text--secondary'}>{defaultMessage}</span>
|
||||||
) : (
|
) : (
|
||||||
<p className={'text--small'}> </p>
|
<span className={'text--small'}> </span>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
) : null;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default FormFeedbackDisplay;
|
export default FormFeedbackDisplay;
|
||||||
|
|
|
@ -1,37 +0,0 @@
|
||||||
import React from 'react';
|
|
||||||
import Row from '@components/Row';
|
|
||||||
|
|
||||||
class HorizontalTriSplit extends React.Component {
|
|
||||||
render () {
|
|
||||||
return (
|
|
||||||
<div className={'horizontal-quad-split'}>
|
|
||||||
<div className={'left-side'}>
|
|
||||||
<div className={'column-a'}>
|
|
||||||
<Row>
|
|
||||||
{this.props.columnA}
|
|
||||||
</Row>
|
|
||||||
</div>
|
|
||||||
<div className={'column-b'}>
|
|
||||||
<Row>
|
|
||||||
{this.props.columnB}
|
|
||||||
</Row>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div className={'right-side'}>
|
|
||||||
<div className={'column-c'}>
|
|
||||||
<Row>
|
|
||||||
{this.props.columnC}
|
|
||||||
</Row>
|
|
||||||
</div>
|
|
||||||
<div className={'column-d'}>
|
|
||||||
<Row>
|
|
||||||
{this.props.columnD}
|
|
||||||
</Row>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default HorizontalTriSplit;
|
|
|
@ -2,13 +2,26 @@ import React from 'react';
|
||||||
|
|
||||||
class HorizontalSplit extends React.Component {
|
class HorizontalSplit extends React.Component {
|
||||||
render () {
|
render () {
|
||||||
|
const { leftSide, rightSide, collapseOnMobile } = this.props;
|
||||||
|
|
||||||
|
let className = 'horizontal-split';
|
||||||
|
if (collapseOnMobile) {
|
||||||
|
className += " horizontal-split--mobile-collapse";
|
||||||
|
}
|
||||||
|
|
||||||
|
// If there is no left side, move the right side to the left
|
||||||
|
// This is mostly for content with no description
|
||||||
|
// It doesn't need to be on the right side with nothing next to it.
|
||||||
|
const leftComponent = leftSide || rightSide;
|
||||||
|
const rightComponent = leftSide ? rightSide : null;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={'horizontal-split'}>
|
<div className={className}>
|
||||||
<div className={'column'}>
|
<div className={'horizontal-split__column horizontal-split__column--left'}>
|
||||||
{this.props.leftSide}
|
{leftComponent}
|
||||||
</div>
|
</div>
|
||||||
<div className={'column'}>
|
<div className={'horizontal-split__column horizontal-split__column--right'}>
|
||||||
{this.props.rightSide}
|
{rightComponent}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -10,7 +10,6 @@ class NavBar extends React.Component {
|
||||||
<div className={'nav-bar'}>
|
<div className={'nav-bar'}>
|
||||||
<SpaceBetween >
|
<SpaceBetween >
|
||||||
<Logo />
|
<Logo />
|
||||||
<SiteDescription />
|
|
||||||
<NavigationLinks />
|
<NavigationLinks />
|
||||||
</SpaceBetween>
|
</SpaceBetween>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -6,7 +6,6 @@ function NavBarChannelDropdown ({ channelName, handleSelection, defaultSelection
|
||||||
<select
|
<select
|
||||||
type='text'
|
type='text'
|
||||||
id='nav-bar-channel-select'
|
id='nav-bar-channel-select'
|
||||||
className='select select--arrow'
|
|
||||||
onChange={handleSelection}
|
onChange={handleSelection}
|
||||||
value={defaultSelection}
|
value={defaultSelection}
|
||||||
>
|
>
|
||||||
|
|
|
@ -62,7 +62,7 @@ class ProgressBar extends React.Component {
|
||||||
};
|
};
|
||||||
render () {
|
render () {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div className="progress-bar__wrapper">
|
||||||
{this.state.bars.map((bar, index) => bar.isActive ? <ActiveStatusBar key={index} /> : <InactiveStatusBar key={index}/>)}
|
{this.state.bars.map((bar, index) => bar.isActive ? <ActiveStatusBar key={index} /> : <InactiveStatusBar key={index}/>)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|
|
@ -13,7 +13,6 @@ const PublishLicenseInput = ({ handleSelect }) => {
|
||||||
type='text'
|
type='text'
|
||||||
name='license'
|
name='license'
|
||||||
id='publish-license'
|
id='publish-license'
|
||||||
className='select select--primary'
|
|
||||||
onChange={handleSelect}
|
onChange={handleSelect}
|
||||||
>
|
>
|
||||||
<option value=''>Unspecified</option>
|
<option value=''>Unspecified</option>
|
||||||
|
|
|
@ -5,16 +5,21 @@ import PublishDetails from '@containers/PublishDetails';
|
||||||
import PublishTitleInput from '@containers/PublishTitleInput';
|
import PublishTitleInput from '@containers/PublishTitleInput';
|
||||||
import Row from '@components/Row';
|
import Row from '@components/Row';
|
||||||
|
|
||||||
|
// this class seems more like PublishForm and should probably be renamed
|
||||||
|
|
||||||
class PublishPreview extends React.Component {
|
class PublishPreview extends React.Component {
|
||||||
render () {
|
render () {
|
||||||
const { isUpdate, uri } = this.props;
|
const { isUpdate, uri } = this.props;
|
||||||
return (
|
return (
|
||||||
<div>
|
<div className={'publish-form'}>
|
||||||
|
<div className={'publish-form__title'}>
|
||||||
<Row>
|
<Row>
|
||||||
{isUpdate && uri && (<p className='text--extra-small'>{`Editing ${uri}`}</p>)}
|
{isUpdate && uri && (<p className='text--secondary'>{`Editing ${uri}`}</p>)}
|
||||||
<PublishTitleInput />
|
<PublishTitleInput />
|
||||||
</Row>
|
</Row>
|
||||||
|
</div>
|
||||||
<HorizontalSplit
|
<HorizontalSplit
|
||||||
|
collapseOnMobile
|
||||||
leftSide={<Dropzone />}
|
leftSide={<Dropzone />}
|
||||||
rightSide={<PublishDetails />}
|
rightSide={<PublishDetails />}
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -6,10 +6,12 @@ import Row from '@components/Row';
|
||||||
import SpaceBetween from '@components/SpaceBetween';
|
import SpaceBetween from '@components/SpaceBetween';
|
||||||
import AssetShareButtons from '@components/AssetShareButtons';
|
import AssetShareButtons from '@components/AssetShareButtons';
|
||||||
import ClickToCopy from '@components/ClickToCopy';
|
import ClickToCopy from '@components/ClickToCopy';
|
||||||
|
import HorizontalSplit from '@components/HorizontalSplit';
|
||||||
|
|
||||||
import siteConfig from '@config/siteConfig.json';
|
import siteConfig from '@config/siteConfig.json';
|
||||||
const { details: { host } } = siteConfig;
|
const { details: { host } } = siteConfig;
|
||||||
import createCanonicalLink from '../../../../utils/createCanonicalLink';
|
import createCanonicalLink from '../../../../utils/createCanonicalLink';
|
||||||
|
import AssetInfoFooter from '../../components/AssetInfoFooter/index';
|
||||||
|
|
||||||
class AssetInfo extends React.Component {
|
class AssetInfo extends React.Component {
|
||||||
render () {
|
render () {
|
||||||
|
@ -29,36 +31,37 @@ class AssetInfo extends React.Component {
|
||||||
channelCanonicalUrl = `${createCanonicalLink({channel})}`;
|
channelCanonicalUrl = `${createCanonicalLink({channel})}`;
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
|
<div className='asset-info'>
|
||||||
|
<HorizontalSplit
|
||||||
|
leftSide={
|
||||||
|
description && (
|
||||||
|
<p className='asset-info__description'>{description}</p>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
rightSide={
|
||||||
<div>
|
<div>
|
||||||
{editable && (
|
{editable && (
|
||||||
<Row>
|
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={<Label value={'Edit:'} />}
|
label={<Label value={'Edit:'} />}
|
||||||
content={<Link to={`/edit${canonicalUrl}`}>{name}</Link>}
|
content={<Link to={`/edit${canonicalUrl}`}>{name}</Link>}
|
||||||
/>
|
/>
|
||||||
</Row>
|
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{channelName && (
|
{channelName && (
|
||||||
<Row>
|
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<Label value={'Channel:'} />
|
<Label value={'Channel'} />
|
||||||
}
|
}
|
||||||
content={
|
content={
|
||||||
<span className='text'>
|
<span className='text'>
|
||||||
<Link to={channelCanonicalUrl}>{channelName}</Link>
|
<Link className='link--primary' to={channelCanonicalUrl}>{channelName}</Link>
|
||||||
</span>
|
</span>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
</Row>
|
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{claimViews ? (
|
{claimViews ? (
|
||||||
<Row>
|
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<Label value={'Views:'} />
|
<Label value={'Views'} />
|
||||||
}
|
}
|
||||||
content={
|
content={
|
||||||
<span className='text'>
|
<span className='text'>
|
||||||
|
@ -66,13 +69,11 @@ class AssetInfo extends React.Component {
|
||||||
</span>
|
</span>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
</Row>
|
|
||||||
) : null}
|
) : null}
|
||||||
|
|
||||||
<Row>
|
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<Label value={'Share:'} />
|
<Label value={'Share'} />
|
||||||
}
|
}
|
||||||
content={
|
content={
|
||||||
<AssetShareButtons
|
<AssetShareButtons
|
||||||
|
@ -81,12 +82,10 @@ class AssetInfo extends React.Component {
|
||||||
/>
|
/>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
</Row>
|
|
||||||
|
|
||||||
<Row>
|
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<Label value={'Link:'} />
|
<Label value={'Link'} />
|
||||||
}
|
}
|
||||||
content={
|
content={
|
||||||
<ClickToCopy
|
<ClickToCopy
|
||||||
|
@ -95,12 +94,10 @@ class AssetInfo extends React.Component {
|
||||||
/>
|
/>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
</Row>
|
|
||||||
|
|
||||||
<Row>
|
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<Label value={'Embed:'} />
|
<Label value={'Embed'} />
|
||||||
}
|
}
|
||||||
content={
|
content={
|
||||||
<div>
|
<div>
|
||||||
|
@ -118,9 +115,7 @@ class AssetInfo extends React.Component {
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
</Row>
|
|
||||||
|
|
||||||
<Row>
|
|
||||||
<SpaceBetween>
|
<SpaceBetween>
|
||||||
<a
|
<a
|
||||||
className='link--primary'
|
className='link--primary'
|
||||||
|
@ -143,20 +138,9 @@ class AssetInfo extends React.Component {
|
||||||
Report
|
Report
|
||||||
</a>
|
</a>
|
||||||
</SpaceBetween>
|
</SpaceBetween>
|
||||||
</Row>
|
</div>
|
||||||
|
} />
|
||||||
{description && (
|
<AssetInfoFooter/>
|
||||||
<Row>
|
|
||||||
<p>{description}</p>
|
|
||||||
</Row>
|
|
||||||
)}
|
|
||||||
|
|
||||||
<Row>
|
|
||||||
<p>
|
|
||||||
Hosted via the <a className={'link--primary'} href={'https://lbry.io/get'} target={'_blank'}>LBRY</a> blockchain
|
|
||||||
</p>
|
|
||||||
</Row>
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,12 +1,8 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Link } from 'react-router-dom';
|
|
||||||
import Row from '@components/Row';
|
|
||||||
|
|
||||||
const AssetTitle = ({ title }) => {
|
const AssetTitle = ({ title }) => {
|
||||||
return (
|
return (
|
||||||
<Row>
|
<h1 className='asset-title'>{title}</h1>
|
||||||
<h3>{title}</h3>
|
|
||||||
</Row>
|
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -59,7 +59,7 @@ class ChannelCreateForm extends React.Component {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
{ !status ? (
|
{ !status ? (
|
||||||
<form onSubmit={this.handleSubmit}>
|
<form className="form-group" onSubmit={this.handleSubmit}>
|
||||||
<ChannelCreateNameInput
|
<ChannelCreateNameInput
|
||||||
value={name.value}
|
value={name.value}
|
||||||
error={name.error}
|
error={name.error}
|
||||||
|
@ -69,10 +69,7 @@ class ChannelCreateForm extends React.Component {
|
||||||
value={password.value}
|
value={password.value}
|
||||||
handlePasswordInput={this.handlePasswordInput}
|
handlePasswordInput={this.handlePasswordInput}
|
||||||
/>
|
/>
|
||||||
<FormFeedbackDisplay
|
<FormFeedbackDisplay errorMessage={formError} />
|
||||||
errorMessage={formError}
|
|
||||||
defaultMessage={'Choose a name and password for your channel'}
|
|
||||||
/>
|
|
||||||
<ButtonPrimary
|
<ButtonPrimary
|
||||||
type={'submit'}
|
type={'submit'}
|
||||||
value={'Create Channel'}
|
value={'Create Channel'}
|
||||||
|
@ -81,7 +78,7 @@ class ChannelCreateForm extends React.Component {
|
||||||
</form>
|
</form>
|
||||||
) : (
|
) : (
|
||||||
<div>
|
<div>
|
||||||
<p className={'text--small text--secondary'}>{status}</p>
|
<span className={'text--small text--secondary'}>{status}</span>
|
||||||
<ProgressBar size={12} />
|
<ProgressBar size={12} />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|
|
@ -49,7 +49,7 @@ class ChannelLoginForm extends React.Component {
|
||||||
}
|
}
|
||||||
render () {
|
render () {
|
||||||
return (
|
return (
|
||||||
<form onSubmit={this.loginToChannel}>
|
<form className="form-group" onSubmit={this.loginToChannel}>
|
||||||
<ChannelLoginNameInput
|
<ChannelLoginNameInput
|
||||||
channelName={this.state.channelName}
|
channelName={this.state.channelName}
|
||||||
handleInput={this.handleInput}
|
handleInput={this.handleInput}
|
||||||
|
@ -58,10 +58,7 @@ class ChannelLoginForm extends React.Component {
|
||||||
channelPassword={this.state.channelPassword}
|
channelPassword={this.state.channelPassword}
|
||||||
handleInput={this.handleInput}
|
handleInput={this.handleInput}
|
||||||
/>
|
/>
|
||||||
<FormFeedbackDisplay
|
<FormFeedbackDisplay errorMessage={this.state.error} />
|
||||||
errorMessage={this.state.error}
|
|
||||||
defaultMessage={'Enter the name and password for your channel'}
|
|
||||||
/>
|
|
||||||
<ButtonPrimary
|
<ButtonPrimary
|
||||||
type={'submit'}
|
type={'submit'}
|
||||||
value={'Authenticate'}
|
value={'Authenticate'}
|
||||||
|
|
|
@ -40,16 +40,16 @@ class ChannelSelect extends React.Component {
|
||||||
const { publishInChannel, channelError, selectedChannel, loggedInChannelName, publishOnlyApproved } = this.props;
|
const { publishInChannel, channelError, selectedChannel, loggedInChannelName, publishOnlyApproved } = this.props;
|
||||||
if (publishOnlyApproved) {
|
if (publishOnlyApproved) {
|
||||||
return (
|
return (
|
||||||
<div>
|
<React.Fragment>
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={<Label value={'Channel:'} />}
|
label={<Label value={'Channel:'} />}
|
||||||
content={<span>{loggedInChannelName}</span>}
|
content={<span>{loggedInChannelName}</span>}
|
||||||
/>
|
/>
|
||||||
</div>
|
</React.Fragment>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
<div>
|
<React.Fragment>
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<ChooseAnonymousPublishRadio
|
<ChooseAnonymousPublishRadio
|
||||||
|
@ -87,7 +87,7 @@ class ChannelSelect extends React.Component {
|
||||||
{ (selectedChannel === CREATE) && <ChannelCreateForm /> }
|
{ (selectedChannel === CREATE) && <ChannelCreateForm /> }
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</div>
|
</React.Fragment>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,14 +7,14 @@ class ChannelTools extends React.Component {
|
||||||
render () {
|
render () {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<Row>
|
<h3 className="form-title">Log in to existing channel</h3>
|
||||||
<h3>Log in to an existing channel:</h3>
|
|
||||||
<ChannelLoginForm />
|
<ChannelLoginForm />
|
||||||
</Row>
|
{!this.props.closedRegistration && (
|
||||||
{!this.props.closedRegistration && (<Row>
|
<React.Fragment>
|
||||||
<h3>Create a brand new channel:</h3>
|
<h3 className="form-title">Create new channel</h3>
|
||||||
<ChannelCreateForm />
|
<ChannelCreateForm />
|
||||||
</Row>)}
|
</React.Fragment>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -84,7 +84,7 @@ class Dropzone extends React.Component {
|
||||||
const { dragOver, mouseOver, dimPreview } = this.state;
|
const { dragOver, mouseOver, dimPreview } = this.state;
|
||||||
const { file, thumbnail, fileError, isUpdate, sourceUrl, fileExt } = this.props;
|
const { file, thumbnail, fileError, isUpdate, sourceUrl, fileExt } = this.props;
|
||||||
return (
|
return (
|
||||||
<div className="dropzone-wrapper">
|
<React.Fragment>
|
||||||
{isUpdate && fileExt === 'mp4' ? (
|
{isUpdate && fileExt === 'mp4' ? (
|
||||||
<p>Video updates are currently disabled. This feature will be available soon. You can edit metadata.</p>
|
<p>Video updates are currently disabled. This feature will be available soon. You can edit metadata.</p>
|
||||||
) : (
|
) : (
|
||||||
|
@ -145,7 +145,7 @@ class Dropzone extends React.Component {
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</div>
|
</React.Fragment>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
|
@ -8,7 +8,6 @@ import Row from '@components/Row';
|
||||||
import Label from '@components/Label';
|
import Label from '@components/Label';
|
||||||
import RowLabeled from '@components/RowLabeled';
|
import RowLabeled from '@components/RowLabeled';
|
||||||
import ButtonPrimaryJumbo from '@components/ButtonPrimaryJumbo';
|
import ButtonPrimaryJumbo from '@components/ButtonPrimaryJumbo';
|
||||||
import ButtonTertiary from '@components/ButtonTertiary';
|
|
||||||
import ButtonSecondary from '@components/ButtonSecondary';
|
import ButtonSecondary from '@components/ButtonSecondary';
|
||||||
import SpaceAround from '@components/SpaceAround';
|
import SpaceAround from '@components/SpaceAround';
|
||||||
import PublishFinePrint from '@components/PublishFinePrint';
|
import PublishFinePrint from '@components/PublishFinePrint';
|
||||||
|
@ -46,7 +45,7 @@ class PublishDetails extends React.Component {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
{isUpdate ? (asset && (
|
{isUpdate ? (asset && (
|
||||||
<Row>
|
<React.Fragment>
|
||||||
<RowLabeled
|
<RowLabeled
|
||||||
label={
|
label={
|
||||||
<Label value={'Channel:'} />
|
<Label value={'Channel:'} />
|
||||||
|
@ -57,16 +56,14 @@ class PublishDetails extends React.Component {
|
||||||
</span>
|
</span>
|
||||||
}
|
}
|
||||||
/>
|
/>
|
||||||
</Row>
|
</React.Fragment>
|
||||||
)) : (
|
)) : (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
<Row>
|
<Row>
|
||||||
<PublishUrlInput />
|
<PublishUrlInput />
|
||||||
</Row>
|
</Row>
|
||||||
|
|
||||||
<Row>
|
|
||||||
<ChannelSelect />
|
<ChannelSelect />
|
||||||
</Row>
|
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
|
@ -100,7 +97,7 @@ class PublishDetails extends React.Component {
|
||||||
|
|
||||||
<Row>
|
<Row>
|
||||||
<SpaceAround>
|
<SpaceAround>
|
||||||
<ButtonTertiary
|
<ButtonSecondary
|
||||||
value={'Cancel'}
|
value={'Cancel'}
|
||||||
onClickHandler={this.onCancel}
|
onClickHandler={this.onCancel}
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -3,6 +3,7 @@ import PublishDescriptionInput from '@components/PublishDescriptionInput';
|
||||||
import PublishLicenseInput from '@components/PublishLicenseInput';
|
import PublishLicenseInput from '@components/PublishLicenseInput';
|
||||||
import PublishNsfwInput from '@components/PublishNsfwInput';
|
import PublishNsfwInput from '@components/PublishNsfwInput';
|
||||||
import ButtonSecondary from '@components/ButtonSecondary';
|
import ButtonSecondary from '@components/ButtonSecondary';
|
||||||
|
import Row from '@components/Row';
|
||||||
|
|
||||||
class PublishMetadataInputs extends React.Component {
|
class PublishMetadataInputs extends React.Component {
|
||||||
constructor (props) {
|
constructor (props) {
|
||||||
|
@ -30,19 +31,19 @@ class PublishMetadataInputs extends React.Component {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
{(showMetadataInputs || isUpdate) && (
|
{(showMetadataInputs || isUpdate) && (
|
||||||
<div>
|
<React.Fragment>
|
||||||
<PublishDescriptionInput
|
<PublishDescriptionInput
|
||||||
description={description}
|
description={this.props.description}
|
||||||
handleInput={this.handleInput}
|
handleInput={this.handleInput}
|
||||||
/>
|
/>
|
||||||
<PublishLicenseInput
|
<PublishLicenseInput
|
||||||
handleSelect={this.handleSelect}
|
handleSelect={this.handleSelect}
|
||||||
/>
|
/>
|
||||||
<PublishNsfwInput
|
<PublishNsfwInput
|
||||||
nsfw={nsfw}
|
nsfw={this.props.nsfw}
|
||||||
handleInput={this.handleInput}
|
handleInput={this.handleInput}
|
||||||
/>
|
/>
|
||||||
</div>
|
</React.Fragment>
|
||||||
)}
|
)}
|
||||||
{!isUpdate && (
|
{!isUpdate && (
|
||||||
<ButtonSecondary
|
<ButtonSecondary
|
||||||
|
|
|
@ -126,7 +126,7 @@ class PublishThumbnailInput extends React.Component {
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
) : (
|
) : (
|
||||||
<p className={'text--small text--secondary'}>loading... </p>
|
<span className={'text--small text--secondary'}>loading... </span>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
<FormFeedbackDisplay
|
<FormFeedbackDisplay
|
||||||
|
|
|
@ -13,6 +13,7 @@ class AboutPage extends React.Component {
|
||||||
pageUri={'about'}
|
pageUri={'about'}
|
||||||
>
|
>
|
||||||
<HorizontalSplit
|
<HorizontalSplit
|
||||||
|
collapseOnMobile
|
||||||
leftSide={<AboutSpeechOverview />}
|
leftSide={<AboutSpeechOverview />}
|
||||||
rightSide={<AboutSpeechDetails />}
|
rightSide={<AboutSpeechDetails />}
|
||||||
/>
|
/>
|
||||||
|
|
|
@ -20,6 +20,7 @@ class LoginPage extends React.Component {
|
||||||
pageUri={'login'}
|
pageUri={'login'}
|
||||||
>
|
>
|
||||||
<HorizontalSplit
|
<HorizontalSplit
|
||||||
|
collapseOnMobile
|
||||||
leftSide={<ChannelAbout />}
|
leftSide={<ChannelAbout />}
|
||||||
rightSide={<ChannelTools />}
|
rightSide={<ChannelTools />}
|
||||||
/>
|
/>
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Add table
Reference in a new issue