UNPKG

rsshub

Version:
269 lines (260 loc) • 4.83 kB
import "./esm-shims-CzJ_djXG.mjs"; import "./config-C37vj7VH.mjs"; import { t as ViewType } from "./types-D84BRIt4.mjs"; import "./dist-BInvbO1W.mjs"; import "./logger-Czu8UMNd.mjs"; import "./ofetch-BIyrKU3Y.mjs"; import "./parse-date-BrP7mxXf.mjs"; import "./cache-Bo__VnGm.mjs"; import "./render-BQo6B4tL.mjs"; import { a as variables, i as getList, r as getData, t as baseUrl } from "./utils-BYCmah7P.mjs"; //#region lib/routes/daily/squads.ts const sourceQuery = ` query Source($handle: ID!) { source(id: $handle) { ...SquadBaseInfo moderationPostCount } } fragment SquadBaseInfo on Source { ...SourceBaseInfo referralUrl createdAt flags { featured totalPosts totalViews totalUpvotes } category { id title slug } ...PrivilegedMembers } fragment SourceBaseInfo on Source { id active handle name permalink public type description image membersCount currentMember { ...CurrentMember } memberPostingRole memberInviteRole moderationRequired } fragment CurrentMember on SourceMember { user { id } permissions role referralToken flags { hideFeedPosts collapsePinnedPosts } } fragment PrivilegedMembers on Source { privilegedMembers { user { id name image permalink username bio reputation companies { name image } contentPreference { status } } role } } `; const query = ` query SourceFeed( $source: ID! $loggedIn: Boolean! = false $first: Int $after: String $ranking: Ranking $supportedTypes: [String!] ) { page: sourceFeed( source: $source first: $first after: $after ranking: $ranking supportedTypes: $supportedTypes ) { ...FeedPostConnection } } fragment FeedPostConnection on PostConnection { pageInfo { hasNextPage endCursor } edges { node { ...FeedPost pinnedAt contentHtml ...UserPost @include(if: $loggedIn) } } } fragment FeedPost on Post { ...FeedPostInfo sharedPost { id title image readTime permalink commentsPermalink createdAt type tags source { id handle permalink image } slug clickbaitTitleDetected } trending feedMeta collectionSources { handle image } numCollectionSources updatedAt slug } fragment FeedPostInfo on Post { id title image readTime permalink commentsPermalink createdAt commented bookmarked views numUpvotes numComments summary bookmark { remindAt } author { id name image username permalink } type tags source { id handle name permalink image type } userState { vote flags { feedbackDismiss } } slug clickbaitTitleDetected } fragment UserPost on Post { read upvoted commented bookmarked downvoted } `; const route = { path: "/squads/:squads/:innerSharedContent?", example: "/daily/squads/watercooler", view: ViewType.Articles, parameters: { innerSharedContent: { description: "Where to Fetch inner Shared Posts instead of original", default: "false", options: [{ value: "false", label: "False" }, { value: "true", label: "True" }] } }, radar: [{ source: ["app.daily.dev/squads/:squads"] }], name: "Squads", maintainers: ["Rjnishant530"], handler, url: "app.daily.dev/squads/discover" }; async function handler(ctx) { const limit = ctx.req.query("limit") ? Number.parseInt(ctx.req.query("limit"), 10) : 20; const innerSharedContent = ctx.req.param("innerSharedContent") ? JSON.parse(ctx.req.param("innerSharedContent")) : false; const squads = ctx.req.param("squads"); const link = `${baseUrl}/squads/${squads}`; const { id, description, name } = await getData({ query: sourceQuery, variables: { handle: squads } }, true); const items = getList(await getData({ query, variables: { ...variables, source: id, ranking: "TIME", supportedTypes: [ "article", "share", "freeform", "video:youtube", "collection", "welcome" ], first: limit } }), innerSharedContent, true); return { title: `${name} - daily.dev`, link, item: items, description, logo: `${baseUrl}/favicon-32x32.png`, icon: `${baseUrl}/favicon-32x32.png`, language: "en-us" }; } //#endregion export { route };