diff --git a/src/components/Nav/index.js b/src/components/Nav/index.js index 235b772515a..ec0bae79a26 100644 --- a/src/components/Nav/index.js +++ b/src/components/Nav/index.js @@ -200,6 +200,10 @@ const Nav = ({ handleThemeChange, isDarkTheme, path }) => { text: "decentralized-social-networks", to: "/social-networks/", }, + { + text: "decentralized-identity", + to: "/decentralized-identity/", + }, ], }, { diff --git a/src/content/decentralized-identity/index.md b/src/content/decentralized-identity/index.md new file mode 100644 index 00000000000..63f2021b2c4 --- /dev/null +++ b/src/content/decentralized-identity/index.md @@ -0,0 +1,171 @@ +--- +title: Decentralized identity +description: What is decentralized identity, and why does it matter? +lang: en +template: use-cases +emoji: ":id:" +sidebar: true +sidebarDepth: 2 +image: ../../assets/eth-gif-cat.png +summaryPoint1: Traditional identity systems have centralized the issuance, maintenance and control of your identifiers. +summaryPoint2: Decentralized identity removes reliance on centralized third parties. +summaryPoint3: Thanks to crypto, users now have the tools to issue, hold and control their own identifiers and attestations once again. +--- + +Identity underpins virtually every aspect of your life today. Using online services, opening a bank account, voting in elections, buying property, securing employment—all of these things require proving your identity. + +However, traditional identity management systems have long relied on centralized intermediaries who issue, hold, and control your identifiers and attestations. This means you cannot control your identity-related information, or decide who has access to personally identifiable information (PII) and how much access these parties have. + +To solve these problems, we have decentralized identity systems built on public blockchains like Ethereum. Decentralized identity allows individuals to manage their identity-related information. With decentralized identity solutions, _you_ can create identifiers and claim and hold your attestations without relying on central authorities, like service providers or governments. + +## What is identity {#what-is-identity} + +Identity means an individual's sense of self, defined by unique characteristics. Identity refers to being an _individual_, i.e., a distinct human entity. Identity could also refer to other non-human entities, such as an organization or authority. + +## What are identifiers? {#what-are-identifiers} + +An identifier is a piece of information that acts as a pointer to a particular identity or identities. Common identifiers include: + +- Name +- Social security number/tax ID number +- Mobile number +- Date and place of birth +- Digital identification credentials, e.g., email addresses, usernames, avatars + +These traditional examples of identifiers are issued, held and controlled by central entities. You need permission from your government to change your name or from a social media platform to change your handle. + +## What are attestations? {#what-are-attestations} + +An attestation is a claim made by one entity about another entity. If you live in the United States, the driver's license issued to you by the Department of Motor Vehicles (one entity) attests that you (another entity) are legally allowed to drive a car. + +Attestations are different from identifiers. An attestation _contains_ identifiers to reference a particular identity, and makes a claim about an attribute related to this identity. So, your driver's license has identifiers (name, date of birth, address) but is also the attestation about your legal right to drive. + +### What are decentralized identifiers? {#what-are-decentralized-identifiers} + +Traditional identifiers like your legal name or email address rely on third parties—governments and email providers. Decentralized identifiers (DIDs) are different—they aren't issued, managed, or controlled by any central entity. + +Decentralized identifiers are issued, held, and controlled by individuals. An [Ethereum account](/developers/docs/accounts/) is an example of a decentralized identifier. You can create as many accounts as you want without permission from anyone and without the need to store them in a central registry. + +Decentralized identifiers are stored on distributed ledgers (blockchains) or peer-to-peer networks. This makes DIDs [globally unique, resolvable with high availability, and cryptographically verifiable](https://w3c-ccg.github.io/did-primer/). A decentralized identifier can be associated with different entities, including people, organizations, or government institutions. + +## What makes decentralized identifiers possible? {#what-makes-decentralized-identifiers-possible} + +### 1. Public Key Infrastructure (PKI) {#public-key-infrastructure} + +Public-key infrastructure (PKI) is an information security measure that generates a [public key](/glossary/#public-key) and [private key](/glossary/#private-key) for an entity. Public-key cryptography is used in blockchain networks to authenticate user identities and prove ownership of digital assets. + +Some decentralized identifiers, such as an Ethereum account, have public and private keys. The public key identifies the account's controller, while the private keys can sign and decrypt messages for this account. PKI provides proofs needed to authenticate entities and prevent impersonation and use of fake identities, using [cryptographic signatures](https://andersbrownworth.com/blockchain/public-private-keys/) to verify all claims. + +### 2. Decentralized datastores {#decentralized-datastores} + +A blockchain serves as a verifiable data registry: an open, trustless, and decentralized repository of information. The existence of public blockchains eliminates the need to store identifiers in centralized registries. + +If anyone needs to confirm the validity of a decentralized identifier, they can look up the associated public key on the blockchain. This is different from traditional identifiers that require third parties to authenticate. + +## How do decentralized identifiers and attestations enable decentralized identity? {#how-decentralized-identifiers-and-attestations-enable-decentralized-identity} + +Decentralized identity is the idea that identity-related information should be self-controlled, private, and portable, with decentralized identifiers and attestations being the primary building blocks. + +In the context of decentralized identity, attestations (also known as [Verifiable Credentials](https://www.w3.org/TR/vc-data-model/)) are tamper-proof, cryptographically verifiable claims made by the issuer. Every attestation or Verifiable Credential an entity (e.g., an organization) issues is associated with their DID. + +Because DIDs are stored on the blockchain, anyone can verify the validity of an attestation by cross-checking the issuer's DID on Ethereum. Essentially, the Ethereum blockchain acts like a global directory that enables the verification of DIDs associated with certain entities. + +Decentralized identifiers are the reason attestations are self-controlled and verifiable. Even if the issuer doesn't exist anymore, the holder always has proof of the attestation's provenance and validity. + +Decentralized identifiers are also crucial to protecting the privacy of personal information through decentralized identity. For instance, if an individual submits proof of an attestation (a driver's license), the verifying party doesn't need to check the validity of information in the proof. Instead, the verifier only needs cryptographic guarantees of the attestation's authenticity and the identity of the issuing organization to determine if the proof is valid. + +## Types of attestations in decentralized identity {#types-of-attestations-in-decentralized-identity} + +How attestation information is stored and retrieved in an Ethereum-based identity ecosystem is different from traditional identity management. Here is an overview of the various approaches to issuing, storing, and verifying attestations in decentralized identity systems: + +### Off-chain attestations {#off-chain-attestations} + +One concern with storing attestations on-chain is that they might contain information individuals want to keep private. The public nature of the Ethereum blockchain makes it unattractive to store such attestations. + +The solution is to issue attestations, held by users off-chain in digital wallets, but signed with the issuer's DID stored on-chain. These attestations are encoded as [JSON Web Tokens](https://en.wikipedia.org/wiki/JSON_Web_Token) and contain the issuer's digital signature—which allows for easy verification of off-chain claims. + +Here's an hypothetical scenario to explain off-chain attestations: + +1. A university (the issuer) generates an attestation (a digital academic certificate), signs with its keys, and issues it to Bob (the identity owner). + +2. Bob applies for a job and wants to prove his academic qualifications to an employer, so he shares the attestation from his mobile wallet. The company (the verifier) can then confirm the validity of the attestation by checking the issuer's DID (i.e., its public key on Ethereum). + +### Off-chain attestations with persistent access {#offchain-attestations-with-persistent-access} + +Under this arrangement attestations are transformed into JSON files and stored off-chain (ideally on a [decentralized cloud storage](/developers/docs/storage/) platform, such as IPFS or Swarm). However, a [hash](/glossary/#hash) of the JSON file is stored on-chain and linked to a DID via an on-chain registry. The associated DID could either be that of the issuer of the attestation or the recipient. + +This approach enables attestations to gain blockchain-based persistence, while keeping claims information encrypted and verifiable. It also allows for selective disclosure since the holder of the private key can decrypt the information. + +### On-chain attestations {#onchain-attestations} + +On-chain attestations are held in [smart contracts](/developers/docs/smart-contracts/) on the Ethereum blockchain. The smart contract (acting as a registry) will map an attestation to a corresponding on-chain decentralized identifier (a public key). + +Here's an example to show how on-chain attestations might work in practice: + +1. A company (XYZ Corp) plans to sell ownership shares using a smart contract but only wants buyers that have completed a background check. + +2. XYZ Corp can have the company performing background checks to issue on-chain attestations on Ethereum. This attestation certifies that an individual has passed the background check without exposing any personal information. + +3. The smart contract selling shares can check the registry contract for the identities of screened buyers, making it possible for the smart contract to determine who is permitted to buy shares or not. + +## Benefits of decentralized identity {#benefits-of-decentralized-identity} + +1. Decentralized identity increases individual control of identifying information. Decentralized identifiers and attestations can be verified without relying on centralized authorities and third-party services. + +2. Decentralized identity solutions facilitates a trustless, seamless, and privacy-protecting method for verifying and managing user identity. + +3. Decentralized identity harnesses blockchain technology, which creates trust between different parties and provides cryptographic guarantees to prove the validity of attestations. + +4. Decentralized identity makes identity data portable. Users store attestations and identifiers in mobile wallet and can share with any party of their choice. Decentralized identifiers and attestations are not locked into the database of the issuing organization. + +## Decentralized identity use-cases {#decentralized-identity-use-cases} + +Decentralized identity has many potential use-cases: + +### 1. Universal logins {#universal-dapp-logins} + +Decentralized identity can help replace password-based logins with [decentralized authentication](https://www.ibm.com/blogs/blockchain/2018/10/decentralized-identity-an-alternative-to-password-based-authentication/). Service providers can can issue attestations to users, which can be stored in an Ethereum wallet. An example attestation would be an [NFT](/nft/) granting the holder access to an online community. + +A [Sign-In with Ethereum](https://login.xyz/) function would then enable servers to confirm the user's Ethereum account and fetch the required attestation from their account address. This means users can access platforms and websites without having to memorize long passwords and improves the online experience for users. + +### 2. KYC authentication {#kyc-authentication} + +Using many online services requires individuals to provide attestations and credentials, such as a driving license or national passport. But this approach is problematic because private user information can be compromised and service providers cannot verify the authenticity of the attestation. + +Decentralized identity allows companies to skip on conventional [Know-Your-Customer (KYC)](https://en.wikipedia.org/wiki/Know_your_customer) processes and authenticate user identities via Verifiable Credentials. This reduces the cost of identity management and prevents the use of fake documentation. + +### 3. Voting and online communities {#voting-and-online-communities} + +Online voting and social media are two novel applications for decentralized identity. Online voting schemes are susceptible to manipulation, especially if malicious actors create false identities to vote. Asking individuals to present on-chain attestations can improve the integrity of online voting processes. + +Decentralized identity can help create online communities that are free of fake accounts. For example, each user might have to authenticate their identity using an on-chain identity system, like the Ethereum Name Service, reducing the possibility of bots. + +## Use decentralized identity {#use-decentralized-identity} + +There are many ambitious projects using Ethereum as a foundation for decentralized identity solutions: + +- **[Ethereum Name Service (ENS)](https://ens.domains/)** - _A decentralized naming system for on-chain, machine-readable identifiers, like, Ethereum wallet addresses, content hashes, and metadata._ +- **[SpruceID](https://www.spruceid.com/)** - _A decentralized identity project which allows users to control digital identity with Ethereum accounts and ENS profiles instead of relying on third-party services._ +- **[Proof of Humanity](https://www.proofofhumanity.id)** - _Proof of Humanity (or PoH) is a social identity verification system built on Ethereum._ +- **[BrightID](https://www.brightid.org/)** - _A decentralized, open-source social identity network seeking to reform identity verification through the creation and analysis of a social graph._ + +## Further reading {#further-reading} + +### Articles {#articles} + +- [Blockchain Use Cases: Blockchain in Digital Identity](https://consensys.net/blockchain-use-cases/digital-identity/) — _ConsenSys_ +- [What is Ethereum ERC725? Self-Sovereign Identity Management on the Blockchain](https://cryptoslate.com/what-is-erc725-self-sovereign-identity-management-on-the-blockchain/) — _Sam Town_ +- [How Blockchain Could Solve the Problem of Digital Identity](https://time.com/6142810/proof-of-humanity/) — _Andrew R. Chow_ +- [What Is Decentralized Identity And Why Should You Care?](https://web3.hashnode.com/what-is-decentralized-identity) — _Emmanuel Awosika_ + +### Videos {#videos} + +- [Decentralized Identity (Bonus Livestream Session)](https://www.youtube.com/watch?v=ySHNB1za_SE&t=539s) — _A great explainer video on decentralized identity by Andreas Antonopolous_ +- [Sign In with Ethereum and Decentralized Identity with Ceramic, IDX, React, and 3ID Connect](https://www.youtube.com/watch?v=t9gWZYJxk7c) — _YouTube utorial on building out an identity management system for creating, reading, and updating a user's profile using their Ethereum wallet by Nader Dabit_ +- [BrightID - Decentralized Identity on Ethereum](https://www.youtube.com/watch?v=D3DbMFYGRoM) — _Bankless podcast episode discussing BrightID, a decentralized identity solution for Ethereum_ +- [The Off Chain Internet: Decentralized Identity & Verifiable Credentials](https://www.youtube.com/watch?v=EZ_Bb6j87mg) — EthDenver 2022 presentation by Evin McMullen + +### Communities {#communities} + +- [ERC-725 Alliance on GitHub](https://github.com/erc725alliance) — _Supporters of the ERC725 standard for managing identity on the Ethereum blockchain_ +- [SpruceID Discord server](https://discord.com/invite/Sf9tSFzrnt) — _Community for enthusiasts and developers working on Sign-in with Ethereum_ diff --git a/src/intl/en/common.json b/src/intl/en/common.json index 2fbbff65e04..c971ac5224b 100644 --- a/src/intl/en/common.json +++ b/src/intl/en/common.json @@ -267,5 +267,6 @@ "dao-page": "Decentralized autonomous organisations (DAOs)", "nft-page": "Non-fungible tokens (NFTs)", "decentralized-social-networks": "Decentralized social networks", + "decentralized-identity": "Decentralized identity", "yes": "Yes" } diff --git a/src/intl/en/template-usecase.json b/src/intl/en/template-usecase.json index 0a7756bd286..2d154f9ab6e 100644 --- a/src/intl/en/template-usecase.json +++ b/src/intl/en/template-usecase.json @@ -3,6 +3,7 @@ "template-usecase-dropdown-nft": "Non-fungible tokens (NFTs)", "template-usecase-dropdown-dao": "Decentralized autonomous organisations (DAOs)", "template-usecase-dropdown-social-networks": "Decentralized social networks", + "template-usecase-dropdown-identity": "Decentralized identity", "template-usecase-dropdown": "Ethereum use cases", "template-usecase-banner": "Uses of Ethereum are always developing and evolving. Add any info you think will make things clearer or more up to date.", "template-usecase-edit-link": "Edit page", diff --git a/src/templates/use-cases.js b/src/templates/use-cases.js deleted file mode 100644 index ed9cf489e67..00000000000 --- a/src/templates/use-cases.js +++ /dev/null @@ -1,448 +0,0 @@ -import React from "react" -import { graphql } from "gatsby" -import { MDXProvider } from "@mdx-js/react" -import { MDXRenderer } from "gatsby-plugin-mdx" -import styled from "styled-components" -import { GatsbyImage, getImage } from "gatsby-plugin-image" -import ButtonLink from "../components/ButtonLink" -import ButtonDropdown from "../components/ButtonDropdown" -import BannerNotification from "../components/BannerNotification" -import Card from "../components/Card" -import ExpandableCard from "../components/ExpandableCard" -import DocLink from "../components/DocLink" -import Icon from "../components/Icon" -import Contributors from "../components/Contributors" -import InfoBanner from "../components/InfoBanner" -import UpgradeStatus from "../components/UpgradeStatus" -import Link from "../components/Link" -import MarkdownTable from "../components/MarkdownTable" -import Logo from "../components/Logo" -import MeetupList from "../components/MeetupList" -import PageMetadata from "../components/PageMetadata" -import Pill from "../components/Pill" -import RandomAppList from "../components/RandomAppList" -import Roadmap from "../components/Roadmap" -import UpgradeTableOfContents from "../components/UpgradeTableOfContents" -import TableOfContents from "../components/TableOfContents" -import TranslationsInProgress from "../components/TranslationsInProgress" -import Translation from "../components/Translation" -import SectionNav from "../components/SectionNav" -import { isLangRightToLeft } from "../utils/translations" -import { getSummaryPoints } from "../utils/getSummaryPoints" -import { - Divider, - Paragraph, - Header1, - Header4, -} from "../components/SharedStyledComponents" -import Emoji from "../components/Emoji" -import YouTube from "../components/YouTube" - -const Page = styled.div` - display: flex; - justify-content: space-between; - width: 100%; - margin: 0 auto 4rem; - - @media (min-width: ${(props) => props.theme.breakpoints.l}) { - padding-top: 4rem; - } - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - flex-direction: column; - } -` - -const InfoColumn = styled.aside` - display: flex; - flex-direction: column; - position: sticky; - top: 6.25rem; /* account for navbar */ - height: calc(100vh - 80px); - flex: 0 1 400px; - margin-right: 4rem; - margin-left: 2rem; - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - display: none; - } -` - -const MobileButton = styled.div` - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - background: ${(props) => props.theme.colors.background}; - box-shadow: 0 -1px 0px ${(props) => props.theme.colors.border}; - width: 100%; - bottom: 0; - position: sticky; - padding: 2rem; - z-index: 99; - margin-bottom: 0rem; - } -` - -// Apply styles for classes within markdown here -const ContentContainer = styled.article` - flex: 1 1 ${(props) => props.theme.breakpoints.l}; - position: relative; - padding: 2rem; - padding-top: 0rem; - - .featured { - padding-left: 1rem; - margin-left: -1rem; - border-left: 1px dotted ${(props) => props.theme.colors.primary}; - } - - .citation { - p { - color: ${(props) => props.theme.colors.text200}; - } - } -` - -const Pre = styled.pre` - max-width: 100%; - overflow-x: scroll; - background-color: ${(props) => props.theme.colors.preBackground}; - border-radius: 0.25rem; - padding: 1rem; - border: 1px solid ${(props) => props.theme.colors.preBorder}; - white-space: pre-wrap; -` - -const InfoTitle = styled.h2` - font-size: 3rem; - font-weight: 700; - text-align: right; - margin-top: 0rem; - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - text-align: left; - font-size: 2.5rem - display: none; - } -` - -const H2 = styled.h2` - font-size: 2rem; - font-weight: 700; - margin-top: 4rem; -` - -const H3 = styled.h3` - font-size: 1.5rem; - font-weight: 700; -` - -// Note: you must pass components to MDXProvider in order to render them in markdown files -// https://www.gatsbyjs.com/plugins/gatsby-plugin-mdx/#mdxprovider -const components = { - a: Link, - h1: Header1, - h2: H2, - h3: H3, - h4: Header4, - p: Paragraph, - pre: Pre, - table: MarkdownTable, - MeetupList, - RandomAppList, - Roadmap, - Logo, - ButtonLink, - Contributors, - InfoBanner, - Card, - Divider, - SectionNav, - Pill, - TranslationsInProgress, - Emoji, - UpgradeStatus, - DocLink, - ExpandableCard, - YouTube, -} - -const Title = styled.h1` - font-size: 2.5rem; - font-weight: 700; - margin-top: 1rem; -` - -const SummaryPoint = styled.li` - font-size: 1rem; - color: ${(props) => props.theme.colors.text300}; - margin-bottom: 0rem; - line-height: auto; -` - -const SummaryBox = styled.div`` - -const StyledButtonDropdown = styled(ButtonDropdown)` - margin-bottom: 2rem; - display: flex; - justify-content: flex-end; - text-align: center; - @media (min-width: ${(props) => props.theme.breakpoints.s}) { - align-self: flex-end; - } -` - -const StyledEmoji = styled(Emoji)` - margin-right: 1rem; - flex-shrink: 0; -` - -const MobileButtonDropdown = styled(StyledButtonDropdown)` - margin-bottom: 0rem; - @media (min-width: ${(props) => props.theme.breakpoints.l}) { - display: none; - } -` - -const Container = styled.div` - position: relative; -` - -const HeroContainer = styled.div` - background: ${(props) => props.theme.colors.cardGradient}; - box-shadow: inset 0px -1px 0px rgba(0, 0, 0, 0.1); - display: flex; - justify-content: flex-end; - max-height: 608px; - min-height: 608px; - width: 100%; - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - flex-direction: column-reverse; - max-height: 100%; - } -` - -const Image = styled(GatsbyImage)` - flex: 1 1 100%; - background-size: cover; - background-repeat: no-repeat; - right: 0; - bottom: 0; - background-size: cover; - max-width: ${({ useCase }) => - useCase === `dao` ? `572px` : useCase === `defi` ? `80%` : `640px`}; - @media (max-width: ${({ theme }) => theme.breakpoints.l}) { - width: 100%; - height: 100%; - max-height: 340px; - max-width: ${({ useCase }) => - useCase === "defi" ? "100%" : "min(405px, 98%)"}; - overflow: initial; - align-self: center; - margin: 0; - } -` - -const MoreContent = styled(Link)` - width: 100%; - background: ${(props) => props.theme.colors.ednBackground}; - padding: 1rem; - display: flex; - justify-content: center; - &:hover { - background: ${(props) => props.theme.colors.background}; - } - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - display: none; - } -` - -const MobileTableOfContents = styled(TableOfContents)` - position: relative; - z-index: 2; -` - -const StyledBannerNotification = styled(BannerNotification)` - display: flex; - justify-content: center; - @media (max-width: ${({ theme }) => theme.breakpoints.l}) { - display: none; - } -` - -const TitleCard = styled.div` - background: ${(props) => props.theme.colors.background}; - border: 1px solid ${(props) => props.theme.colors.border}; - box-shadow: ${(props) => props.theme.colors.cardBoxShadow}; - padding: 2rem; - display: flex; - position: absolute; - left: 6rem; - top: 6rem; - flex-direction: column; - justify-content: flex-start; - border-radius: 2px; - z-index: 10; - max-width: 640px; - margin-top: 3rem; - @media (max-width: ${(props) => props.theme.breakpoints.l}) { - max-width: 100%; - position: relative; - left: 0rem; - top: 0rem; - background: ${(props) => props.theme.colors.ednBackground}; - box-shadow: none; - margin-top: 0; - } -` - -const UseCasePage = ({ data, pageContext }) => { - const mdx = data.pageData - const isRightToLeft = isLangRightToLeft(mdx.frontmatter.lang) - const tocItems = mdx.tableOfContents.items - const summaryPoints = getSummaryPoints(mdx.frontmatter) - - const { editContentUrl } = data.siteData.siteMetadata - const { relativePath } = pageContext - const absoluteEditPath = `${editContentUrl}${relativePath}` - - let useCase = "defi" - if (pageContext.slug.includes("dao")) { - useCase = "dao" - } - if (pageContext.slug.includes("nft")) { - useCase = "nft" - } - - const dropdownLinks = { - text: "template-usecase-dropdown", - ariaLabel: "template-usecase-dropdown-aria", - items: [ - { - text: "template-usecase-dropdown-defi", - to: "/defi/", - }, - { - text: "template-usecase-dropdown-nft", - to: "/nft/", - }, - { - text: "template-usecase-dropdown-dao", - to: "/dao/", - }, - { - text: "template-usecase-dropdown-social-networks", - to: "/social-networks/", - }, - ], - } - - return ( - - - -
- {" "} - - - -
-
- - - - {mdx.frontmatter.title} - -
    - {summaryPoints.map((point, idx) => ( - {point} - ))} -
-
- -
- {mdx.frontmatter.alt} -
- - - - - - - - {mdx.frontmatter.title} - - {mdx.frontmatter.sidebar && tocItems && ( - - )} - - - - {mdx.body} - - - - - - -
- ) -} - -export const useCasePageQuery = graphql` - query UseCasePageQuery($relativePath: String) { - siteData: site { - siteMetadata { - editContentUrl - } - } - pageData: mdx(fields: { relativePath: { eq: $relativePath } }) { - fields { - slug - } - frontmatter { - title - description - lang - sidebar - emoji - sidebarDepth - summaryPoint1 - summaryPoint2 - summaryPoint3 - alt - image { - childImageSharp { - gatsbyImageData( - layout: FULL_WIDTH - placeholder: BLURRED - quality: 100 - ) - } - } - isOutdated - } - body - tableOfContents - parent { - ... on File { - mtime - fields { - gitLogLatestDate - } - } - } - } - } -` - -export default UseCasePage diff --git a/src/templates/use-cases.tsx b/src/templates/use-cases.tsx index b9f1fb67e11..c7c6f06c007 100644 --- a/src/templates/use-cases.tsx +++ b/src/templates/use-cases.tsx @@ -320,6 +320,14 @@ const UseCasePage = ({ if (pageContext.slug.includes("nft")) { useCase = "nft" } + // Use the same styling as DeFi page for hero image + if (pageContext.slug.includes("social")) { + useCase = "defi" + } + // Use the same styling as DAOs page for hero image + if (pageContext.slug.includes("identity")) { + useCase = "dao" + } const dropdownLinks = { text: "template-usecase-dropdown", @@ -337,6 +345,14 @@ const UseCasePage = ({ text: "template-usecase-dropdown-dao", to: "/dao/", }, + { + text: "template-usecase-dropdown-social-networks", + to: "/social-networks/", + }, + { + text: "template-usecase-dropdown-identity", + to: "/decentralized-identity/", + }, ], }