Merge branch 'initial-custom-homepages' into 'main'
Initial support for custom homepages See merge request romanrex19/madiator.com!1
This commit is contained in:
commit
408ef64719
4 changed files with 162 additions and 4 deletions
|
@ -13,7 +13,7 @@ This repo contains the UI code that powers the official LBRY desktop app, as wel
|
|||
|
||||
## Running from Source
|
||||
|
||||
You can run the web version (lbry.tv), the electron app, or both at the same time.
|
||||
You can run the web version (madiator.com), the electron app, or both at the same time.
|
||||
|
||||
#### Prerequisites
|
||||
|
||||
|
@ -49,9 +49,6 @@ nano .env
|
|||
- To specify your own OG-IMAGE
|
||||
You can either place a png named v2-og.png in the /custom folder or specify the OG_IMAGE_URL in .env
|
||||
|
||||
- To specify your own channels to be followed on first run
|
||||
`AUTO_FOLLOW_URLS=lbry://@chan#123...a lbry://@chan2#456...a`
|
||||
|
||||
- If you want to customize the homepage content
|
||||
|
||||
1. add `CUSTOM_HOMEPAGE=true` to the '.env' file
|
||||
|
|
4
custom/homepages/v2/index.js
Normal file
4
custom/homepages/v2/index.js
Normal file
|
@ -0,0 +1,4 @@
|
|||
const madiator_en = require('./madiator-en.js');
|
||||
module.exports = {
|
||||
en: madiator_en,
|
||||
};
|
157
custom/homepages/v2/madiator-en.js
Normal file
157
custom/homepages/v2/madiator-en.js
Normal file
|
@ -0,0 +1,157 @@
|
|||
//module.exports = {
|
||||
// LINUX,
|
||||
//};
|
||||
|
||||
//const PRIMARY_CONTENT_CHANNEL_IDS = [
|
||||
//e15f8434e6fd76b05f0b6c2918f71a7f29b93f7e,
|
||||
//];
|
||||
|
||||
//const PRIMARY_CONTENT = {
|
||||
// channelIds: PRIMARY_CONTENT_CHANNEL_IDS,
|
||||
// name: 'general',
|
||||
// sortOrder: 1,
|
||||
// icon: 'Cheese',
|
||||
// label: 'Cheese',
|
||||
// channelLimit: 'auto',
|
||||
// daysOfContent: 180,
|
||||
// pageSize: 24,
|
||||
//pinnedUrls: ['lbry://@RationalAnimations#1/humanity-was-born-way-ahead-of-its-time.#5',]
|
||||
//mixIn: [],
|
||||
//};
|
||||
|
||||
import * as PAGES from 'constants/pages';
|
||||
import * as CS from 'constants/claim_search';
|
||||
import * as ICONS from 'constants/icons';
|
||||
import { parseURI } from 'lbry-redux';
|
||||
import moment from 'moment';
|
||||
import { toCapitalCase } from 'util/string';
|
||||
import React from 'react';
|
||||
import Icon from 'component/common/icon';
|
||||
|
||||
export type RowDataItem = {
|
||||
title: string,
|
||||
link?: string,
|
||||
help?: any,
|
||||
options?: {},
|
||||
};
|
||||
|
||||
export default function GetHomePageRowData(
|
||||
authenticated: boolean,
|
||||
showPersonalizedChannels: boolean,
|
||||
showPersonalizedTags: boolean,
|
||||
subscribedChannels: Array<Subscription>,
|
||||
followedTags: Array<Tag>,
|
||||
showIndividualTags: boolean
|
||||
) {
|
||||
let rowData: Array<RowDataItem> = [];
|
||||
const individualTagDataItems: Array<RowDataItem> = [];
|
||||
|
||||
const TOP_CONTENT_TODAY = {
|
||||
title: 'Top Content from Today',
|
||||
link: `/$/${PAGES.DISCOVER}?${CS.ORDER_BY_KEY}=${CS.ORDER_BY_TOP}&${CS.FRESH_KEY}=${CS.FRESH_DAY}`,
|
||||
options: {
|
||||
pageSize: 12,
|
||||
orderBy: ['effective_amount'],
|
||||
claimType: ['stream'],
|
||||
releaseTime: `>${Math.floor(
|
||||
moment()
|
||||
.subtract(1, 'day')
|
||||
.startOf('day')
|
||||
.unix()
|
||||
)}`,
|
||||
},
|
||||
};
|
||||
|
||||
const TOP_CHANNELS = {
|
||||
title: 'Top Channels On LBRY',
|
||||
link: `/$/${PAGES.DISCOVER}?claim_type=channel&${CS.ORDER_BY_KEY}=${CS.ORDER_BY_TOP}&${CS.FRESH_KEY}=${CS.FRESH_ALL}`,
|
||||
options: {
|
||||
orderBy: ['effective_amount'],
|
||||
claimType: ['channel'],
|
||||
},
|
||||
};
|
||||
|
||||
const TRENDING_CLASSICS = {
|
||||
title: 'Trending Classics',
|
||||
link: `/$/${PAGES.DISCOVER}?${CS.ORDER_BY_KEY}=${CS.ORDER_BY_TRENDING}&${CS.FRESH_KEY}=${CS.FRESH_WEEK}`,
|
||||
options: {
|
||||
pageSize: 6,
|
||||
claimType: ['stream'],
|
||||
releaseTime: `<${Math.floor(
|
||||
moment()
|
||||
.subtract(6, 'month')
|
||||
.startOf('day')
|
||||
.unix()
|
||||
)}`,
|
||||
},
|
||||
};
|
||||
|
||||
const TRENDING_ON_LBRY = {
|
||||
title: 'Trending On LBRY',
|
||||
link: `/$/${PAGES.DISCOVER}`,
|
||||
options: {
|
||||
pageSize: showPersonalizedChannels || showPersonalizedTags ? 4 : 8,
|
||||
},
|
||||
};
|
||||
|
||||
const TRENDING_FOR_TAGS = {
|
||||
title: 'Trending For Your Tags',
|
||||
link: `/$/${PAGES.TAGS_FOLLOWING}`,
|
||||
options: {
|
||||
tags: followedTags.map(tag => tag.name),
|
||||
claimType: ['stream'],
|
||||
},
|
||||
};
|
||||
|
||||
const LATEST_FROM_LBRY = {
|
||||
title: 'Latest From @Madiator2011',
|
||||
link: `/@Madiator2011:e`,
|
||||
options: {
|
||||
orderBy: ['release_time'],
|
||||
pageSize: 8,
|
||||
channelIds: ['e15f8434e6fd76b05f0b6c2918f71a7f29b93f7e'],
|
||||
},
|
||||
};
|
||||
|
||||
const LATEST_FROM_LBRYCAST = {
|
||||
title: 'Latest From @blenderdumbass',
|
||||
link: `/@blenderdumbass:f`,
|
||||
options: {
|
||||
orderBy: ['release_time'],
|
||||
pageSize: 4,
|
||||
channelIds: ['fd60b4b0b82f7f4e870c956ab61e9137b7c54680'],
|
||||
},
|
||||
};
|
||||
|
||||
// const LINUX_CHANNEL_IDS = [
|
||||
// '5d5770bc07e5727320d5e18680867cbe47ae72bd',
|
||||
// 'e5d96ea3720b01cca537c6d90f38e8c11ff06a0a',
|
||||
// ];
|
||||
// const LINUXI = {
|
||||
// channelIds: LINUX_CHANNEL_IDS,
|
||||
// name: 'linux',
|
||||
// sortOrder: 40,
|
||||
// icon: 'Speaker',
|
||||
// label: 'Linux',
|
||||
// channelLimit: 'auto',
|
||||
// daysOfContent: 180,
|
||||
// pageSize: 24,
|
||||
//};
|
||||
|
||||
|
||||
if (showPersonalizedChannels) rowData.push(RECENT_FROM_FOLLOWING);
|
||||
if (showPersonalizedTags && !showIndividualTags) rowData.push(TRENDING_FOR_TAGS);
|
||||
if (showPersonalizedTags && showIndividualTags) {
|
||||
individualTagDataItems.forEach((item: RowDataItem) => {
|
||||
rowData.push(item);
|
||||
});
|
||||
}
|
||||
rowData.push(TOP_CONTENT_TODAY);
|
||||
rowData.push(LATEST_FROM_LBRY);
|
||||
rowData.push(LATEST_FROM_LBRYCAST);
|
||||
rowData.push(TRENDING_ON_LBRY);
|
||||
rowData.push(TOP_CHANNELS);
|
||||
rowData.push(TRENDING_CLASSICS);
|
||||
return rowData;
|
||||
}
|
||||
|
Loading…
Add table
Reference in a new issue