Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
80d36d5
add demo dropdown nav to landing page header
daniellam258 Mar 24, 2026
ec0a613
Make Walrus epoch defaults network-aware
useername Mar 24, 2026
9625311
chore: update dockerfile app
daniellam258 Mar 24, 2026
0bdd517
feat(sdk): auto-increment prerelease versions for dev/staging branches
ducnmm Mar 24, 2026
5e53bdc
fix(sdk): use node -e instead of npm version to avoid workspace confl…
ducnmm Mar 24, 2026
326810e
Document network-specific Walrus epoch defaults
useername Mar 24, 2026
b933185
Revise environment variable section and title
Aaron1924 Mar 24, 2026
f0d2dae
docs: use placeholders instead of process.env in quick start
daniellam258 Mar 24, 2026
09fdb93
docs: add public relayer URLs for production and staging
daniellam258 Mar 24, 2026
7496e30
docs: update self-hosting network env vars
Aaron1924 Mar 24, 2026
9ffe7e5
docs: add example apps guide and remove duplicate basic usage
Aaron1924 Mar 24, 2026
5e483f9
docs: sync docs folder with dev
Aaron1924 Mar 24, 2026
7d986df
docs: surface network ids and reorder examples tab
Aaron1924 Mar 24, 2026
a845c40
fix: add VITE_DEMO_URLS to walrus deploy workflow
ducnmm Mar 24, 2026
fbb149a
Merge pull request #19 from MystenLabs/fix/walrus-var
ducnmm Mar 24, 2026
d00e01a
docs: update MemWal positioning copy
Aaron1924 Mar 24, 2026
1dab127
Merge remote-tracking branch 'origin/dev' into feat/docs
Aaron1924 Mar 24, 2026
47c0fbd
Merge pull request #22 from MystenLabs/feat/docs
ducnmm Mar 24, 2026
998255f
docs: remove duplicate examples tab
Aaron1924 Mar 24, 2026
864bb07
Merge pull request #23 from MystenLabs/fix/docs-remove-duplicate-exam…
Aaron1924 Mar 24, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .github/workflows/deploy-app-walrus.yml
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ jobs:
VITE_MEMWAL_REGISTRY_ID: ${{ vars.VITE_MEMWAL_REGISTRY_ID }}
VITE_SEAL_KEY_SERVERS: ${{ vars.VITE_SEAL_KEY_SERVERS }}
VITE_DOCS_URL: ${{ vars.VITE_DOCS_URL }}
VITE_DEMO_URLS: ${{ vars.VITE_DEMO_URLS }}

- name: Deploy to Walrus Site (Mainnet)
id: deploy-mainnet
Expand Down
57 changes: 40 additions & 17 deletions .github/workflows/release-sdk.yml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ on:
- dev
paths:
- 'packages/sdk/**'
- '.changeset/**'
- '.github/workflows/release-sdk.yml'
workflow_dispatch:

Expand Down Expand Up @@ -47,34 +46,58 @@ jobs:
run: pnpm build:sdk

# ── main branch → stable release (latest) ──
- name: Create Release PR or Publish to npm
- name: Publish stable release
if: github.ref == 'refs/heads/main'
uses: changesets/action@v1
with:
title: 'chore: version packages'
commit: 'chore: version packages'
publish: pnpm changeset publish
run: |
BASE_VERSION=$(node -p "require('./packages/sdk/package.json').version")
npm view @mysten/memwal@$BASE_VERSION version 2>/dev/null \
&& echo "Version $BASE_VERSION already published, skipping" && exit 0
cd packages/sdk && npm publish --access public
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}

# ── staging branch → release candidate (rc tag) ──
# ── staging branch → release candidate (rc tag, auto-increment) ──
- name: Publish staging release candidate
if: github.ref == 'refs/heads/staging'
run: |
PKG_VERSION=$(node -p "require('./packages/sdk/package.json').version")
npm view @mysten/memwal@$PKG_VERSION version 2>/dev/null && echo "Version $PKG_VERSION already published, skipping" && exit 0
cd packages/sdk && npm publish --tag rc --access public
BASE_VERSION=$(node -p "require('./packages/sdk/package.json').version")
LATEST=$(npm view @mysten/memwal versions --json 2>/dev/null \
| node -p "
const versions = JSON.parse(require('fs').readFileSync('/dev/stdin','utf8'));
const nums = (Array.isArray(versions) ? versions : [versions])
.filter(v => v.startsWith('${BASE_VERSION}-rc.'))
.map(v => +v.split('-rc.')[1])
.sort((a,b) => b - a);
nums.length ? nums[0] : -1;
" || echo "-1")
NEXT=$((LATEST + 1))
NEW_VERSION="${BASE_VERSION}-rc.${NEXT}"
echo "Publishing @mysten/memwal@${NEW_VERSION}"
cd packages/sdk
node -e "const p=require('./package.json');p.version='${NEW_VERSION}';require('fs').writeFileSync('./package.json',JSON.stringify(p,null,4)+'\n')"
npm publish --tag rc --access public
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}

# ── dev branch → prerelease (dev tag) ──
# ── dev branch → prerelease (dev tag, auto-increment) ──
- name: Publish dev prerelease
if: github.ref == 'refs/heads/dev'
run: |
PKG_VERSION=$(node -p "require('./packages/sdk/package.json').version")
npm view @mysten/memwal@$PKG_VERSION version 2>/dev/null && echo "Version $PKG_VERSION already published, skipping" && exit 0
cd packages/sdk && npm publish --tag dev --access public
BASE_VERSION=$(node -p "require('./packages/sdk/package.json').version")
LATEST=$(npm view @mysten/memwal versions --json 2>/dev/null \
| node -p "
const versions = JSON.parse(require('fs').readFileSync('/dev/stdin','utf8'));
const nums = (Array.isArray(versions) ? versions : [versions])
.filter(v => v.startsWith('${BASE_VERSION}-dev.'))
.map(v => +v.split('-dev.')[1])
.sort((a,b) => b - a);
nums.length ? nums[0] : -1;
" || echo "-1")
NEXT=$((LATEST + 1))
NEW_VERSION="${BASE_VERSION}-dev.${NEXT}"
echo "Publishing @mysten/memwal@${NEW_VERSION}"
cd packages/sdk
node -e "const p=require('./package.json');p.version='${NEW_VERSION}';require('fs').writeFileSync('./package.json',JSON.stringify(p,null,4)+'\n')"
npm publish --tag dev --access public
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
4 changes: 4 additions & 0 deletions apps/app/.env.example
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,10 @@ VITE_MEMWAL_SERVER_URL=http://localhost:8000
# Docs URL (separate deployment)
VITE_DOCS_URL=http://localhost:5174

# Demo app links (comma-separated, format: Label|URL)
# Example: VITE_DEMO_URLS=Chat Demo|https://chat.example.com,Agent Demo|https://agent.example.com
VITE_DEMO_URLS=

# ══════════════════════════════════════════════════════════════
# ▷ INACTIVE: MAINNET (uncomment below, comment out TESTNET above)
# ══════════════════════════════════════════════════════════════
Expand Down
2 changes: 2 additions & 0 deletions apps/app/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ ARG VITE_SUI_NETWORK=mainnet
ARG VITE_ENOKI_API_KEY
ARG VITE_GOOGLE_CLIENT_ID
ARG VITE_DOCS_URL
ARG VITE_DEMO_URLS

ENV VITE_MEMWAL_SERVER_URL=$VITE_MEMWAL_SERVER_URL
ENV VITE_MEMWAL_PACKAGE_ID=$VITE_MEMWAL_PACKAGE_ID
Expand All @@ -43,6 +44,7 @@ ENV VITE_SUI_NETWORK=$VITE_SUI_NETWORK
ENV VITE_ENOKI_API_KEY=$VITE_ENOKI_API_KEY
ENV VITE_GOOGLE_CLIENT_ID=$VITE_GOOGLE_CLIENT_ID
ENV VITE_DOCS_URL=$VITE_DOCS_URL
ARG VITE_DEMO_URLS=$VITE_DEMO_URLS

RUN pnpm --filter @memwal/app build

Expand Down
6 changes: 6 additions & 0 deletions apps/app/src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,4 +14,10 @@ export const config = {
.split(',').map(s => s.trim()).filter(Boolean) as string[],
sidecarUrl: import.meta.env.VITE_SIDECAR_URL as string || 'http://localhost:9000',
docsUrl: import.meta.env.VITE_DOCS_URL as string || '',
demoUrls: (import.meta.env.VITE_DEMO_URLS as string || '')
.split(',').map(s => s.trim()).filter(Boolean)
.map(entry => {
const [label, url] = entry.split('|').map(s => s.trim())
return url ? { label, url } : { label: label, url: label }
}),
} as const
84 changes: 84 additions & 0 deletions apps/app/src/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -515,6 +515,90 @@ h1, h2, h3 {
box-shadow: 1px 1px 0 #000000;
}

/* ── Demo Dropdown ── */

.lp-demo-dropdown {
position: relative;
}

.lp-demo-trigger {
display: flex;
align-items: center;
gap: 4px;
background: none;
border: 2px solid #000000;
border-radius: 12px;
padding: 10px 18px;
font-size: 0.92rem;
font-weight: 700;
font-family: var(--font-sans);
cursor: pointer;
transition: transform 0.15s, box-shadow 0.15s;
box-shadow: 3px 3px 0 #000000;
color: #000000;
background: #ffffff;
}

.lp-demo-trigger:hover {
transform: translate(-2px, -2px);
box-shadow: 5px 5px 0 #000000;
}

.lp-demo-trigger:active {
transform: translate(2px, 2px);
box-shadow: 1px 1px 0 #000000;
}

.lp-demo-chevron {
transition: transform 0.2s;
}

.lp-demo-chevron.open {
transform: rotate(180deg);
}

.lp-demo-menu {
position: absolute;
top: calc(100% + 8px);
right: 0;
min-width: 200px;
background: #ffffff;
border: 2px solid #000000;
border-radius: 12px;
box-shadow: 4px 4px 0 #000000;
padding: 6px;
z-index: 100;
animation: lp-dropdown-in 0.15s ease-out;
}

@keyframes lp-dropdown-in {
from {
opacity: 0;
transform: translateY(-4px);
}
to {
opacity: 1;
transform: translateY(0);
}
}

.lp-demo-item {
display: flex;
align-items: center;
justify-content: space-between;
padding: 10px 14px;
color: #000000;
text-decoration: none;
font-size: 0.88rem;
font-weight: 600;
border-radius: 8px;
transition: background 0.1s;
}

.lp-demo-item:hover {
background: #E8FF75;
}

/* ── Hero ── */

.lp-hero {
Expand Down
42 changes: 41 additions & 1 deletion apps/app/src/pages/LandingPage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,8 @@ import {
useWallets,
} from '@mysten/dapp-kit'
import { isEnokiWallet, type EnokiWallet, type AuthProvider } from '@mysten/enoki'
import { Github } from 'lucide-react'
import { ChevronDown, Github } from 'lucide-react'
import { useRef, useState, useEffect } from 'react'
import { useNavigate } from 'react-router-dom'
import { config } from '../config'
import memwalLogo from '../assets/memwal-logo.svg'
Expand All @@ -29,6 +30,19 @@ export default function LandingPage() {

const navigate = useNavigate()
const hasEnokiConfig = config.enokiApiKey && config.googleClientId
const demoUrls = config.demoUrls
const [demoOpen, setDemoOpen] = useState(false)
const demoRef = useRef<HTMLDivElement>(null)

useEffect(() => {
const handleClickOutside = (e: MouseEvent) => {
if (demoRef.current && !demoRef.current.contains(e.target as Node)) {
setDemoOpen(false)
}
}
document.addEventListener('mousedown', handleClickOutside)
return () => document.removeEventListener('mousedown', handleClickOutside)
}, [])

const handleConnect = () => {
if (currentAccount) {
Expand All @@ -49,6 +63,32 @@ export default function LandingPage() {
</a>

<div className="lp-nav-links">
{demoUrls.length > 0 && (
<div className="lp-demo-dropdown" ref={demoRef}>
<button
className="lp-demo-trigger"
onClick={() => setDemoOpen(o => !o)}
>
Demo <ChevronDown size={14} className={`lp-demo-chevron${demoOpen ? ' open' : ''}`} />
</button>
{demoOpen && (
<div className="lp-demo-menu">
{demoUrls.map(({ label, url }) => (
<a
key={url}
href={url}
target="_blank"
rel="noopener noreferrer"
className="lp-demo-item"
onClick={() => setDemoOpen(false)}
>
{label} <span className="lp-arrow">↗</span>
</a>
))}
</div>
)}
</div>
)}
{currentAccount ? (
<button className="lp-nav-cta" onClick={() => navigate('/dashboard')}>
Playground <span className="lp-arrow">↗</span>
Expand Down
22 changes: 22 additions & 0 deletions docs/contract/overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,28 @@ title: "Smart Contract Overview"

The smart contract (`memwal::account`) defines the onchain account model for MemWal. It is a Move module deployed on Sui.

## Network IDs

These are the onchain IDs for the current public MemWal deployments:

### Staging (Testnet)

```env
SUI_NETWORK=testnet
MEMWAL_PACKAGE_ID=0xcf6ad755a1cdff7217865c796778fabe5aa399cb0cf2eba986f4b582047229c6
MEMWAL_REGISTRY_ID=0xe80f2feec1c139616a86c9f71210152e2a7ca552b20841f2e192f99f75864437
```

### Production (Mainnet)

```env
SUI_NETWORK=mainnet
MEMWAL_PACKAGE_ID=0xcee7a6fd8de52ce645c38332bde23d4a30fd9426bc4681409733dd50958a24c6
MEMWAL_REGISTRY_ID=0x0da982cefa26864ae834a8a0504b904233d49e20fcc17c373c8bed99c75a7edd
```

For relayer setup and environment variable usage, see [Self-Hosting](/relayer/self-hosting) and [Environment Variables](/reference/environment-variables).

## What It Manages

- **Ownership** — who owns a MemWal account
Expand Down
11 changes: 11 additions & 0 deletions docs/docs.json
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,17 @@
}
]
},
{
"tab": "Examples",
"groups": [
{
"group": "Examples",
"pages": [
"examples/example-apps"
]
}
]
},
{
"tab": "Reference",
"groups": [
Expand Down
Loading
Loading