add more filters to recent

This commit is contained in:
keyan 2022-12-01 16:22:13 -06:00
parent a2db3e18b4
commit 2a4e5a0617
10 changed files with 74 additions and 42 deletions

View File

@ -126,6 +126,21 @@ export async function filterClause (me, models) {
return clause return clause
} }
function recentClause (type) {
switch (type) {
case 'links':
return ' AND url IS NOT NULL'
case 'discussions':
return ' AND url IS NULL AND bio = false AND "pollCost" IS NULL'
case 'polls':
return ' AND "pollCost" IS NOT NULL'
case 'bios':
return ' AND bio = true'
default:
return ''
}
}
export default { export default {
Query: { Query: {
itemRepetition: async (parent, { parentId }, { me, models }) => { itemRepetition: async (parent, { parentId }, { me, models }) => {
@ -170,7 +185,7 @@ export default {
comments comments
} }
}, },
items: async (parent, { sub, sort, cursor, name, within }, { me, models }) => { items: async (parent, { sub, sort, type, cursor, name, within }, { me, models }) => {
const decodedCursor = decodeCursor(cursor) const decodedCursor = decodeCursor(cursor)
let items; let user; let pins; let subFull let items; let user; let pins; let subFull
@ -212,6 +227,7 @@ export default {
${subClause(3)} ${subClause(3)}
${activeOrMine()} ${activeOrMine()}
${await filterClause(me, models)} ${await filterClause(me, models)}
${recentClause(type)}
ORDER BY created_at DESC ORDER BY created_at DESC
OFFSET $2 OFFSET $2
LIMIT ${LIMIT}`, decodedCursor.time, decodedCursor.offset, sub || 'NULL') LIMIT ${LIMIT}`, decodedCursor.time, decodedCursor.offset, sub || 'NULL')

View File

@ -2,7 +2,7 @@ import { gql } from 'apollo-server-micro'
export default gql` export default gql`
extend type Query { extend type Query {
items(sub: String, sort: String, cursor: String, name: String, within: String): Items items(sub: String, sort: String, type: String, cursor: String, name: String, within: String): Items
moreFlatComments(sort: String!, cursor: String, name: String, within: String): Comments moreFlatComments(sort: String!, cursor: String, name: String, within: String): Comments
item(id: ID!): Item item(id: ID!): Item
comments(id: ID!, sort: String): [Item!]! comments(id: ID!, sort: String): [Item!]!

View File

@ -185,9 +185,13 @@ export default function JobForm ({ item, sub }) {
<PromoteJob item={item} sub={sub} storageKeyPrefix={storageKeyPrefix} /> <PromoteJob item={item} sub={sub} storageKeyPrefix={storageKeyPrefix} />
{item && <StatusControl item={item} />} {item && <StatusControl item={item} />}
<div className='d-flex align-items-center mt-3'> <div className='d-flex align-items-center mt-3'>
<ActionTooltip overlayText='1000 sats'> {item
<SubmitButton variant='secondary'>{item ? 'save' : <>post <small> 1000 sats</small></>}</SubmitButton> ? <SubmitButton variant='secondary'>save</SubmitButton>
</ActionTooltip> : (
<ActionTooltip overlayText='1000 sats'>
<SubmitButton variant='secondary'>post <small> 1000 sats</small></SubmitButton>
</ActionTooltip>
)}
</div> </div>
</Form> </Form>
</> </>

View File

@ -1,35 +1,25 @@
import { Nav, Navbar } from 'react-bootstrap' import { Form, Select } from './form'
import styles from './header.module.css' import { useRouter } from 'next/router'
import Link from 'next/link'
export default function RecentHeader ({ type }) {
const router = useRouter()
export default function RecentHeader ({ itemType }) {
return ( return (
<Navbar className='pt-0'> <Form
<Nav initial={{
className={`${styles.navbarNav} justify-content-around`} type: router.query.type || type || 'posts'
activeKey={itemType} }}
> >
<Nav.Item> <div className='text-muted font-weight-bold mt-1 mb-3 d-flex justify-content-end align-items-center'>
<Link href='/recent' passHref> <Select
<Nav.Link groupClassName='mb-0 ml-2'
eventKey='posts' className='w-auto'
className={styles.navLink} name='type'
> size='sm'
posts items={['posts', 'comments', 'links', 'discussions', 'polls', 'bios']}
</Nav.Link> onChange={(formik, e) => router.push(e.target.value === 'posts' ? '/recent' : `/recent/${e.target.value}`)}
</Link> />
</Nav.Item> </div>
<Nav.Item> </Form>
<Link href='/recent/comments' passHref>
<Nav.Link
eventKey='comments'
className={styles.navLink}
>
comments
</Nav.Link>
</Link>
</Nav.Item>
</Nav>
</Navbar>
) )
} }

View File

@ -56,8 +56,8 @@ export const ITEM_FIELDS = gql`
export const ITEMS = gql` export const ITEMS = gql`
${ITEM_FIELDS} ${ITEM_FIELDS}
query items($sub: String, $sort: String, $cursor: String, $name: String, $within: String) { query items($sub: String, $sort: String, $type: String, $cursor: String, $name: String, $within: String) {
items(sub: $sub, sort: $sort, cursor: $cursor, name: $name, within: $within) { items(sub: $sub, sort: $sort, type: $type, cursor: $cursor, name: $name, within: $within) {
cursor cursor
items { items {
...ItemFields ...ItemFields

View File

@ -50,7 +50,7 @@ function getClient (uri) {
} }
}, },
items: { items: {
keyArgs: ['sub', 'sort', 'name', 'within'], keyArgs: ['sub', 'sort', 'type', 'name', 'within'],
merge (existing, incoming) { merge (existing, incoming) {
if (isFirstPage(incoming.cursor, existing?.items)) { if (isFirstPage(incoming.cursor, existing?.items)) {
return incoming return incoming

22
pages/recent/[type].js Normal file
View File

@ -0,0 +1,22 @@
import Layout from '../../components/layout'
import Items from '../../components/items'
import { getGetServerSideProps } from '../../api/ssrApollo'
import { ITEMS } from '../../fragments/items'
import RecentHeader from '../../components/recent-header'
import { useRouter } from 'next/router'
const variables = { sort: 'recent' }
export const getServerSideProps = getGetServerSideProps(ITEMS, variables)
export default function Index ({ data: { items: { items, cursor } } }) {
const router = useRouter()
return (
<Layout>
<RecentHeader />
<Items
items={items} cursor={cursor}
variables={{ ...variables, type: router.query.type }} rank
/>
</Layout>
)
}

View File

@ -10,7 +10,7 @@ export const getServerSideProps = getGetServerSideProps(MORE_FLAT_COMMENTS, vari
export default function Index ({ data: { moreFlatComments: { comments, cursor } } }) { export default function Index ({ data: { moreFlatComments: { comments, cursor } } }) {
return ( return (
<Layout> <Layout>
<RecentHeader itemType='comments' /> <RecentHeader type='comments' />
<CommentsFlat <CommentsFlat
comments={comments} cursor={cursor} comments={comments} cursor={cursor}
variables={{ sort: 'recent' }} includeParent noReply variables={{ sort: 'recent' }} includeParent noReply

View File

@ -10,7 +10,7 @@ export const getServerSideProps = getGetServerSideProps(ITEMS, variables)
export default function Index ({ data: { items: { items, cursor } } }) { export default function Index ({ data: { items: { items, cursor } } }) {
return ( return (
<Layout> <Layout>
<RecentHeader itemType='posts' /> <RecentHeader type='posts' />
<Items <Items
items={items} cursor={cursor} items={items} cursor={cursor}
variables={variables} rank variables={variables} rank

View File

@ -67,7 +67,7 @@ const dateFormatter = when => {
case 'forever': case 'forever':
return `${('0' + (date.getMonth() % 12 + 1)).slice(-2)}/${String(date.getFullYear()).slice(-2)}` return `${('0' + (date.getMonth() % 12 + 1)).slice(-2)}/${String(date.getFullYear()).slice(-2)}`
default: default:
return `${date.getHours() % 12 || 12}${date.getHours() >= 12 ? 'p' : 'a'}` return `${date.getHours() % 12 || 12}${date.getHours() >= 12 ? 'pm' : 'am'}`
} }
} }
} }