Merge pull request #957 from lbryio/issue/952

Refactor lbryuri.js into separate named exports
This commit is contained in:
Liam Cardenas 2018-01-22 10:25:03 -08:00 committed by GitHub
commit c975454501
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
23 changed files with 80 additions and 88 deletions

View file

@ -1,5 +1,5 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri.js'; import { normalizeURI } from 'lbryURI';
import CardMedia from 'component/cardMedia'; import CardMedia from 'component/cardMedia';
import Link from 'component/link'; import Link from 'component/link';
import { TruncatedText } from 'component/common'; import { TruncatedText } from 'component/common';
@ -57,7 +57,7 @@ class FileCard extends React.PureComponent {
rewardedContentClaimIds, rewardedContentClaimIds,
} = this.props; } = this.props;
const uri = lbryuri.normalize(this.props.uri); const uri = normalizeURI(this.props.uri);
const title = metadata && metadata.title ? metadata.title : uri; const title = metadata && metadata.title ? metadata.title : uri;
const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null; const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null;
const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw; const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw;

View file

@ -1,5 +1,5 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri.js'; import { buildURI } from 'lbryURI';
import FormField from 'component/formField'; import FormField from 'component/formField';
import FileTile from 'component/fileTile'; import FileTile from 'component/fileTile';
import { BusyMessage } from 'component/common.js'; import { BusyMessage } from 'component/common.js';
@ -76,7 +76,7 @@ class FileList extends React.PureComponent {
uriParams.claimId = fileInfo.claim_id; uriParams.claimId = fileInfo.claim_id;
uriParams.name = fileInfo.name; uriParams.name = fileInfo.name;
} }
const uri = lbryuri.build(uriParams); const uri = buildURI(uriParams);
content.push( content.push(
<FileTile <FileTile

View file

@ -3,7 +3,7 @@ import FileTile from 'component/fileTile';
import ChannelTile from 'component/channelTile'; import ChannelTile from 'component/channelTile';
import Link from 'component/link'; import Link from 'component/link';
import { BusyMessage } from 'component/common.js'; import { BusyMessage } from 'component/common.js';
import lbryuri from 'lbryuri'; import { parseURI } from 'lbryURI';
const SearchNoResults = props => { const SearchNoResults = props => {
const { query } = props; const { query } = props;
@ -45,7 +45,7 @@ class FileListSearch extends React.PureComponent {
{uris && uris.length {uris && uris.length
? uris.map( ? uris.map(
uri => uri =>
lbryuri.parse(uri).name[0] === '@' ? ( parseURI(uri).name[0] === '@' ? (
<ChannelTile key={uri} uri={uri} /> <ChannelTile key={uri} uri={uri} />
) : ( ) : (
<FileTile key={uri} uri={uri} /> <FileTile key={uri} uri={uri} />

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import * as icons from 'constants/icons'; import * as icons from 'constants/icons';
import lbryuri from 'lbryuri.js'; import { normalizeURI, isURIClaimable, parseURI } from 'lbryURI';
import CardMedia from 'component/cardMedia'; import CardMedia from 'component/cardMedia';
import { TruncatedText } from 'component/common.js'; import { TruncatedText } from 'component/common.js';
import FilePrice from 'component/filePrice'; import FilePrice from 'component/filePrice';
@ -65,11 +65,11 @@ class FileTile extends React.PureComponent {
fileInfo, fileInfo,
} = this.props; } = this.props;
const uri = lbryuri.normalize(this.props.uri); const uri = normalizeURI(this.props.uri);
const isClaimed = !!claim; const isClaimed = !!claim;
const isClaimable = lbryuri.isClaimable(uri); const isClaimable = isURIClaimable(uri);
const title = const title =
isClaimed && metadata && metadata.title ? metadata.title : lbryuri.parse(uri).contentName; isClaimed && metadata && metadata.title ? metadata.title : parseURI(uri).contentName;
const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null; const thumbnail = metadata && metadata.thumbnail ? metadata.thumbnail : null;
const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw; const obscureNsfw = this.props.obscureNsfw && metadata && metadata.nsfw;
const isRewardContent = claim && rewardedContentClaimIds.includes(claim.claim_id); const isRewardContent = claim && rewardedContentClaimIds.includes(claim.claim_id);

View file

@ -1,5 +1,5 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri'; import { isNameValid } from 'lbryURI';
import { FormRow } from 'component/form.js'; import { FormRow } from 'component/form.js';
import { BusyMessage } from 'component/common'; import { BusyMessage } from 'component/common';
import Link from 'component/link'; import Link from 'component/link';
@ -29,7 +29,7 @@ class ChannelSection extends React.PureComponent {
? event.target.value ? event.target.value
: `@${event.target.value}`; : `@${event.target.value}`;
if (newChannelName.length > 1 && !lbryuri.isValidName(newChannelName.substr(1), false)) { if (newChannelName.length > 1 && !isNameValid(newChannelName.substr(1), false)) {
this.refs.newChannelName.showError( this.refs.newChannelName.showError(
__('LBRY channel names must contain only letters, numbers and dashes.') __('LBRY channel names must contain only letters, numbers and dashes.')
); );

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import lbry from 'lbry'; import lbry from 'lbry';
import lbryuri from 'lbryuri'; import { isNameValid, buildURI, regexInvalidURI } from 'lbryURI';
import FormField from 'component/formField'; import FormField from 'component/formField';
import { Form, FormRow, Submit } from 'component/form.js'; import { Form, FormRow, Submit } from 'component/form.js';
import Link from 'component/link'; import Link from 'component/link';
@ -245,7 +245,7 @@ class PublishForm extends React.PureComponent {
return; return;
} }
if (!lbryuri.isValidName(rawName, false)) { if (!isNameValid(rawName, false)) {
this.refs.name.showError(__('LBRY names must contain only letters, numbers and dashes.')); this.refs.name.showError(__('LBRY names must contain only letters, numbers and dashes.'));
return; return;
} }
@ -254,7 +254,7 @@ class PublishForm extends React.PureComponent {
if (this.state.channel !== 'anonymous') channel = this.state.channel; if (this.state.channel !== 'anonymous') channel = this.state.channel;
const name = rawName.toLowerCase(); const name = rawName.toLowerCase();
const uri = lbryuri.build({ contentName: name, channelName: channel }); const uri = buildURI({ contentName: name, channelName: channel });
this.setState({ this.setState({
rawName, rawName,
name, name,
@ -446,7 +446,7 @@ class PublishForm extends React.PureComponent {
const extension = path.extname(fileName); const extension = path.extname(fileName);
fileName = path.basename(fileName, extension); fileName = path.basename(fileName, extension);
fileName = fileName.replace(lbryuri.REGEXP_INVALID_URI, ''); fileName = fileName.replace(regexInvalidURI, '');
return fileName; return fileName;
} }

View file

@ -3,7 +3,7 @@ import LinkTransaction from 'component/linkTransaction';
import { CreditAmount } from 'component/common'; import { CreditAmount } from 'component/common';
import DateTime from 'component/dateTime'; import DateTime from 'component/dateTime';
import Link from 'component/link'; import Link from 'component/link';
import lbryuri from 'lbryuri'; import { buildURI } from 'lbryURI';
import * as txnTypes from 'constants/transaction_types'; import * as txnTypes from 'constants/transaction_types';
class TransactionListItem extends React.PureComponent { class TransactionListItem extends React.PureComponent {
@ -74,7 +74,7 @@ class TransactionListItem extends React.PureComponent {
<Link <Link
className="button-text" className="button-text"
navigate="/show" navigate="/show"
navigateParams={{ uri: lbryuri.build({ name, claimId }) }} navigateParams={{ uri: buildURI({ name, claimId }) }}
> >
{name} {name}
</Link> </Link>

View file

@ -1,5 +1,5 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri'; import { normalizeURI } from 'lbryURI';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { doResolveUri } from 'redux/actions/content'; import { doResolveUri } from 'redux/actions/content';
import { makeSelectIsUriResolving } from 'redux/selectors/content'; import { makeSelectIsUriResolving } from 'redux/selectors/content';
@ -9,7 +9,7 @@ import UriIndicator from './view';
const select = (state, props) => ({ const select = (state, props) => ({
claim: makeSelectClaimForUri(props.uri)(state), claim: makeSelectClaimForUri(props.uri)(state),
isResolvingUri: makeSelectIsUriResolving(props.uri)(state), isResolvingUri: makeSelectIsUriResolving(props.uri)(state),
uri: lbryuri.normalize(props.uri), uri: normalizeURI(props.uri),
}); });
const perform = dispatch => ({ const perform = dispatch => ({

View file

@ -1,7 +1,7 @@
import React from 'react'; import React from 'react';
import Icon from 'component/icon'; import Icon from 'component/icon';
import Link from 'component/link'; import Link from 'component/link';
import lbryuri from 'lbryuri'; import { buildURI } from 'lbryURI';
import classnames from 'classnames'; import classnames from 'classnames';
class UriIndicator extends React.PureComponent { class UriIndicator extends React.PureComponent {
@ -49,7 +49,7 @@ class UriIndicator extends React.PureComponent {
if (signatureIsValid) { if (signatureIsValid) {
modifier = 'valid'; modifier = 'valid';
channelLink = link ? lbryuri.build({ channelName, claimId: channelClaimId }, false) : false; channelLink = link ? buildURI({ channelName, claimId: channelClaimId }, false) : false;
} else { } else {
icon = 'icon-times-circle'; icon = 'icon-times-circle';
modifier = 'invalid'; modifier = 'invalid';

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import { Form, FormRow, Submit } from 'component/form'; import { Form, FormRow, Submit } from 'component/form';
import lbryuri from 'lbryuri'; import { regexAddress } from 'lbryURI';
class WalletSend extends React.PureComponent { class WalletSend extends React.PureComponent {
handleSubmit() { handleSubmit() {
@ -42,7 +42,7 @@ class WalletSend extends React.PureComponent {
size="60" size="60"
onChange={setAddress} onChange={setAddress}
value={address} value={address}
regexp={lbryuri.REGEXP_ADDRESS} regexp={regexAddress}
trim trim
/> />
<div className="form-row-submit"> <div className="form-row-submit">

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import lbryuri from 'lbryuri.js'; import { normalizeURI } from 'lbryURI.js';
import { selectWunderBarAddress, selectWunderBarIcon } from 'redux/selectors/search'; import { selectWunderBarAddress, selectWunderBarIcon } from 'redux/selectors/search';
import { doNavigate } from 'redux/actions/navigation'; import { doNavigate } from 'redux/actions/navigation';
import Wunderbar from './view'; import Wunderbar from './view';
@ -13,7 +13,7 @@ const select = state => ({
const perform = dispatch => ({ const perform = dispatch => ({
onSearch: query => dispatch(doNavigate('/search', { query })), onSearch: query => dispatch(doNavigate('/search', { query })),
onSubmit: (query, extraParams) => onSubmit: (query, extraParams) =>
dispatch(doNavigate('/show', { uri: lbryuri.normalize(query), ...extraParams })), dispatch(doNavigate('/show', { uri: normalizeURI(query), ...extraParams })),
}); });
export default connect(select, perform)(Wunderbar); export default connect(select, perform)(Wunderbar);

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import PropTypes from 'prop-types'; import PropTypes from 'prop-types';
import lbryuri from 'lbryuri.js'; import { normalizeURI } from 'lbryURI';
import Icon from 'component/icon'; import Icon from 'component/icon';
import { parseQueryParams } from 'util/query_params'; import { parseQueryParams } from 'util/query_params';
@ -130,7 +130,7 @@ class WunderBar extends React.PureComponent {
if (parts.length > 0) extraParams = parseQueryParams(parts.join('')); if (parts.length > 0) extraParams = parseQueryParams(parts.join(''));
try { try {
uri = lbryuri.normalize(value); uri = normalizeURI(value);
this.setState({ value: uri }); this.setState({ value: uri });
} catch (error) { } catch (error) {
// then it's not a valid URL, so let's search // then it's not a valid URL, so let's search

View file

@ -1,10 +1,8 @@
const CHANNEL_NAME_MIN_LEN = 1; const channelNameMinLength = 1;
const CLAIM_ID_MAX_LEN = 40; const claimIdMaxLength = 40;
const Lbryuri = {}; export const regexInvalidURI = /[^A-Za-z0-9-]/g;
export const regexAddress = /^b(?=[^0OIl]{32,33})[0-9A-Za-z]{32,33}$/;
Lbryuri.REGEXP_INVALID_URI = /[^A-Za-z0-9-]/g;
Lbryuri.REGEXP_ADDRESS = /^b(?=[^0OIl]{32,33})[0-9A-Za-z]{32,33}$/;
/** /**
* Parses a LBRY name into its component parts. Throws errors with user-friendly * Parses a LBRY name into its component parts. Throws errors with user-friendly
@ -28,7 +26,7 @@ Lbryuri.REGEXP_ADDRESS = /^b(?=[^0OIl]{32,33})[0-9A-Za-z]{32,33}$/;
* - contentName (string): For anon claims, the name; for channel claims, the path * - contentName (string): For anon claims, the name; for channel claims, the path
* - channelName (string, if present): Channel name without @ * - channelName (string, if present): Channel name without @
*/ */
Lbryuri.parse = (uri, requireProto = false) => { export function parseURI(URI, requireProto = false) {
// Break into components. Empty sub-matches are converted to null // Break into components. Empty sub-matches are converted to null
const componentsRegex = new RegExp( const componentsRegex = new RegExp(
'^((?:lbry://)?)' + // protocol '^((?:lbry://)?)' + // protocol
@ -37,7 +35,7 @@ Lbryuri.parse = (uri, requireProto = false) => {
'(/?)(.*)' // path separator, path '(/?)(.*)' // path separator, path
); );
const [proto, name, modSep, modVal, pathSep, path] = componentsRegex const [proto, name, modSep, modVal, pathSep, path] = componentsRegex
.exec(uri) .exec(URI)
.slice(1) .slice(1)
.map(match => match || null); .map(match => match || null);
@ -61,14 +59,14 @@ Lbryuri.parse = (uri, requireProto = false) => {
throw new Error(__('No channel name after @.')); throw new Error(__('No channel name after @.'));
} }
if (channelName.length < CHANNEL_NAME_MIN_LEN) { if (channelName.length < channelNameMinLength) {
throw new Error(__(`Channel names must be at least %s characters.`, CHANNEL_NAME_MIN_LEN)); throw new Error(__(`Channel names must be at least %s characters.`, channelNameMinLength));
} }
contentName = path; contentName = path;
} }
const nameBadChars = (channelName || name).match(Lbryuri.REGEXP_INVALID_URI); const nameBadChars = (channelName || name).match(regexInvalidURI);
if (nameBadChars) { if (nameBadChars) {
throw new Error( throw new Error(
__( __(
@ -99,7 +97,7 @@ Lbryuri.parse = (uri, requireProto = false) => {
if ( if (
claimId && claimId &&
(claimId.length > CLAIM_ID_MAX_LEN || !claimId.match(/^[0-9a-f]+$/)) && (claimId.length > claimIdMaxLength || !claimId.match(/^[0-9a-f]+$/)) &&
!claimId.match(/^pending/) // ought to be dropped when savePendingPublish drops hack !claimId.match(/^pending/) // ought to be dropped when savePendingPublish drops hack
) { ) {
throw new Error(__(`Invalid claim ID %s.`, claimId)); throw new Error(__(`Invalid claim ID %s.`, claimId));
@ -119,7 +117,7 @@ Lbryuri.parse = (uri, requireProto = false) => {
throw new Error(__('Only channel URIs may have a path.')); throw new Error(__('Only channel URIs may have a path.'));
} }
const pathBadChars = path.match(Lbryuri.REGEXP_INVALID_URI); const pathBadChars = path.match(regexInvalidURI);
if (pathBadChars) { if (pathBadChars) {
throw new Error(__(`Invalid character in path: %s`, pathBadChars.join(', '))); throw new Error(__(`Invalid character in path: %s`, pathBadChars.join(', ')));
} }
@ -140,17 +138,17 @@ Lbryuri.parse = (uri, requireProto = false) => {
...(claimId ? { claimId } : {}), ...(claimId ? { claimId } : {}),
...(path ? { path } : {}), ...(path ? { path } : {}),
}; };
}; }
/** /**
* Takes an object in the same format returned by lbryuri.parse() and builds a URI. * Takes an object in the same format returned by parse() and builds a URI.
* *
* The channelName key will accept names with or without the @ prefix. * The channelName key will accept names with or without the @ prefix.
*/ */
Lbryuri.build = (uriObj, includeProto = true) => { export function buildURI(URIObj, includeProto = true) {
const { claimId, claimSequence, bidPosition, contentName, channelName } = uriObj; const { claimId, claimSequence, bidPosition, contentName, channelName } = URIObj;
let { name, path } = uriObj; let { name, path } = URIObj;
if (channelName) { if (channelName) {
const channelNameFormatted = channelName.startsWith('@') ? channelName : `@${channelName}`; const channelNameFormatted = channelName.startsWith('@') ? channelName : `@${channelName}`;
@ -188,36 +186,35 @@ Lbryuri.build = (uriObj, includeProto = true) => {
(bidPosition ? `${bidPosition}` : '') + (bidPosition ? `${bidPosition}` : '') +
(path ? `/${path}` : '') (path ? `/${path}` : '')
); );
}; }
/* Takes a parseable LBRY URI and converts it to standard, canonical format (currently this just /* Takes a parseable LBRY URI and converts it to standard, canonical format */
* consists of adding the lbry:// prefix if needed) */ export function normalizeURI(URI) {
Lbryuri.normalize = uri => { if (URI.match(/pending_claim/)) return URI;
if (uri.match(/pending_claim/)) return uri;
const { name, path, bidPosition, claimSequence, claimId } = Lbryuri.parse(uri); const { name, path, bidPosition, claimSequence, claimId } = parseURI(URI);
return Lbryuri.build({ name, path, claimSequence, bidPosition, claimId }); return buildURI({ name, path, claimSequence, bidPosition, claimId });
}; }
Lbryuri.isValid = uri => { export function isURIValid(URI) {
let parts; let parts;
try { try {
parts = Lbryuri.parse(Lbryuri.normalize(uri)); parts = parseURI(normalizeURI(URI));
} catch (error) { } catch (error) {
return false; return false;
} }
return parts && parts.name; return parts && parts.name;
}; }
Lbryuri.isValidName = (name, checkCase = true) => { export function isNameValid(name, checkCase = true) {
const regexp = new RegExp('^[a-z0-9-]+$', checkCase ? '' : 'i'); const regexp = new RegExp('^[a-z0-9-]+$', checkCase ? '' : 'i');
return regexp.test(name); return regexp.test(name);
}; }
Lbryuri.isClaimable = uri => { export function isURIClaimable(URI) {
let parts; let parts;
try { try {
parts = Lbryuri.parse(Lbryuri.normalize(uri)); parts = parseURI(normalizeURI(URI));
} catch (error) { } catch (error) {
return false; return false;
} }
@ -230,7 +227,4 @@ Lbryuri.isClaimable = uri => {
!parts.isChannel && !parts.isChannel &&
!parts.path !parts.path
); );
}; }
window.lbryuri = Lbryuri;
export default Lbryuri;

View file

@ -1,5 +1,5 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri'; import { buildURI } from 'lbryURI';
import { BusyMessage } from 'component/common'; import { BusyMessage } from 'component/common';
import FileTile from 'component/fileTile'; import FileTile from 'component/fileTile';
import ReactPaginate from 'react-paginate'; import ReactPaginate from 'react-paginate';
@ -46,7 +46,7 @@ class ChannelPage extends React.PureComponent {
} = this.props; } = this.props;
const { name, claim_id: claimId } = claim; const { name, claim_id: claimId } = claim;
const subscriptionUri = lbryuri.build({ channelName: name, claimId }, false); const subscriptionUri = buildURI({ channelName: name, claimId }, false);
let contentList; let contentList;
if (fetching) { if (fetching) {
@ -57,7 +57,7 @@ class ChannelPage extends React.PureComponent {
claimsInChannel.map(claim => ( claimsInChannel.map(claim => (
<FileTile <FileTile
key={claim.claim_id} key={claim.claim_id}
uri={lbryuri.build({ uri={buildURI({
name: claim.name, name: claim.name,
claimId: claim.claim_id, claimId: claim.claim_id,
})} })}

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import ReactDOM from 'react-dom'; import ReactDOM from 'react-dom';
import lbryuri from 'lbryuri'; import { normalizeURI } from 'lbryURI';
import FileCard from 'component/fileCard'; import FileCard from 'component/fileCard';
import { BusyMessage } from 'component/common.js'; import { BusyMessage } from 'component/common.js';
import Icon from 'component/icon'; import Icon from 'component/icon';
@ -212,7 +212,7 @@ export class FeaturedCategory extends React.PureComponent {
<div ref="rowitems" className="card-row__items"> <div ref="rowitems" className="card-row__items">
{names && {names &&
names.map(name => ( names.map(name => (
<FileCard key={name} displayStyle="card" uri={lbryuri.normalize(name)} /> <FileCard key={name} displayStyle="card" uri={normalizeURI(name)} />
))} ))}
</div> </div>
</div> </div>

View file

@ -1,6 +1,6 @@
import React from 'react'; import React from 'react';
import lbry from 'lbry'; import lbry from 'lbry';
import lbryuri from 'lbryuri'; import { buildURI, normalizeURI } from 'lbryURI';
import Video from 'component/video'; import Video from 'component/video';
import { Thumbnail } from 'component/common'; import { Thumbnail } from 'component/common';
import FilePrice from 'component/filePrice'; import FilePrice from 'component/filePrice';
@ -65,7 +65,7 @@ class FilePage extends React.PureComponent {
let subscriptionUri; let subscriptionUri;
if (channelName && channelClaimId) { if (channelName && channelClaimId) {
subscriptionUri = lbryuri.build({ channelName, claimId: channelClaimId }, false); subscriptionUri = buildURI({ channelName, claimId: channelClaimId }, false);
} }
return ( return (
@ -86,7 +86,7 @@ class FilePage extends React.PureComponent {
<div className="card__title-identity"> <div className="card__title-identity">
{!fileInfo || fileInfo.written_bytes <= 0 ? ( {!fileInfo || fileInfo.written_bytes <= 0 ? (
<span style={{ float: 'right' }}> <span style={{ float: 'right' }}>
<FilePrice uri={lbryuri.normalize(uri)} /> <FilePrice uri={normalizeURI(uri)} />
{isRewardContent && ( {isRewardContent && (
<span> <span>
{' '} {' '}

View file

@ -1,5 +1,5 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri'; import { isURIValid, normalizeURI } from 'lbryURI';
import FileTile from 'component/fileTile'; import FileTile from 'component/fileTile';
import FileListSearch from 'component/fileListSearch'; import FileListSearch from 'component/fileListSearch';
import { ToolTip } from 'component/tooltip.js'; import { ToolTip } from 'component/tooltip.js';
@ -10,7 +10,7 @@ class SearchPage extends React.PureComponent {
return ( return (
<main className="main--single-column"> <main className="main--single-column">
{lbryuri.isValid(query) ? ( {isURIValid(query) ? (
<section className="section-spaced"> <section className="section-spaced">
<h3 className="card-row__header"> <h3 className="card-row__header">
{__('Exact URL')}{' '} {__('Exact URL')}{' '}
@ -20,7 +20,7 @@ class SearchPage extends React.PureComponent {
className="tooltip--header" className="tooltip--header"
/> />
</h3> </h3>
<FileTile uri={lbryuri.normalize(query)} showEmpty={FileTile.SHOW_EMPTY_PUBLISH} /> <FileTile uri={normalizeURI(query)} showEmpty={FileTile.SHOW_EMPTY_PUBLISH} />
</section> </section>
) : ( ) : (
'' ''

View file

@ -1,5 +1,4 @@
import React from 'react'; import React from 'react';
import lbryuri from 'lbryuri';
import { BusyMessage } from 'component/common'; import { BusyMessage } from 'component/common';
import ChannelPage from 'page/channel'; import ChannelPage from 'page/channel';
import FilePage from 'page/file'; import FilePage from 'page/file';

View file

@ -4,7 +4,7 @@ import * as SETTINGS from 'constants/settings';
import { ipcRenderer } from 'electron'; import { ipcRenderer } from 'electron';
import Lbry from 'lbry'; import Lbry from 'lbry';
import Lbryio from 'lbryio'; import Lbryio from 'lbryio';
import Lbryuri from 'lbryuri'; import { normalizeURI, buildURI } from 'lbryURI';
import { doAlertError, doOpenModal } from 'redux/actions/app'; import { doAlertError, doOpenModal } from 'redux/actions/app';
import { doClaimEligiblePurchaseRewards } from 'redux/actions/rewards'; import { doClaimEligiblePurchaseRewards } from 'redux/actions/rewards';
import { selectBadgeNumber } from 'redux/selectors/app'; import { selectBadgeNumber } from 'redux/selectors/app';
@ -26,7 +26,7 @@ const DOWNLOAD_POLL_INTERVAL = 250;
export function doResolveUris(uris) { export function doResolveUris(uris) {
return (dispatch, getState) => { return (dispatch, getState) => {
const normalizedUris = uris.map(Lbryuri.normalize); const normalizedUris = uris.map(normalizeURI);
const state = getState(); const state = getState();
// Filter out URIs that are already resolving // Filter out URIs that are already resolving
@ -506,7 +506,7 @@ export function doAbandonClaim(txid, nout) {
claimId, claimId,
}, },
}); });
dispatch(doResolveUri(Lbryuri.build({ name, claimId }))); dispatch(doResolveUri(buildURI({ name, claimId })));
dispatch(doFetchClaimListMine()); dispatch(doFetchClaimListMine());
} else { } else {
dispatch(doOpenModal(MODALS.TRANSACTION_FAILED)); dispatch(doOpenModal(MODALS.TRANSACTION_FAILED));

View file

@ -1,5 +1,5 @@
import * as ACTIONS from 'constants/action_types'; import * as ACTIONS from 'constants/action_types';
import Lbryuri from 'lbryuri'; import { buildURI } from 'lbryURI';
import { doResolveUri } from 'redux/actions/content'; import { doResolveUri } from 'redux/actions/content';
import { doNavigate } from 'redux/actions/navigation'; import { doNavigate } from 'redux/actions/navigation';
import { selectCurrentPage } from 'redux/selectors/navigation'; import { selectCurrentPage } from 'redux/selectors/navigation';
@ -40,7 +40,7 @@ export function doSearch(rawQuery) {
const actions = []; const actions = [];
data.forEach(result => { data.forEach(result => {
const uri = Lbryuri.build({ const uri = buildURI({
name: result.name, name: result.name,
claimId: result.claimId, claimId: result.claimId,
}); });

View file

@ -1,4 +1,4 @@
import Lbryuri from 'lbryuri'; import { normalizeURI } from 'lbryURI';
import { makeSelectCurrentParam } from 'redux/selectors/navigation'; import { makeSelectCurrentParam } from 'redux/selectors/navigation';
import { createSelector } from 'reselect'; import { createSelector } from 'reselect';
@ -32,7 +32,7 @@ export const selectAllClaimsByChannel = createSelector(
); );
export const makeSelectClaimForUri = uri => export const makeSelectClaimForUri = uri =>
createSelector(selectClaimsByUri, claims => claims && claims[Lbryuri.normalize(uri)]); createSelector(selectClaimsByUri, claims => claims && claims[normalizeURI(uri)]);
export const selectMyClaimsRaw = createSelector(selectState, state => state.myClaims); export const selectMyClaimsRaw = createSelector(selectState, state => state.myClaims);
@ -53,7 +53,7 @@ export const selectMyActiveClaims = createSelector(
); );
export const makeSelectClaimIsMine = rawUri => { export const makeSelectClaimIsMine = rawUri => {
const uri = Lbryuri.normalize(rawUri); const uri = normalizeURI(rawUri);
return createSelector( return createSelector(
selectClaimsByUri, selectClaimsByUri,
selectMyActiveClaims, selectMyActiveClaims,

View file

@ -1,6 +1,5 @@
import * as settings from 'constants/settings'; import * as settings from 'constants/settings';
import { createSelector } from 'reselect'; import { createSelector } from 'reselect';
import lbryuri from 'lbryuri';
import { makeSelectClaimForUri } from 'redux/selectors/claims'; import { makeSelectClaimForUri } from 'redux/selectors/claims';
const _selectState = state => state.media || {}; const _selectState = state => state.media || {};

View file

@ -1,6 +1,6 @@
import { createSelector } from 'reselect'; import { createSelector } from 'reselect';
import { parseQueryParams, toQueryString } from 'util/query_params'; import { parseQueryParams, toQueryString } from 'util/query_params';
import Lbryuri from 'lbryuri'; import { normalizeURI } from 'lbryURI';
export const selectState = state => state.navigation || {}; export const selectState = state => state.navigation || {};
@ -93,7 +93,7 @@ export const selectPageTitle = createSelector(
case 'developer': case 'developer':
return __('Developer'); return __('Developer');
case 'show': { case 'show': {
const parts = [Lbryuri.normalize(params.uri)]; const parts = [normalizeURI(params.uri)];
// If the params has any keys other than "uri" // If the params has any keys other than "uri"
if (Object.keys(params).length > 1) { if (Object.keys(params).length > 1) {
parts.push(toQueryString(Object.assign({}, params, { uri: null }))); parts.push(toQueryString(Object.assign({}, params, { uri: null })));