+ TLSNotary leverages the ubiquitous TLS (Transport Layer Security) protocol to securely and privately prove a transcript of communications took place with a webserver.
+
+
+ At the core of the TLSNotary protocol is dividing TLS session keys between two parties (Client and Notary) and then using secure two-party computation (2PC) to encrypt and authenticate requests from the Client to a TLS-enabled webserver.
+
+
+ During the protocol neither the Client nor Notary are in posession of the full TLS session keys, they only know their shares of those keys.
+ This preserves the security assumptions of TLS while at the same time allows the Client to prove to the Notary the authenticity of the transcript.
+
+
+ This is all achieved with full privacy. The Notary is never aware of which webserver is being queried, nor do they ever see the unencrypted communications.
+
+
+ Furthermore, our protocol is transparent to the webserver.
+ In fact, the webserver is never aware that this process took place.
+
+ With TLSNotary, you can create cryptographic proofs of authenticity for any data on the web, even your private data.
+ Using our protocol you can securely prove:
+
+
+
+
+
+
+
Private information about yourself.
+
+
+
+
+
+
You received a private message from someone.
+
+
+
+
+
+
You received a money transfer.
+
+
+
+
+
+
A snapshot of a webpage.
+
+
+
+
+
+
You were blocked from using an app.
+
+
+
+
+
+
You have access to an account.
+
+
+
+
+
Is it secure?
+
+
+ One may assume that TLSNotary requires a “man-in-the-middle” setup where the Notary snoops on the connection with the webserver.
+ Fortunately, this is not true! Data is kept private even from the Notary.
+
+
+ See below for more details on how it works.
+
+
+
What's the catch?
+
+
+ TLSNotary does require a trust assumption.
+ A Verifier of a proof must trust that the Notary did not collude with the Prover to forge it.
+ This trust can be minimized by requiring multiple proofs each signed by different Notaries.
+
+
+ In some applications the Verifier can act as the Notary themselves, which allows for fully trustless proofs!
+
+
+
+ );
+}
diff --git a/src/config.json b/src/config.json
new file mode 100644
index 0000000..8bf7a67
--- /dev/null
+++ b/src/config.json
@@ -0,0 +1,9 @@
+{
+ "links": {
+ "discord": "https://discord.gg/9XwESXtcN7",
+ "repo": "https://github.com/tlsnotary/tlsn",
+ "docs": "https://docs.tlsnotary.org",
+ "pse": "https://appliedzkp.org/",
+ "legacy": "https://old.tlsnotary.org/"
+ }
+}
diff --git a/src/data/Example.md b/src/data/Example.md
deleted file mode 100644
index abf79a7..0000000
--- a/src/data/Example.md
+++ /dev/null
@@ -1,57 +0,0 @@
-# Examples
-
-## Project Example
-
-```json
- {
- "name": "Test",
- "short_name": "TEST",
- "description": "Black Magic",
- "long_description": "Black Magic",
- "image": "banner.png",
- "links": [
- {
- "website": "https://discord.gg"
- },
- {
- "twitter": "https://discord.gg/1"
- },
- {
- "telegram": "https://discord.gg/2"
- },
- {
- "discord": "https://discord.gg/3"
- },
- {
- "github": "https://discord.gg/4"
- }
- ]
-}
-```
-
-## Team Member Example
-
-```json
- {
- "name": "NAME / USERNAME",
- "description": "Whatever description you want, try to keep it tweet sized",
- "image": "{filename}(Upload image to /src/images and put the file name here, will add support for external images soon)",
- "links": [
- {
- "github": "https://github.com/USERNAME"
- },
- {
- "twitter": "https://twitter.com/USERNAME"
- },
- {
- "discord": "https://discord.com//users/USER_ID (NOT USERNAME, https://i.imgur.com/6CDZ1dp.gifv for how-to)"
- },
- {
- "telegram": "t.me/USERNAME"
- },
- {
- "website": "{YOUR_WEBSITE}"
- }
- ]
- }
-```
diff --git a/src/data/Projects.json b/src/data/Projects.json
deleted file mode 100644
index fa00be2..0000000
--- a/src/data/Projects.json
+++ /dev/null
@@ -1,247 +0,0 @@
-[
- {
- "name": "Zkopru",
- "image": "zkopru-cover.png",
- "description": "Zkopru is an optimistic rollup that uses zero knowledge proofs to enable private, low-cost transactions with ETH, ERC-20s and NFTs on layer 2.",
- "links": [
- {
- "website": "https://zkopru.network/"
- },
- {
- "github": "https://github.com/zkopru-network"
- },
- {
- "discord": "https://discord.gg/R8QKzad8u4"
- }
- ]
- },
- {
- "name": "WAX",
- "image": "wax.png",
- "description": "Formerly BLS Wallet. Reduce transaction costs on evm-L2s using BLS signatures. The smart contract wallet also includes: recovery, multi-action, gas-less transactions, and upgradability. Expanding verification options via 4337 compatibility.",
- "links": [
- {
- "website": "https://getwax.org/"
- },
- {
- "github": "https://github.com/web3well/bls-wallet"
- }
- ]
- },
- {
- "name": "zkEVM",
- "image": "zkEVM.svg",
- "description": "A zk-rollup that can generate zk proofs for general EVM verification. This allows us to build a fully EVM-compatible zk-Rollup, which any existing Ethereum application can easily migrate to.",
- "links": [
- {
- "documentation": "https://privacy-scaling-explorations.github.io/zkevm-docs/"
- },
- {
- "website": "https://github.com/privacy-scaling-explorations/zkevm-specs"
- },
- {
- "github": "https://github.com/privacy-scaling-explorations/zkevm-circuits"
- }
- ]
- },
- {
- "name": "MACI",
- "image": "MACI.svg",
- "description": "MACI (Minimal Anti-Collusion Infrastructure) uses zero knowledge proofs for collusion resistance in blockchain voting (such as quadratic funding mechanisms) by making it impossible for anyone other than the vote coordinator to verify how a specific user voted. MACI also ensures correct execution of the votes, allowing anyone to verify the results.",
- "links": [
- {
- "website": ""
- },
- {
- "github": "https://github.com/appliedzkp/maci"
- }
- ]
- },
- {
- "name": "UniRep",
- "description": "UniRep (Universal Reputation) is a private and non-repudiable data storage and retrieval system. Applications can attest to changes in user data using short lived identifiers called epoch keys. The high-level goal for UniRep is to be a base layer on top of which anyone can easily build custom, yet interoperable, zk applications. UniRep acts as a memory layer for zk: anything stored in UniRep can be retrieved and proven with strong privacy guarantees and constant computation complexity. UniRep can be used to store the result of large proofs (e.g. proof of Ethereum address control from an ECDSA signature). This result can later be retrieved and proven by a user any number of times. Similar patterns exist for web2 authentication bridging; a user oauths with a trusted entity once, and the entity attests storing information about the users web2 identity in zk. UniRep can be used to store data important to applications. This might include reputation the user has accrued, actions the user has taken, groups the user is a member of, or anything else. Applications can interoperate by having users make proofs using publicly available state roots.",
- "image": "unirep.svg",
- "links": [
- {
- "website": "https://developer.unirep.io/"
- },
- {
- "github": "https://github.com/unirep"
- },
- {
- "discord": "https://discord.gg/qrqq8SeN7F"
- }
- ]
- },
- {
- "name": "Semaphore",
- "description": "Semaphore is a protocol, designed to be a simple and generic privacy layer for Ethereum DApps. Using zero knowledge, Ethereum users can prove their membership of a group and send signals such as votes or endorsements without revealing their original identity.",
- "image": "semaphore.svg",
- "links": [
- {
- "website": "https://semaphore.appliedzkp.org/"
- },
- {
- "github": "https://semaphore.appliedzkp.org/github"
- },
- {
- "discord": "https://semaphore.appliedzkp.org/discord"
- }
- ]
- },
- {
- "name": "ZK-kit",
- "description": "ZK-kit is a set of NPM modules (algorithms or utility functions) that can be reused in different projects and zero-knowledge protocols, making it easier for developers to access ready-to-use and tested libraries for common tasks.",
- "image": "zk-kit.svg",
- "links": [
- {
- "github": "https://github.com/privacy-scaling-explorations/zk-kit"
- }
- ]
- },
- {
- "name": "Interep",
- "description": "Private reputation and identity system allowing services to verify that users belong to a certain group or meet certain reputation criteria without revealing their identities. Users can anonymously export reputation from platforms such as Twitter and Github.",
- "image": "interep.svg",
- "links": [
- {
- "website": "https://interep.link/"
- },
- {
- "github": "https://github.com/interep-project"
- }
- ]
- },
- {
- "name": "Clr.fund for Everyone",
- "short_name": "Clr.fund",
- "image": "clr.svg",
- "description": "Infrastructure to make it easy for any community to run their own CLR round with clr.fund.",
- "links": [
- {
- "website": "https://qf.ethprague.com/"
- },
- {
- "documentation": "https://clrfund.gitbook.io/deployer/"
- },
- {
- "github": "https://github.com/quadratic-funding/qfi"
- }
- ]
- },
- {
- "name": "Rate Limiting Nullifier",
- "short_name": "RLN",
- "image": "rln.svg",
- "description": "RLN is a construct based on zero-knowledge proofs that enables spam prevention mechanism for decentralized, anonymous environments. In anonymous environments, the identity of the entities is unknown.",
- "links": [
- {
- "website": "https://rate-limiting-nullifier.github.io/rln-docs/"
- },
- {
- "github": "https://github.com/Rate-Limiting-Nullifier/"
- }
- ]
- },
- {
- "name": "zk-chat",
- "image": "zkchat.svg",
- "description": "Anonymous and private chat environments, using Interep for a privacy preserving registry and sybil resistance and RLN for spam protection.",
- "links": [
- {
- "website": "https://zkchat.org"
- },
- {
- "github": "https://github.com/njofce/zk-chat"
- }
- ]
- },
- {
- "name": "COCO",
- "description": "Collaborative content curation of online communities using a double-or-nothing challenge mechanism.",
- "image": "Coco.svg",
- "links": [
- {
- "website": "https://www.cocoverse.club/"
- },
- {
- "github": "https://github.com/Janmajayamall/coco-contracts"
- },
- {
- "telegram": "https://t.me/+A47HJeqh0-tlODI1"
- }
- ]
- },
- {
- "name": "Trusted Setup",
- "image": "trust-setup.svg",
- "description": "Open source infrastructure for running a trusted setup ceremony in which many people participate in generating entropy which will secure a cryptographic protocol. Perpetual Powers of Tau: A universal ceremony for the initial phase of a trusted setup. MPC Phase 2 UI: UI for a CLI or browser-based ceremony for the second, circuit-specific phase for Groth-16 SNARKs. MPC Phase2 Suite: All-in-one suite of tools for conducting Phase 2 Trusted Setup ceremonies for multiple and large Groth-16 SNARKs circuits.",
- "links": [
- {
- "github": "https://github.com/privacy-scaling-explorations/perpetualpowersoftau"
- },
- {
- "github": "https://github.com/zkparty/setup-mpc-ui"
- },
- {
- "github": "https://github.com/quadratic-funding/mpc-phase2-suite"
- }
- ]
- },
- {
- "name": "TLSNotary",
- "short_name": "TLSN",
- "description": "TLSNotary leverages the ubiquitous TLS protocol to allow users to privately export their data from any webserver in a provable way.",
- "image": "tlsn.png",
- "links": [
- {
- "website": "https://tlsnotary.org"
- },
- {
- "github": "https://github.com/tlsnotary/tlsn"
- },
- {
- "discord": "https://discord.gg/9XwESXtcN7"
- }
- ]
- },
- {
- "name": "Crypt-Keeper",
- "short_name": "Crypt-Keeper",
- "description": "Crypt-Keeper is a Zero knowledge identity management and proof generation",
- "image": "zk-keeper.png",
- "links": [
- {
- "github": "https://github.com/privacy-scaling-explorations/crypt-keeper-extension"
- }
- ]
- },
- {
- "name": "Bandada",
- "short_name": "Bandada",
- "description": "An open-source system for managing privacy-preserving groups.",
- "image": "bandada.svg",
- "links": [
- {
- "github": "https://github.com/privacy-scaling-explorations/zk-groups"
- }
- ]
- },
- {
- "name": "Channel 4",
- "short_name": "Channel 4",
- "description": "Discover the unexpected with State Channel.",
- "image": "channel4.svg",
- "links": [
- {
- "website": "https://channel4.wtf//"
- },
- {
- "github": "https://github.com/State-Channel-4"
- },
- {
- "discord": "https://discord.gg/76UrYgVyEx"
- }
- ]
- }
-]
diff --git a/src/data/Team.json b/src/data/Team.json
deleted file mode 100644
index e880a8c..0000000
--- a/src/data/Team.json
+++ /dev/null
@@ -1,166 +0,0 @@
-[
- {
- "name": "sinu",
- "description": "TLSNotary Project Lead and Software Engineer",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/sinui0"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/sinu_eth"
- }
- ]
- },
- {
- "name": "AtHeartEngineer",
- "description": "Full stack / systems engineer; working on RLN",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/atheartengineer"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/atheartengineer"
- }
- ]
- },
- {
- "name": "Geoff Lamperd",
- "description": "Full stack engineer; working on Trusted Setup and Interep",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/glamperd"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/glamperd"
- }
- ]
- },
- {
- "name": "James Zaki",
- "description": "WAX project lead and software engineer",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/jzaki"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/james_zaki"
- }
- ]
- },
- {
- "name": "Beyondr (Jeo)",
- "description": "Designer & developer. Main project is ZKOPRU at the moment but also working on other auxiliary projects.",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/thebeyondr"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/thebeyondr"
- }
- ]
- },
- {
- "name": "Jacob Caban-Tomski",
- "description": "Full stack engineer; working on BLS Wallet",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/jacque006"
- }
- ]
- },
- {
- "name": "Chiali",
- "description": "Pollen Labs team lead. Building the best experience for freedom & humanity",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/ChialiT"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/Chia_Tea"
- }
- ]
- },
- {
- "name": "Cedoor",
- "description": "Software engineer; working on Semaphore and related projects",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/cedoor"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/cedoor_"
- }
- ]
- },
- {
- "name": "Rachel",
- "description": "Design strategy for ZK explorations",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/rachelaux"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/rachel_aux"
- }
- ]
- },
- {
- "name": "Andy",
- "description": "Product owner; working on Semaphore and other projects",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/aguzmant103"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/AndyGuzmanEth"
- }
- ]
- },
- {
- "name": "Vivian",
- "description": "Unirep Project Lead and Software Engineer",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/vivianjeng"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/vivi4322"
- }
- ]
- },
- {
- "name": "0xjei",
- "description": "Software Engineer; working on MACI/QFI and Trusted Setup",
- "links": [
- {
- "provider": "github",
- "url": "https://github.com/0xjei"
- },
- {
- "provider": "twitter",
- "url": "https://twitter.com/0xjei"
- }
- ]
- }
-]
diff --git a/src/images/Coco.svg b/src/images/Coco.svg
deleted file mode 100644
index a908b0b..0000000
--- a/src/images/Coco.svg
+++ /dev/null
@@ -1,44 +0,0 @@
-
diff --git a/src/images/MACI.svg b/src/images/MACI.svg
deleted file mode 100644
index eb1c80a..0000000
--- a/src/images/MACI.svg
+++ /dev/null
@@ -1,13 +0,0 @@
-
diff --git a/src/images/arrow-down.svg b/src/images/arrow-down.svg
deleted file mode 100644
index 08bed66..0000000
--- a/src/images/arrow-down.svg
+++ /dev/null
@@ -1,10 +0,0 @@
-
diff --git a/src/images/banner.png b/src/images/banner.png
deleted file mode 100644
index b953f12..0000000
Binary files a/src/images/banner.png and /dev/null differ
diff --git a/src/images/box_arrow_out.svg b/src/images/box_arrow_out.svg
deleted file mode 100644
index bfad9a1..0000000
--- a/src/images/box_arrow_out.svg
+++ /dev/null
@@ -1,3 +0,0 @@
-
diff --git a/src/images/clr.svg b/src/images/clr.svg
deleted file mode 100644
index d912614..0000000
--- a/src/images/clr.svg
+++ /dev/null
@@ -1,20 +0,0 @@
-
diff --git a/src/images/coco.png b/src/images/coco.png
deleted file mode 100644
index bc0c8c6..0000000
Binary files a/src/images/coco.png and /dev/null differ
diff --git a/src/images/docs.svg b/src/images/docs.svg
new file mode 100644
index 0000000..3df9843
--- /dev/null
+++ b/src/images/docs.svg
@@ -0,0 +1,3 @@
+
diff --git a/src/images/eth-diamond-color.png b/src/images/eth-diamond-color.png
deleted file mode 100644
index bc4c7aa..0000000
Binary files a/src/images/eth-diamond-color.png and /dev/null differ
diff --git a/src/images/eth-logo-blue.svg b/src/images/eth-logo-blue.svg
new file mode 100644
index 0000000..393fec4
--- /dev/null
+++ b/src/images/eth-logo-blue.svg
@@ -0,0 +1,69 @@
+
+
+
+
diff --git a/src/images/footer.png b/src/images/footer.png
deleted file mode 100644
index b7e393f..0000000
Binary files a/src/images/footer.png and /dev/null differ
diff --git a/src/images/globe.svg b/src/images/globe.svg
deleted file mode 100644
index b321f93..0000000
--- a/src/images/globe.svg
+++ /dev/null
@@ -1,3 +0,0 @@
-
diff --git a/src/images/img-bear-access.svg b/src/images/img-bear-access.svg
new file mode 100644
index 0000000..44c761a
--- /dev/null
+++ b/src/images/img-bear-access.svg
@@ -0,0 +1,17 @@
+
diff --git a/src/images/img-bear.svg b/src/images/img-bear.svg
new file mode 100644
index 0000000..edde5af
--- /dev/null
+++ b/src/images/img-bear.svg
@@ -0,0 +1,10 @@
+
diff --git a/src/images/img-block-to-app.svg b/src/images/img-block-to-app.svg
new file mode 100644
index 0000000..e78d3e2
--- /dev/null
+++ b/src/images/img-block-to-app.svg
@@ -0,0 +1,32 @@
+
diff --git a/src/images/img-elephant-love.svg b/src/images/img-elephant-love.svg
new file mode 100644
index 0000000..3e62969
--- /dev/null
+++ b/src/images/img-elephant-love.svg
@@ -0,0 +1,36 @@
+
diff --git a/src/images/img-elephant-reading.svg b/src/images/img-elephant-reading.svg
new file mode 100644
index 0000000..128bd62
--- /dev/null
+++ b/src/images/img-elephant-reading.svg
@@ -0,0 +1,21 @@
+
diff --git a/src/images/img-proveyouself.svg b/src/images/img-proveyouself.svg
new file mode 100644
index 0000000..a770912
--- /dev/null
+++ b/src/images/img-proveyouself.svg
@@ -0,0 +1,15 @@
+
diff --git a/src/images/interep.svg b/src/images/interep.svg
deleted file mode 100644
index 041c5f2..0000000
--- a/src/images/interep.svg
+++ /dev/null
@@ -1,4 +0,0 @@
-
diff --git a/src/images/lock-gfc.svg b/src/images/lock-gfc.svg
deleted file mode 100644
index d6b232f..0000000
--- a/src/images/lock-gfc.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/src/images/overview-pretty.png b/src/images/overview-pretty.png
new file mode 100644
index 0000000..0f4b6ad
Binary files /dev/null and b/src/images/overview-pretty.png differ
diff --git a/src/images/pse-deco.png b/src/images/pse-deco.png
deleted file mode 100644
index f7a1ec0..0000000
Binary files a/src/images/pse-deco.png and /dev/null differ
diff --git a/src/images/pse-deco.svg b/src/images/pse-deco.svg
deleted file mode 100644
index 8a14b6b..0000000
--- a/src/images/pse-deco.svg
+++ /dev/null
@@ -1,58 +0,0 @@
-
diff --git a/src/images/pse-logo.svg b/src/images/pse-logo.svg
deleted file mode 100644
index 476a515..0000000
--- a/src/images/pse-logo.svg
+++ /dev/null
@@ -1,6 +0,0 @@
-
diff --git a/src/images/pse-og.png b/src/images/pse-og.png
deleted file mode 100644
index c3d234e..0000000
Binary files a/src/images/pse-og.png and /dev/null differ
diff --git a/src/images/rln.png b/src/images/rln.png
deleted file mode 100644
index f7a7eed..0000000
Binary files a/src/images/rln.png and /dev/null differ
diff --git a/src/images/rln.svg b/src/images/rln.svg
deleted file mode 100644
index 41f8e34..0000000
--- a/src/images/rln.svg
+++ /dev/null
@@ -1,88 +0,0 @@
-
diff --git a/src/images/semaphore.svg b/src/images/semaphore.svg
deleted file mode 100644
index 0bad963..0000000
--- a/src/images/semaphore.svg
+++ /dev/null
@@ -1,13 +0,0 @@
-
diff --git a/src/images/site-footer.svg b/src/images/site-footer.svg
deleted file mode 100644
index 70cda64..0000000
--- a/src/images/site-footer.svg
+++ /dev/null
@@ -1,63 +0,0 @@
-
diff --git a/src/images/telegram.svg b/src/images/telegram.svg
deleted file mode 100644
index 1f7cd5e..0000000
--- a/src/images/telegram.svg
+++ /dev/null
@@ -1,3 +0,0 @@
-
diff --git a/src/images/tlsn-logo.svg b/src/images/tlsn-logo.svg
new file mode 100644
index 0000000..1b6d6d0
--- /dev/null
+++ b/src/images/tlsn-logo.svg
@@ -0,0 +1,6 @@
+
diff --git a/src/images/triangle-gfc.svg b/src/images/triangle-gfc.svg
deleted file mode 100644
index 7e77502..0000000
--- a/src/images/triangle-gfc.svg
+++ /dev/null
@@ -1 +0,0 @@
-
\ No newline at end of file
diff --git a/src/images/trust-setup.svg b/src/images/trust-setup.svg
deleted file mode 100644
index ba403df..0000000
--- a/src/images/trust-setup.svg
+++ /dev/null
@@ -1,12 +0,0 @@
-
diff --git a/src/images/unirep.svg b/src/images/unirep.svg
deleted file mode 100644
index bbaf732..0000000
--- a/src/images/unirep.svg
+++ /dev/null
@@ -1,86 +0,0 @@
-
diff --git a/src/images/zk-keeper.png b/src/images/zk-keeper.png
deleted file mode 100644
index d21f4b0..0000000
Binary files a/src/images/zk-keeper.png and /dev/null differ
diff --git a/src/images/zk-keeper.svg b/src/images/zk-keeper.svg
deleted file mode 100644
index af4c289..0000000
--- a/src/images/zk-keeper.svg
+++ /dev/null
@@ -1,20 +0,0 @@
-
diff --git a/src/images/zk-kit.svg b/src/images/zk-kit.svg
deleted file mode 100644
index 01db4c9..0000000
--- a/src/images/zk-kit.svg
+++ /dev/null
@@ -1,25 +0,0 @@
-
diff --git a/src/images/zkEVM.svg b/src/images/zkEVM.svg
deleted file mode 100644
index e5082c4..0000000
--- a/src/images/zkEVM.svg
+++ /dev/null
@@ -1,13 +0,0 @@
-
diff --git a/src/images/zkchat.svg b/src/images/zkchat.svg
deleted file mode 100644
index fc2054a..0000000
--- a/src/images/zkchat.svg
+++ /dev/null
@@ -1,60 +0,0 @@
-
diff --git a/src/images/zkopru-cover.png b/src/images/zkopru-cover.png
deleted file mode 100644
index ffdc85a..0000000
Binary files a/src/images/zkopru-cover.png and /dev/null differ
diff --git a/src/index.css b/src/index.css
index 6cd87b4..e7c89b1 100644
--- a/src/index.css
+++ b/src/index.css
@@ -12,7 +12,10 @@
--white: #fcfcfc;
--box-shadow: -5px 3px 0px var(--gray);
--black: #151616;
- --iceberg-200: #A7E8DC;
+ --blue: #243f5f;
+ --light-blue: #8ca4c1;
+ --light-brown: #ece5d8;
+ --brown: #a27f3c;
--twitter: #1da1f2;
--telegram: #0088cc;
@@ -22,33 +25,36 @@
--discord: #7289da;
--website: var(--green);
- --background: #F2FBF9;
+ --background: #fafbfc;
+ --background-blue: #243f5f;
--text-color: #151616;
- --border-color: var(--text-color);
- --border-radius: 4px;
+ --border-color: var(--blue);
+ --border-radius: 8px;
--border: 1px solid var(--border-color);
--link-bold: #854ad1;
--padding: 10px;
}
+
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');
body {
- color: var(--black);
+ color: var(--blue);
margin: 0 auto;
- max-width: 1800px;
+ max-width: 1440px;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-rendering: optimizeLegibility;
background-color: var(--background);
background-attachment: fixed;
- font-family: 'Space Grotesk', sans-serif;;
+ font-family: 'Space Grotesk', sans-serif;
+ ;
}
h1,
h2,
h3 {
font-weight: 700;
- color: var(--black);
+ color: var(--blue);
padding: 0px;
margin: 0px;
}
@@ -62,7 +68,7 @@ h2 {
}
p {
- color: var(--black);
+ color: var(--blue);
font-weight: 400;
font-size: 1.125rem;
line-height: 120%;
@@ -72,16 +78,33 @@ p {
a {
text-decoration: none;
- color: var(--black);
+ color: var(--light-blue);
}
html {
scroll-behavior: smooth;
}
+.pill-button {
+ display: flex;
+ font-family: "Inter", sans-serif;
+ background-color: var(--white);
+ border: 3px solid var(--blue);
+ color: var(--blue);
+ text-align: center;
+ font-size: 20px;
+ font-weight: 600;
+ border-radius: 32px;
+ padding: 18px 24px;
+ align-items: center;
+}
+
+.pill-button:hover {
+ background-color: var(--light-brown);
+}
+
/*
Responsiveness
*/
-@media screen and (max-width: 800px) {
-}
+@media screen and (max-width: 800px) {}
\ No newline at end of file
diff --git a/src/index.tsx b/src/index.tsx
index 33771bb..d96208f 100644
--- a/src/index.tsx
+++ b/src/index.tsx
@@ -4,12 +4,14 @@ import './index.css';
import HomePage from './HomePage';
import { BrowserRouter, Routes, Route } from 'react-router-dom';
import reportWebVitals from './reportWebVitals';
+import './config'
const root = ReactDOM.createRoot(document.getElementById('root') as HTMLElement);
root.render(
- } />
+ } />
+ } />
);
diff --git a/webpack.config.js b/webpack.config.js
index 5c68b56..2e31d45 100644
--- a/webpack.config.js
+++ b/webpack.config.js
@@ -1,63 +1,72 @@
-const HtmlWebpackPlugin = require('html-webpack-plugin')
-const HtmlWebpackInlineSourcePlugin = require('html-webpack-inline-source-plugin')
-const path = require('path')
-const MiniCssExtractPlugin = require('mini-css-extract-plugin')
-const CssMinimizerPlugin = require('css-minimizer-webpack-plugin')
-const CopyPlugin = require('copy-webpack-plugin')
+const HtmlWebpackPlugin = require("html-webpack-plugin");
+const HtmlWebpackInlineSourcePlugin = require("html-webpack-inline-source-plugin");
+const path = require("path");
+const MiniCssExtractPlugin = require("mini-css-extract-plugin");
+const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");
+const CopyPlugin = require("copy-webpack-plugin");
module.exports = {
- entry: ['./src/index.tsx'],
- mode: 'development',
+ entry: ["./src/index.tsx"],
+ mode: "development",
output: {
- path: path.resolve(__dirname, 'build'),
- publicPath: '/',
+ path: path.resolve(__dirname, "build"),
+ publicPath: "/",
},
resolve: {
- extensions: ['*', '.js', '.jsx', '.ts', '.tsx', '.json'],
+ extensions: ["*", ".js", ".jsx", ".ts", ".tsx", ".json"],
},
module: {
rules: [
{
test: /\.(js|tsx?)$/,
- loader: 'babel-loader'
+ loader: "babel-loader",
},
{
test: /\.(png|svg|jpg|gif|ico)$/,
- loader: 'file-loader',
+ loader: "file-loader",
options: {
- // publicPath: 'build',
+ publicPath: './',
esModule: false,
- }
+ },
},
{
test: /\.css$/,
// exclude: /node_modules/,
- use: [{
- loader: MiniCssExtractPlugin.loader,
- }, 'css-loader',]
- }
- ]
+ use: [
+ {
+ loader: MiniCssExtractPlugin.loader,
+ },
+ "css-loader",
+ ],
+ },
+ ],
},
plugins: [
new HtmlWebpackPlugin({
- template: 'public/index.html',
- filename: 'index.html',
- inlineSource: '.(js|css)',
+ template: "public/index.html",
+ filename: "index.html",
+ inlineSource: ".(js|css)",
+ publicPath: "./",
}),
new MiniCssExtractPlugin({
- filename: 'styles.css',
+ filename: "styles.css",
}),
new CopyPlugin({
patterns: [
- { from: './public/manifest.json', to: 'manifest.json' },
+ {
+ from: "./public/manifest.json",
+ to: "manifest.json"
+ },
+ {
+ from: "./public/*.pdf",
+ to: "[name][ext]",
+ noErrorOnMissing: true
+ }
],
}),
// new HtmlWebpackInlineSourcePlugin(),
],
optimization: {
- minimizer: [
- `...`,
- new CssMinimizerPlugin(),
- ],
+ minimizer: [`...`, new CssMinimizerPlugin()],
},
-}
+};
diff --git a/webpack.prerender.js b/webpack.prerender.js
index f76c320..b7300b1 100644
--- a/webpack.prerender.js
+++ b/webpack.prerender.js
@@ -24,7 +24,7 @@ module.exports = {
test: /\.(png|svg|jpg|gif)$/,
loader: 'file-loader',
options: {
- // publicPath: 'build',
+ publicPath: './',
esModule: false,
}
},