{"version":3,"sources":["webpack:///./src/components/Content.js","webpack:///./src/templates/author-page.js","webpack:///./src/components/SimpleFunctions.js"],"names":["HTMLContent","content","className","dangerouslySetInnerHTML","__html","Content","AuthorPosts","props","posts","pageContext","currentPage","isFirst","isLast","numPages","prevPage","slug","nextPage","map","post","node","frontmatter","category","cat","title","date","img","featuredimage","base","childImageSharp","original","width","height","fields","id","FindCategory","categoryName","categoryLink","key","to","srcSet","src","alt","loading","rel","AuthorPage","data","PageContent","markdownRemark","seoTitle","seoDescription","description","html","allMdx","edges","ID","FindItems","categories","nodes","find","useStaticQuery","authors"],"mappings":"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","file":"component---src-templates-author-page-js.js","sourcesContent":["import React from \"react\";\nimport PropTypes from \"prop-types\";\n\nexport const HTMLContent = ({ content, className }) =>
;\n\nconst Content = ({ content, className }) =>
{content}
;\n\nContent.propTypes = {\n content: PropTypes.node,\n className: PropTypes.string,\n};\n\nHTMLContent.propTypes = Content.propTypes;\n\nexport default Content;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { graphql, Link } from \"gatsby\";\nimport Layout from \"../components/Layout\";\nimport Content, { HTMLContent } from \"../components/Content\";\nimport HeadData from \"../components/HeadData.js\";\nimport { FindCategory } from \"../components/SimpleFunctions.js\";\n\nconst AuthorPage = (props) => {\n const { data } = props;\n const PageContent = HTMLContent || Content;\n const { markdownRemark: post } = data;\n const { title, seoTitle, seoDescription } = post.frontmatter;\n\n return (\n \n \n
\n
\n
\n \n
\n \n
\n
\n
\n );\n};\n\nAuthorPage.propTypes = {\n data: PropTypes.object.isRequired,\n};\n\nconst AuthorPosts = (props) => {\n const { posts } = props;\n const { currentPage, numPages } = props.pageContext;\n const isFirst = currentPage === 1;\n const isLast = currentPage === numPages;\n const prevPage = currentPage - 1 === 1 ? `${props.pageContext.slug}/` : `${props.pageContext.slug}/page/${currentPage - 1}/`;\n const nextPage = `${props.pageContext.slug}/page/${currentPage + 1}/`;\n\n return (\n
\n

Author Posts

\n
\n
\n {posts &&\n posts.map(({ node: post }) => {\n const { cat: category, title, date } = post.frontmatter;\n const { base: img } = post.frontmatter.featuredimage;\n const { width, height } = post.frontmatter.featuredimage.childImageSharp.original;\n const slug = post.fields.slug;\n const id = post.id;\n const { categoryName, categoryLink } = FindCategory(category);\n\n return (\n
\n
\n
\n
\n \n \n \n {title}\n \n \n
\n
\n
\n {title}\n
\n
\n {categoryName} | {date}\n
\n
\n
\n );\n })}\n
\n
\n
\n
\n {!isFirst && (\n \n ← Newer Posts\n \n )}\n
\n
\n {!isLast && (\n \n Older Posts →\n \n )}\n
\n
\n
\n );\n};\n\nexport default AuthorPage;\n\nexport const authorPageQuery = graphql`\n query AuthorPageByID($id: String!, $cat: String!, $skip: Int!, $limit: Int!) {\n markdownRemark(id: { eq: $id }) {\n html\n frontmatter {\n title\n seoTitle\n seoDescription\n }\n }\n allMdx(sort: { order: DESC, fields: [frontmatter___date] }, filter: { frontmatter: { writer: { eq: $cat } } }, limit: $limit, skip: $skip) {\n edges {\n node {\n id\n fields {\n slug\n }\n frontmatter {\n title\n cat\n date(formatString: \"MMMM DD, YYYY\")\n featuredimage {\n name\n base\n childImageSharp {\n original {\n height\n width\n }\n }\n }\n }\n }\n }\n }\n }\n`;\n","import { useStaticQuery, graphql } from \"gatsby\";\n\nexport const FindCategory = (ID) => {\n const { categories } = FindItems();\n\n const category = categories.nodes.find((category) => category.frontmatter.id === ID);\n const categoryName = category?.frontmatter?.title;\n const categoryLink = category?.fields?.slug;\n\n return { categoryName, categoryLink };\n};\n\nexport const FindAuthor = (ID) => {\n const { authors } = FindItems();\n\n const author = authors.nodes.find((author) => author.frontmatter.id === ID);\n const authorName = author?.frontmatter?.title;\n const authorLink = author?.fields?.slug;\n\n return { authorName, authorLink };\n};\n\nexport const CreateID = (name) =>\n name\n .replace(/[^\\w ]/, \"\")\n .split(\" \")\n .join(\"_\");\n\nexport const LinkFix = (item) => (item.link?.includes(\"/\") ? item.link : `/${item.link}/`);\n\nconst FindItems = () => {\n const { authors, categories } = useStaticQuery(graphql`\n query Authors {\n authors: allMarkdownRemark(filter: { frontmatter: { templateKey: { eq: \"author-page\" } } }) {\n nodes {\n fields {\n slug\n }\n frontmatter {\n id\n title\n }\n }\n }\n categories: allMarkdownRemark(filter: { frontmatter: { templateKey: { eq: \"category-page\" } } }) {\n nodes {\n fields {\n slug\n }\n frontmatter {\n id\n title\n }\n }\n }\n }\n `);\n\n return { authors, categories };\n};\n"],"sourceRoot":""}